mirror of https://github.com/apache/jclouds.git
JCLOUDS-217: Percent encoding changes.
jclouds should not check if the string is encoded, but rather expect that all strings would be encoded prior to transmission. As part of that change, we must make sure that no code relies on such behavior within jclouds. This commit adds a blobstore test to check encoding pattern for blobs. It also removes the encoding check in the Strings2 class and the related test.
This commit is contained in:
parent
9be7339c32
commit
aaa164179c
|
@ -47,6 +47,7 @@ import org.jclouds.blobstore.domain.ContainerAccess;
|
||||||
import org.jclouds.blobstore.domain.PageSet;
|
import org.jclouds.blobstore.domain.PageSet;
|
||||||
import org.jclouds.blobstore.domain.StorageMetadata;
|
import org.jclouds.blobstore.domain.StorageMetadata;
|
||||||
import org.jclouds.blobstore.options.ListContainerOptions;
|
import org.jclouds.blobstore.options.ListContainerOptions;
|
||||||
|
import org.testng.annotations.DataProvider;
|
||||||
import org.testng.annotations.Test;
|
import org.testng.annotations.Test;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
import com.google.common.collect.ImmutableMap;
|
||||||
|
@ -561,7 +562,31 @@ public class BaseContainerIntegrationTest extends BaseBlobStoreIntegrationTest {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void checkEqualNames(ImmutableSet<String> expectedSet, PageSet<? extends StorageMetadata> results) {
|
@DataProvider
|
||||||
|
public Object[][] getBlobsToEscape() {
|
||||||
|
ImmutableSet<String> testNames = ImmutableSet.of("%20", "%20 ", " %20", " ");
|
||||||
|
Object[][] result = new Object[1][1];
|
||||||
|
result[0][0] = testNames;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(dataProvider = "getBlobsToEscape", groups = {"integration", "live"})
|
||||||
|
public void testBlobNameEscaping(Set<String> blobNames) throws InterruptedException {
|
||||||
|
final String containerName = getContainerName();
|
||||||
|
BlobStore blobStore = view.getBlobStore();
|
||||||
|
try {
|
||||||
|
for (String name : blobNames) {
|
||||||
|
Blob blob = blobStore.blobBuilder(name).payload(ByteSource.wrap("test".getBytes())).contentLength(4)
|
||||||
|
.build();
|
||||||
|
blobStore.putBlob(containerName, blob);
|
||||||
|
}
|
||||||
|
checkEqualNames(blobNames, blobStore.list(containerName));
|
||||||
|
} finally {
|
||||||
|
returnContainer(containerName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkEqualNames(Set<String> expectedSet, PageSet<? extends StorageMetadata> results) {
|
||||||
Set<String> names = new HashSet<String>();
|
Set<String> names = new HashSet<String>();
|
||||||
for (StorageMetadata sm : results) {
|
for (StorageMetadata sm : results) {
|
||||||
names.add(sm.getName());
|
names.add(sm.getName());
|
||||||
|
|
|
@ -144,7 +144,6 @@ public final class Uris {
|
||||||
}
|
}
|
||||||
|
|
||||||
public UriBuilder appendPath(String path) {
|
public UriBuilder appendPath(String path) {
|
||||||
path = urlDecode(checkNotNull(path, "path"));
|
|
||||||
if (this.path == null) {
|
if (this.path == null) {
|
||||||
path(path);
|
path(path);
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -53,8 +53,6 @@ public class Strings2 {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String urlEncode(String in, Iterable<Character> skipEncode) {
|
public static String urlEncode(String in, Iterable<Character> skipEncode) {
|
||||||
if (isUrlEncoded(in))
|
|
||||||
return in;
|
|
||||||
try {
|
try {
|
||||||
String returnVal = URLEncoder.encode(in, "UTF-8");
|
String returnVal = URLEncoder.encode(in, "UTF-8");
|
||||||
returnVal = returnVal.replace("+", "%20");
|
returnVal = returnVal.replace("+", "%20");
|
||||||
|
@ -109,11 +107,10 @@ public class Strings2 {
|
||||||
public static String urlDecode(@Nullable String in) {
|
public static String urlDecode(@Nullable String in) {
|
||||||
if (in == null)
|
if (in == null)
|
||||||
return null;
|
return null;
|
||||||
String input = in.toString();
|
if (!isUrlEncoded(in)) {
|
||||||
// Don't double decode
|
return in;
|
||||||
if (!isUrlEncoded(input)) {
|
|
||||||
return input;
|
|
||||||
}
|
}
|
||||||
|
String input = in.toString();
|
||||||
try {
|
try {
|
||||||
return URLDecoder.decode(input, "UTF-8");
|
return URLDecoder.decode(input, "UTF-8");
|
||||||
} catch (UnsupportedEncodingException e) {
|
} catch (UnsupportedEncodingException e) {
|
||||||
|
|
|
@ -32,12 +32,6 @@ public class Strings2Test {
|
||||||
assert !Strings2.isUrlEncoded("/read-tests/ tep");
|
assert !Strings2.isUrlEncoded("/read-tests/ tep");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testNoDoubleEncode() {
|
|
||||||
assertEquals(urlEncode("/read-tests/%73%6f%6d%65%20%66%69%6c%65", '/'),
|
|
||||||
"/read-tests/%73%6f%6d%65%20%66%69%6c%65");
|
|
||||||
assertEquals(urlEncode("/read-tests/ tep", '/'), "/read-tests/%20tep");
|
|
||||||
}
|
|
||||||
|
|
||||||
public void testNoDoubleDecode() {
|
public void testNoDoubleDecode() {
|
||||||
assertEquals(urlDecode("foo%20bar%2Bbaz"), "foo bar+baz");
|
assertEquals(urlDecode("foo%20bar%2Bbaz"), "foo bar+baz");
|
||||||
assertEquals(urlDecode("foo bar+baz"), "foo bar+baz");
|
assertEquals(urlDecode("foo bar+baz"), "foo bar+baz");
|
||||||
|
|
Loading…
Reference in New Issue