Issue 1052:Path incorrect when S3 in path-mode and servicePath is default

This commit is contained in:
Adrian Cole 2012-08-01 11:14:10 -07:00
parent 795dd48abb
commit 1abcffb612
3 changed files with 106 additions and 4 deletions

View File

@ -69,13 +69,18 @@ public class BindAsHostPrefixIfConfigured implements Binder {
return (R) request.toBuilder().replaceHeader(HttpHeaders.HOST, host).build(); return (R) request.toBuilder().replaceHeader(HttpHeaders.HOST, host).build();
} else { } else {
StringBuilder path = new StringBuilder(request.getEndpoint().getPath()); StringBuilder path = new StringBuilder(request.getEndpoint().getPath());
if (servicePath.equals("/")) {
if (path.toString().equals("/"))
path.append(payloadAsString);
else
path.insert(0, "/" + payloadAsString);
} else {
int indexToInsert = 0; int indexToInsert = 0;
if (!servicePath.equals("/")) {
indexToInsert = path.indexOf(servicePath); indexToInsert = path.indexOf(servicePath);
indexToInsert = indexToInsert == -1 ? 0 : indexToInsert; indexToInsert = indexToInsert == -1 ? 0 : indexToInsert;
indexToInsert += servicePath.length(); indexToInsert += servicePath.length();
}
path.insert(indexToInsert, "/" + payloadAsString); path.insert(indexToInsert, "/" + payloadAsString);
}
return (R) request.toBuilder().replacePath(path.toString()).build(); return (R) request.toBuilder().replacePath(path.toString()).build();
} }
} }

View File

@ -85,7 +85,8 @@ public class ParseS3ErrorFromXmlContent extends ParseAWSErrorFromXmlContent {
exception = new ContainerNotFoundException(container, message); exception = new ContainerNotFoundException(container, message);
else else
exception = new KeyNotFoundException(container, key, message); exception = new KeyNotFoundException(container, key, message);
} else if (command.getCurrentRequest().getEndpoint().getPath().indexOf(servicePath + "/") == 0) { } else if (command.getCurrentRequest().getEndpoint().getPath()
.indexOf(servicePath.equals("/") ? "/" : servicePath + "/") == 0) {
String path = command.getCurrentRequest().getEndpoint().getPath().substring(servicePath.length()); String path = command.getCurrentRequest().getEndpoint().getPath().substring(servicePath.length());
List<String> parts = newArrayList(filter(Splitter.on('/').split(path), not(equalTo("")))); List<String> parts = newArrayList(filter(Splitter.on('/').split(path), not(equalTo(""))));
if (parts.size() == 1) { if (parts.size() == 1) {

View File

@ -0,0 +1,96 @@
/**
* Licensed to jclouds, Inc. (jclouds) under one or more
* contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. jclouds licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.jclouds.s3;
import static org.jclouds.s3.reference.S3Constants.PROPERTY_S3_VIRTUAL_HOST_BUCKETS;
import java.util.Properties;
import org.jclouds.http.HttpRequest;
import org.jclouds.http.HttpResponse;
import org.jclouds.s3.domain.S3Object;
import org.jclouds.s3.internal.BaseS3ClientExpectTest;
import org.testng.Assert;
import org.testng.annotations.Test;
import com.google.common.net.HttpHeaders;
/**
*
* @author Adrian Cole
*/
@Test(groups = "unit", testName = "PathBasedS3ClientExpectTest")
public class PathBasedS3ClientExpectTest extends BaseS3ClientExpectTest {
@Override
protected Properties setupProperties() {
Properties overrides = super.setupProperties();
overrides.setProperty(PROPERTY_S3_VIRTUAL_HOST_BUCKETS, "false");
return overrides;
}
@Test
public void testBucketExistsReturnsTrueOn200AndFalseOn404() {
HttpRequest bucketFooExists = HttpRequest.builder().method("HEAD")
.endpoint("https://s3.amazonaws.com/foo?max-keys=0")
.addHeader("Date", CONSTANT_DATE)
.addHeader("Authorization", "AWS identity:lLD0mzo2bZPIWhxlFDZoT09MKUQ=")
.build();
S3Client clientWhenBucketExists = requestSendsResponse(bucketFooExists, HttpResponse.builder().statusCode(200).build());
assert clientWhenBucketExists.bucketExists("foo");
S3Client clientWhenBucketDoesntExist = requestSendsResponse(bucketFooExists, HttpResponse.builder().statusCode(404).build());
assert !clientWhenBucketDoesntExist.bucketExists("foo");
}
@Test
public void testPutBucketReturnsTrueOn200() {
HttpRequest bucketFooExists = HttpRequest.builder().method("PUT")
.endpoint("https://s3.amazonaws.com/foo")
.addHeader("Date", CONSTANT_DATE)
.addHeader("Authorization", "AWS identity:GeP4OqEL/eM+gQt+4Vtcm02gebc=")
.build();
S3Client clientWhenBucketExists = requestSendsResponse(bucketFooExists, HttpResponse.builder().statusCode(200).build());
assert clientWhenBucketExists.putBucketInRegion(null, "foo");
}
@Test
public void testPutObjectReturnsETagOn200() {
HttpRequest bucketFooExists = HttpRequest.builder().method("PUT")
.endpoint("https://s3.amazonaws.com/bucket/object")
.addHeader("Date", CONSTANT_DATE)
.addHeader("Authorization", "AWS identity:6gC0m7SYFDPwkUqY5EHV/6i9DfM=")
.payload("hello world")
.build();
S3Client clientWhenBucketExists = requestSendsResponse(bucketFooExists, HttpResponse.builder().statusCode(200).addHeader(HttpHeaders.ETAG, "etag").build());
S3Object object = clientWhenBucketExists.newS3Object();
object.getMetadata().setKey("object");
object.setPayload("hello world");
Assert.assertEquals(clientWhenBucketExists.putObject("bucket", object), "etag");
}
}