mirror of https://github.com/apache/jclouds.git
JCLOUDS-155: Making header handling in OpenStack case-insensitive
Submitted by Rodney Beede
This commit is contained in:
parent
bf723a8649
commit
375cb2075d
|
@ -56,9 +56,11 @@ public class ParseAuthenticationResponseFromHeaders implements Function<HttpResp
|
||||||
*/
|
*/
|
||||||
public AuthenticationResponse apply(HttpResponse from) {
|
public AuthenticationResponse apply(HttpResponse from) {
|
||||||
releasePayload(from);
|
releasePayload(from);
|
||||||
|
|
||||||
|
// HTTP headers are case insensitive (RFC 2616) so we must allow for that when looking an header names for the URL keyword
|
||||||
Builder<String, URI> builder = ImmutableMap.builder();
|
Builder<String, URI> builder = ImmutableMap.builder();
|
||||||
for (Entry<String, String> entry : from.getHeaders().entries()) {
|
for (Entry<String, String> entry : from.getHeaders().entries()) {
|
||||||
if (entry.getKey().endsWith(URL_SUFFIX))
|
if (entry.getKey().toLowerCase().endsWith(URL_SUFFIX.toLowerCase()))
|
||||||
builder.put(entry.getKey(), getURI(entry.getValue()));
|
builder.put(entry.getKey(), getURI(entry.getValue()));
|
||||||
}
|
}
|
||||||
AuthenticationResponse response = new AuthenticationResponse(checkNotNull(from.getFirstHeaderOrNull(AUTH_TOKEN),
|
AuthenticationResponse response = new AuthenticationResponse(checkNotNull(from.getFirstHeaderOrNull(AUTH_TOKEN),
|
||||||
|
|
|
@ -21,7 +21,6 @@ import static org.testng.Assert.assertEquals;
|
||||||
import java.net.URI;
|
import java.net.URI;
|
||||||
|
|
||||||
import org.jclouds.Constants;
|
import org.jclouds.Constants;
|
||||||
import org.jclouds.blobstore.reference.BlobStoreConstants;
|
|
||||||
import org.jclouds.http.HttpResponse;
|
import org.jclouds.http.HttpResponse;
|
||||||
import org.jclouds.openstack.domain.AuthenticationResponse;
|
import org.jclouds.openstack.domain.AuthenticationResponse;
|
||||||
import org.testng.annotations.Test;
|
import org.testng.annotations.Test;
|
||||||
|
@ -33,8 +32,8 @@ import com.google.inject.Injector;
|
||||||
import com.google.inject.name.Names;
|
import com.google.inject.name.Names;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests behavior of {@code ParseContainerListFromJsonResponse}
|
* Tests behavior of {@code ParseAuthenticationResponseFromHeaders}
|
||||||
*
|
*
|
||||||
* @author Adrian Cole
|
* @author Adrian Cole
|
||||||
*/
|
*/
|
||||||
@Test(groups = "unit", testName = "ParseAuthenticationResponseFromHeadersTest")
|
@Test(groups = "unit", testName = "ParseAuthenticationResponseFromHeadersTest")
|
||||||
|
@ -44,7 +43,6 @@ public class ParseAuthenticationResponseFromHeadersTest {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void configure() {
|
protected void configure() {
|
||||||
bindConstant().annotatedWith(Names.named(BlobStoreConstants.PROPERTY_USER_METADATA_PREFIX)).to("sdf");
|
|
||||||
bindConstant().annotatedWith(Names.named(Constants.PROPERTY_API_VERSION)).to("1");
|
bindConstant().annotatedWith(Names.named(Constants.PROPERTY_API_VERSION)).to("1");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -53,14 +51,27 @@ public class ParseAuthenticationResponseFromHeadersTest {
|
||||||
public void testReplaceLocalhost() {
|
public void testReplaceLocalhost() {
|
||||||
ParseAuthenticationResponseFromHeaders parser = i.getInstance(ParseAuthenticationResponseFromHeaders.class);
|
ParseAuthenticationResponseFromHeaders parser = i.getInstance(ParseAuthenticationResponseFromHeaders.class);
|
||||||
parser = parser.setHostToReplace("fooman");
|
parser = parser.setHostToReplace("fooman");
|
||||||
|
|
||||||
HttpResponse response = HttpResponse.builder().statusCode(204).message("No Content")
|
HttpResponse response = HttpResponse.builder().statusCode(204).message("No Content")
|
||||||
.addHeader("X-Auth-Token", "token")
|
.addHeader("X-Auth-Token", "token")
|
||||||
.addHeader("X-Storage-Token", "token")
|
.addHeader("X-Storage-Token", "token")
|
||||||
.addHeader("X-Storage-Url", "http://127.0.0.1:8080/v1/token").build();
|
.addHeader("X-Storage-Url", "http://127.0.0.1:8080/v1/token").build();
|
||||||
|
|
||||||
AuthenticationResponse md = parser.apply(response);
|
AuthenticationResponse md = parser.apply(response);
|
||||||
assertEquals(md, new AuthenticationResponse("token", ImmutableMap.<String, URI> of("X-Storage-Url", URI
|
assertEquals(md, new AuthenticationResponse("token", ImmutableMap.<String, URI> of("X-Storage-Url",
|
||||||
.create("http://fooman:8080/v1/token"))));
|
URI.create("http://fooman:8080/v1/token"))));
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testHandleHeadersCaseInsensitively() {
|
||||||
|
ParseAuthenticationResponseFromHeaders parser = i.getInstance(ParseAuthenticationResponseFromHeaders.class);
|
||||||
|
parser = parser.setHostToReplace("fooman");
|
||||||
|
|
||||||
|
HttpResponse response = HttpResponse.builder().statusCode(204).message("No Content")
|
||||||
|
.addHeader("x-auth-token", "token")
|
||||||
|
.addHeader("x-storage-token", "token")
|
||||||
|
.addHeader("x-storage-url", "http://127.0.0.1:8080/v1/token").build();
|
||||||
|
AuthenticationResponse md = parser.apply(response);
|
||||||
|
assertEquals(md, new AuthenticationResponse("token", ImmutableMap.<String, URI> of("x-storage-url",
|
||||||
|
URI.create("http://fooman:8080/v1/token"))));
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue