You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@jclouds.apache.org by na...@apache.org on 2018/01/11 15:41:16 UTC
[33/50] [abbrv] jclouds git commit: wip
wip
Project: http://git-wip-us.apache.org/repos/asf/jclouds/repo
Commit: http://git-wip-us.apache.org/repos/asf/jclouds/commit/9e2b3815
Tree: http://git-wip-us.apache.org/repos/asf/jclouds/tree/9e2b3815
Diff: http://git-wip-us.apache.org/repos/asf/jclouds/diff/9e2b3815
Branch: refs/heads/keystonev3
Commit: 9e2b3815b6ac05160a3e86436a918af627ceb148
Parents: 5234a44
Author: Andrea Turli <an...@gmail.com>
Authored: Tue Dec 12 09:39:20 2017 +0100
Committer: Ignasi Barrera <na...@apache.org>
Committed: Thu Jan 11 16:21:30 2018 +0100
----------------------------------------------------------------------
.../keystone/v3/KeystoneApiMetadata.java | 6 +-
.../keystone/v3/auth/V3AuthenticationApi.java | 4 +-
.../v3/config/KeystoneHttpApiModule.java | 49 ++
.../v3/config/KeystoneParserModule.java | 31 ++
.../keystone/v3/features/TokenApi.java | 10 +-
.../v3/internal/BaseV3KeystoneApiLiveTest.java | 39 ++
.../v3/internal/BaseV3KeystoneApiMockTest.java | 141 +++++
.../src/test/resources/logback-test.xml | 42 ++
.../src/test/resources/logback.xml | 64 ---
.../src/test/resources/v3/token.json | 510 +++++++++++++++++++
.../digitalocean2/src/test/resources/token.json | 0
11 files changed, 821 insertions(+), 75 deletions(-)
----------------------------------------------------------------------
http://git-wip-us.apache.org/repos/asf/jclouds/blob/9e2b3815/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/KeystoneApiMetadata.java
----------------------------------------------------------------------
diff --git a/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/KeystoneApiMetadata.java b/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/KeystoneApiMetadata.java
index d649563..52c400c 100644
--- a/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/KeystoneApiMetadata.java
+++ b/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/KeystoneApiMetadata.java
@@ -27,8 +27,8 @@ import org.jclouds.apis.ApiMetadata;
import org.jclouds.openstack.keystone.auth.config.AuthenticationModule;
import org.jclouds.openstack.keystone.catalog.config.KeystoneAdminURLModule;
import org.jclouds.openstack.keystone.catalog.config.ServiceCatalogModule;
-import org.jclouds.openstack.keystone.v2_0.config.KeystoneHttpApiModule;
-import org.jclouds.openstack.keystone.v2_0.config.KeystoneParserModule;
+import org.jclouds.openstack.keystone.v3.config.KeystoneHttpApiModule;
+import org.jclouds.openstack.keystone.v3.config.KeystoneParserModule;
import org.jclouds.openstack.v2_0.ServiceType;
import org.jclouds.rest.internal.BaseHttpApiMetadata;
@@ -59,7 +59,7 @@ public class KeystoneApiMetadata extends BaseHttpApiMetadata<KeystoneApi> {
Properties properties = BaseHttpApiMetadata.defaultProperties();
properties.setProperty(CREDENTIAL_TYPE, org.jclouds.openstack.keystone.auth.config.CredentialTypes.PASSWORD_CREDENTIALS);
properties.setProperty(SERVICE_TYPE, ServiceType.IDENTITY);
- properties.setProperty(KEYSTONE_VERSION, "2");
+ properties.setProperty(KEYSTONE_VERSION, "3");
return properties;
}
http://git-wip-us.apache.org/repos/asf/jclouds/blob/9e2b3815/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/auth/V3AuthenticationApi.java
----------------------------------------------------------------------
diff --git a/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/auth/V3AuthenticationApi.java b/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/auth/V3AuthenticationApi.java
index 0553c15..0d99b66 100644
--- a/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/auth/V3AuthenticationApi.java
+++ b/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/auth/V3AuthenticationApi.java
@@ -45,14 +45,14 @@ public interface V3AuthenticationApi extends AuthenticationApi, Closeable {
@Named("token:create")
@POST
- @ResponseParser(ParseTokenFromHttpResponse.class) //ParseToken.class)
+ @ResponseParser(ParseTokenFromHttpResponse.class)
@MapBinder(BindPasswordAuthToJsonPayload.class)
@Override
Token authenticatePassword(TenantAndCredentials<PasswordCredentials> credentials);
@Named("token:create")
@POST
- @ResponseParser(ParseTokenFromHttpResponse.class) //ParseToken.class)
+ @ResponseParser(ParseTokenFromHttpResponse.class)
@MapBinder(BindTokenAuthToJsonPayload.class)
@Override
Token authenticateToken(TenantAndCredentials<TokenCredentials> credentials);
http://git-wip-us.apache.org/repos/asf/jclouds/blob/9e2b3815/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/config/KeystoneHttpApiModule.java
----------------------------------------------------------------------
diff --git a/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/config/KeystoneHttpApiModule.java b/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/config/KeystoneHttpApiModule.java
new file mode 100644
index 0000000..6458726
--- /dev/null
+++ b/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/config/KeystoneHttpApiModule.java
@@ -0,0 +1,49 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF 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.openstack.keystone.v3.config;
+
+import java.net.URI;
+
+import org.jclouds.openstack.keystone.v2_0.config.NamespaceAliases;
+import org.jclouds.openstack.keystone.v3.KeystoneApi;
+import org.jclouds.rest.ConfiguresHttpApi;
+import org.jclouds.rest.config.HttpApiModule;
+
+import com.google.inject.Binder;
+import com.google.inject.multibindings.MapBinder;
+
+/**
+ * Configures the Keystone API.
+ */
+@ConfiguresHttpApi
+public class KeystoneHttpApiModule extends HttpApiModule<KeystoneApi> {
+
+ public KeystoneHttpApiModule() {
+ }
+
+ // Allow providers to cleanly contribute their own aliases
+ public static MapBinder<URI, URI> namespaceAliasBinder(Binder binder) {
+ return MapBinder.newMapBinder(binder, URI.class, URI.class, NamespaceAliases.class).permitDuplicates();
+ }
+
+ @Override
+ protected void configure() {
+ super.configure();
+ namespaceAliasBinder(binder());
+ }
+
+}
http://git-wip-us.apache.org/repos/asf/jclouds/blob/9e2b3815/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/config/KeystoneParserModule.java
----------------------------------------------------------------------
diff --git a/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/config/KeystoneParserModule.java b/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/config/KeystoneParserModule.java
new file mode 100644
index 0000000..f76e28b
--- /dev/null
+++ b/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/config/KeystoneParserModule.java
@@ -0,0 +1,31 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF 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.openstack.keystone.v3.config;
+
+import org.jclouds.json.config.GsonModule;
+import org.jclouds.json.config.GsonModule.DateAdapter;
+
+import com.google.inject.AbstractModule;
+
+public class KeystoneParserModule extends AbstractModule {
+
+ @Override
+ protected void configure() {
+ bind(DateAdapter.class).to(GsonModule.Iso8601DateAdapter.class);
+ }
+
+}
http://git-wip-us.apache.org/repos/asf/jclouds/blob/9e2b3815/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/features/TokenApi.java
----------------------------------------------------------------------
diff --git a/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/features/TokenApi.java b/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/features/TokenApi.java
index bba190a..75ade88 100644
--- a/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/features/TokenApi.java
+++ b/apis/openstack-keystone/src/main/java/org/jclouds/openstack/keystone/v3/features/TokenApi.java
@@ -20,11 +20,7 @@ import java.util.List;
import java.util.Set;
import javax.inject.Named;
-import javax.ws.rs.Consumes;
-import javax.ws.rs.GET;
-import javax.ws.rs.HEAD;
-import javax.ws.rs.Path;
-import javax.ws.rs.PathParam;
+import javax.ws.rs.*;
import javax.ws.rs.core.MediaType;
import org.jclouds.Fallbacks.EmptyListOnNotFoundOr404;
@@ -39,6 +35,7 @@ import org.jclouds.openstack.keystone.v3.domain.Region;
import org.jclouds.openstack.keystone.v3.domain.Token;
import org.jclouds.openstack.v2_0.services.Identity;
import org.jclouds.rest.annotations.Fallback;
+import org.jclouds.rest.annotations.Headers;
import org.jclouds.rest.annotations.RequestFilters;
import org.jclouds.rest.annotations.SelectJson;
@@ -58,9 +55,10 @@ public interface TokenApi {
@Named("token:get")
@GET
@SelectJson("token")
- @Path("/auth/tokens/{token}")
+ @Path("/auth/tokens")
@Fallback(NullOnNotFoundOr404.class)
@Nullable
+ @Headers( keys = "X-Subject-Token", values = "{token}")
Token get(@PathParam("token") String token);
/**
http://git-wip-us.apache.org/repos/asf/jclouds/blob/9e2b3815/apis/openstack-keystone/src/test/java/org/jclouds/openstack/keystone/v3/internal/BaseV3KeystoneApiLiveTest.java
----------------------------------------------------------------------
diff --git a/apis/openstack-keystone/src/test/java/org/jclouds/openstack/keystone/v3/internal/BaseV3KeystoneApiLiveTest.java b/apis/openstack-keystone/src/test/java/org/jclouds/openstack/keystone/v3/internal/BaseV3KeystoneApiLiveTest.java
new file mode 100644
index 0000000..acde256
--- /dev/null
+++ b/apis/openstack-keystone/src/test/java/org/jclouds/openstack/keystone/v3/internal/BaseV3KeystoneApiLiveTest.java
@@ -0,0 +1,39 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF 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.openstack.keystone.v3.internal;
+
+import java.util.Properties;
+
+import org.jclouds.apis.BaseApiLiveTest;
+import org.jclouds.openstack.keystone.config.KeystoneProperties;
+import org.jclouds.openstack.keystone.v3.KeystoneApi;
+
+public class BaseV3KeystoneApiLiveTest extends BaseApiLiveTest<KeystoneApi> {
+
+ public BaseV3KeystoneApiLiveTest() {
+ provider = "openstack-keystone-3";
+ }
+
+ @Override
+ protected Properties setupProperties() {
+ Properties props = super.setupProperties();
+ props.setProperty("jclouds.api-version", "v3");
+ setIfTestSystemPropertyPresent(props, KeystoneProperties.CREDENTIAL_TYPE);
+ return props;
+ }
+
+}
http://git-wip-us.apache.org/repos/asf/jclouds/blob/9e2b3815/apis/openstack-keystone/src/test/java/org/jclouds/openstack/keystone/v3/internal/BaseV3KeystoneApiMockTest.java
----------------------------------------------------------------------
diff --git a/apis/openstack-keystone/src/test/java/org/jclouds/openstack/keystone/v3/internal/BaseV3KeystoneApiMockTest.java b/apis/openstack-keystone/src/test/java/org/jclouds/openstack/keystone/v3/internal/BaseV3KeystoneApiMockTest.java
new file mode 100644
index 0000000..1d134e0
--- /dev/null
+++ b/apis/openstack-keystone/src/test/java/org/jclouds/openstack/keystone/v3/internal/BaseV3KeystoneApiMockTest.java
@@ -0,0 +1,141 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF 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.openstack.keystone.v3.internal;
+
+import static com.google.common.base.Preconditions.checkArgument;
+import static com.google.common.collect.Iterables.getOnlyElement;
+import static com.google.common.util.concurrent.MoreExecutors.newDirectExecutorService;
+import static org.testng.Assert.assertEquals;
+
+import java.io.IOException;
+import java.util.Map;
+import java.util.Properties;
+import java.util.Set;
+
+import org.jclouds.ContextBuilder;
+import org.jclouds.concurrent.config.ExecutorServiceModule;
+import org.jclouds.json.Json;
+import org.jclouds.openstack.keystone.v3.KeystoneApi;
+import org.jclouds.openstack.keystone.v3.KeystoneApiMetadata;
+import org.jclouds.rest.ApiContext;
+import org.testng.annotations.AfterMethod;
+import org.testng.annotations.BeforeMethod;
+
+import com.google.common.base.Charsets;
+import com.google.common.base.Throwables;
+import com.google.common.collect.ImmutableSet;
+import com.google.common.io.Resources;
+import com.google.common.reflect.TypeToken;
+import com.google.gson.JsonParser;
+import com.google.inject.Module;
+import com.squareup.okhttp.mockwebserver.MockResponse;
+import com.squareup.okhttp.mockwebserver.MockWebServer;
+import com.squareup.okhttp.mockwebserver.RecordedRequest;
+
+public class BaseV3KeystoneApiMockTest {
+
+ private static final String DEFAULT_ENDPOINT = new KeystoneApiMetadata().getDefaultEndpoint().orNull();
+
+ private final Set<Module> modules = ImmutableSet.<Module> of(new ExecutorServiceModule(newDirectExecutorService()));
+
+ protected MockWebServer server;
+ protected KeystoneApi api;
+ private Json json;
+
+ // So that we can ignore formatting.
+ private final JsonParser parser = new JsonParser();
+
+ @BeforeMethod
+ public void start() throws IOException {
+ server = new MockWebServer();
+ server.play();
+ ApiContext<KeystoneApi> ctx = ContextBuilder.newBuilder("openstack-keystone-3")
+ .credentials("identity", "credential")
+ .endpoint(url(""))
+ .modules(modules)
+ .overrides(overrides())
+ .build();
+ json = ctx.utils().injector().getInstance(Json.class);
+ api = ctx.getApi();
+ }
+
+ @AfterMethod(alwaysRun = true)
+ public void stop() throws IOException {
+ server.shutdown();
+ api.close();
+ }
+
+ protected Properties overrides() {
+ return new Properties();
+ }
+
+ protected String url(String path) {
+ return server.getUrl(path).toString();
+ }
+
+ protected MockResponse jsonResponse(String resource) {
+ return new MockResponse().addHeader("Content-Type", "application/json").setBody(stringFromResource(resource));
+ }
+
+ protected MockResponse response404() {
+ return new MockResponse().setStatus("HTTP/1.1 404 Not Found");
+ }
+
+ protected MockResponse response204() {
+ return new MockResponse().setStatus("HTTP/1.1 204 No Content");
+ }
+
+ protected String stringFromResource(String resourceName) {
+ try {
+ return Resources.toString(getClass().getResource(resourceName), Charsets.UTF_8)
+ .replace(DEFAULT_ENDPOINT, url(""));
+ } catch (IOException e) {
+ throw Throwables.propagate(e);
+ }
+ }
+
+ protected <T> T onlyObjectFromResource(String resourceName, TypeToken<Map<String, T>> type) {
+ // Assume JSON objects passed here will be in the form: { "entity": { ... } }
+ String text = stringFromResource(resourceName);
+ Map<String, T> object = json.fromJson(text, type.getType());
+ checkArgument(!object.isEmpty(), "The given json does not contain any object: %s", text);
+ checkArgument(object.keySet().size() == 1, "The given json does not contain more than one object: %s", text);
+ return object.get(getOnlyElement(object.keySet()));
+ }
+
+ protected <T> T objectFromResource(String resourceName, Class<T> type) {
+ String text = stringFromResource(resourceName);
+ return json.fromJson(text, type);
+ }
+
+ protected RecordedRequest assertSent(MockWebServer server, String method, String path) throws InterruptedException {
+ RecordedRequest request = server.takeRequest();
+ assertEquals(request.getMethod(), method);
+ assertEquals(request.getPath(), path);
+ assertEquals(request.getHeader("Accept"), "application/json");
+ assertEquals(request.getHeader("Authorization"), "X-Token " + "token");
+ return request;
+ }
+
+ protected RecordedRequest assertSent(MockWebServer server, String method, String path, String json)
+ throws InterruptedException {
+ RecordedRequest request = assertSent(server, method, path);
+ assertEquals(request.getHeader("Content-Type"), "application/json");
+ assertEquals(parser.parse(new String(request.getBody(), Charsets.UTF_8)), parser.parse(json));
+ return request;
+ }
+}
http://git-wip-us.apache.org/repos/asf/jclouds/blob/9e2b3815/apis/openstack-keystone/src/test/resources/logback-test.xml
----------------------------------------------------------------------
diff --git a/apis/openstack-keystone/src/test/resources/logback-test.xml b/apis/openstack-keystone/src/test/resources/logback-test.xml
new file mode 100644
index 0000000..4cac342
--- /dev/null
+++ b/apis/openstack-keystone/src/test/resources/logback-test.xml
@@ -0,0 +1,42 @@
+<?xml version="1.0"?>
+<configuration scan="false">
+ <appender name="FILE" class="ch.qos.logback.core.FileAppender">
+ <file>target/test-data/jclouds.log</file>
+ <encoder>
+ <Pattern>%d %-5p [%c] [%thread] %m%n</Pattern>
+ </encoder>
+ </appender>
+ <appender name="WIREFILE" class="ch.qos.logback.core.FileAppender">
+ <file>target/test-data/jclouds-wire.log</file>
+ <encoder>
+ <Pattern>%d %-5p [%c] [%thread] %m%n</Pattern>
+ </encoder>
+ </appender>
+ <appender name="COMPUTEFILE" class="ch.qos.logback.core.FileAppender">
+ <file>target/jclouds-compute.log</file>
+ <encoder>
+ <Pattern>%d %-5p [%c] [%thread] %m%n</Pattern>
+ </encoder>
+ </appender>
+
+ <logger name="org.jclouds">
+ <level value="DEBUG" />
+ <appender-ref ref="FILE" />
+ </logger>
+ <logger name="jclouds.compute">
+ <level value="DEBUG" />
+ <appender-ref ref="COMPUTEFILE" />
+ </logger>
+ <logger name="jclouds.wire">
+ <level value="DEBUG" />
+ <appender-ref ref="WIREFILE" />
+ </logger>
+ <logger name="jclouds.headers">
+ <level value="DEBUG" />
+ <appender-ref ref="WIREFILE" />
+ </logger>
+
+ <root>
+ <level value="INFO" />
+ </root>
+</configuration>
\ No newline at end of file
http://git-wip-us.apache.org/repos/asf/jclouds/blob/9e2b3815/apis/openstack-keystone/src/test/resources/logback.xml
----------------------------------------------------------------------
diff --git a/apis/openstack-keystone/src/test/resources/logback.xml b/apis/openstack-keystone/src/test/resources/logback.xml
deleted file mode 100644
index 98b1ea9..0000000
--- a/apis/openstack-keystone/src/test/resources/logback.xml
+++ /dev/null
@@ -1,64 +0,0 @@
-<?xml version="1.0"?>
-<configuration scan="false">
- <appender name="FILE" class="ch.qos.logback.core.FileAppender">
- <file>target/test-data/jclouds.log</file>
-
- <encoder>
- <Pattern>%d %-5p [%c] [%thread] %m%n</Pattern>
- </encoder>
- </appender>
-
- <appender name="WIREFILE" class="ch.qos.logback.core.FileAppender">
- <file>target/test-data/jclouds-wire.log</file>
-
- <encoder>
- <Pattern>%d %-5p [%c] [%thread] %m%n</Pattern>
- </encoder>
- </appender>
-
- <appender name="COMPUTEFILE" class="ch.qos.logback.core.FileAppender">
- <file>target/test-data/jclouds-compute.log</file>
-
- <encoder>
- <Pattern>%d %-5p [%c] [%thread] %m%n</Pattern>
- </encoder>
- </appender>
-
- <appender name="SSHFILE" class="ch.qos.logback.core.FileAppender">
- <file>target/test-data/jclouds-ssh.log</file>
-
- <encoder>
- <Pattern>%d %-5p [%c] [%thread] %m%n</Pattern>
- </encoder>
- </appender>
-
- <root>
- <level value="warn" />
- </root>
-
- <logger name="org.jclouds">
- <level value="DEBUG" />
- <appender-ref ref="FILE" />
- </logger>
-
- <logger name="jclouds.wire">
- <level value="DEBUG" />
- <appender-ref ref="WIREFILE" />
- </logger>
-
- <logger name="jclouds.headers">
- <level value="DEBUG" />
- <appender-ref ref="WIREFILE" />
- </logger>
-
- <logger name="jclouds.compute">
- <level value="DEBUG" />
- <appender-ref ref="COMPUTEFILE" />
- </logger>
-
- <logger name="jclouds.ssh">
- <level value="DEBUG" />
- <appender-ref ref="SSHFILE" />
- </logger>
-
-</configuration>
http://git-wip-us.apache.org/repos/asf/jclouds/blob/9e2b3815/apis/openstack-keystone/src/test/resources/v3/token.json
----------------------------------------------------------------------
diff --git a/apis/openstack-keystone/src/test/resources/v3/token.json b/apis/openstack-keystone/src/test/resources/v3/token.json
new file mode 100644
index 0000000..1e8906d
--- /dev/null
+++ b/apis/openstack-keystone/src/test/resources/v3/token.json
@@ -0,0 +1,510 @@
+{
+ "token": {
+ "methods": [
+ "password"
+ ],
+ "roles": [
+ {
+ "id": "9fe2ff9ee4384b1894a90878d3e92bab",
+ "name": "_member_"
+ },
+ {
+ "id": "df7d043a09d34a7c9e2bad15926ee097",
+ "name": "cpf_org_manager"
+ },
+ {
+ "id": "3af119c426a742999e7890f6d1f70b36",
+ "name": "cpf_admin"
+ }
+ ],
+ "expires_at": "2017-12-10T11:48:46.546830Z",
+ "project": {
+ "domain": {
+ "id": "2347b158dcaf488496b44cc4edfd2bd8",
+ "name": "0kjFQF29"
+ },
+ "id": "2233c4d7d5c044b1b48e1bef25c1f305",
+ "name": "0kjFQF29-prj"
+ },
+ "catalog": [
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://objectstorage.uk-1.cloud.global.fujitsu.com/v1/AUTH_2233c4d7d5c044b1b48e1bef25c1f305",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "b506af0e016a4b5fb592f196da569a41",
+ "name": "objectstorage"
+ }
+ ],
+ "type": "object-store",
+ "id": "024329e4fde148e58ecd90b7d9872438",
+ "name": "objectstorage"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://keymanagement.uk-1.cloud.global.fujitsu.com/v1",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "0419c448001845af8f6828cf49745e72",
+ "name": "keymanagement"
+ }
+ ],
+ "type": "keystore",
+ "id": "07f309b0ef9d42758ea4de47bdca9c32",
+ "name": "keymanagement"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://certificate.uk-1.cloud.global.fujitsu.com/v1",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "e1cc93936fb94cdbadc20f17c4ad3140",
+ "name": "certificate"
+ }
+ ],
+ "type": "certificate",
+ "id": "0bd9a971e97d4c15af6b94311e4e9c15",
+ "name": "certificate"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://orchestration.uk-1.cloud.global.fujitsu.com/v1/2233c4d7d5c044b1b48e1bef25c1f305",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "c3ee708a6ae24ddf92c078526c36a446",
+ "name": "orchestration"
+ }
+ ],
+ "type": "orchestration",
+ "id": "0dafa2a9240c41268c37818979769c88",
+ "name": "orchestration"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://blockstorage.uk-1.cloud.global.fujitsu.com/v1/2233c4d7d5c044b1b48e1bef25c1f305",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "ba9061d324954b1a9f6b1c1f5d4a5c5e",
+ "name": "blockstorage"
+ }
+ ],
+ "type": "volume",
+ "id": "0ec640e57e4d4374841d2ab7b292f2c2",
+ "name": "blockstorage"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://loadbalancing.uk-1.cloud.global.fujitsu.com",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "169bcb3f92384f709232864f4d5304eb",
+ "name": "loadbalancing"
+ }
+ ],
+ "type": "loadbalancing",
+ "id": "15ef761fa00a438985213aec7b6fb18a",
+ "name": "loadbalancing"
+ },
+ {
+ "endpoints": [],
+ "type": "dwh",
+ "id": "1a53a2e82370422d90174c4acf585ea9",
+ "name": "dwh"
+ },
+ {
+ "endpoints": [],
+ "type": "contract",
+ "id": "1b35fa74ae0e46ebbc2014f976fec0e1",
+ "name": "contract"
+ },
+ {
+ "endpoints": [],
+ "type": "appplatform",
+ "id": "253096ed430c49c48c9f3549e867b538",
+ "name": "appplatform"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://compute-w.uk-1.cloud.global.fujitsu.com",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "e26ad89a682d4c8f8a71c9e76cd785b4",
+ "name": "compute-w"
+ }
+ ],
+ "type": "compute-w",
+ "id": "327c11710f184555b43bc6fdfc47626b",
+ "name": "compute-w"
+ },
+ {
+ "endpoints": [],
+ "type": "notification",
+ "id": "3435ad7a1da04b1cb2e249665529eb51",
+ "name": "notification"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://compute.uk-1.cloud.global.fujitsu.com/v2/2233c4d7d5c044b1b48e1bef25c1f305",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "f70e51b9a6a74a87a4c7055b8df8bedf",
+ "name": "compute"
+ }
+ ],
+ "type": "compute",
+ "id": "3e19093f50cc4590973c8953e2c327f9",
+ "name": "compute"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://queue.uk-1.cloud.global.fujitsu.com",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "c46b5ec51ab04402a9ffd8177743ba6f",
+ "name": "queue"
+ }
+ ],
+ "type": "queue",
+ "id": "4a9ab69b74ec4948a0a6958177d30387",
+ "name": "queue"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://autoscale.uk-1.cloud.global.fujitsu.com/autoscale_schedulers",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "071ee50be4b341558e37f84abac47d02",
+ "name": "autoscale"
+ }
+ ],
+ "type": "autoscale",
+ "id": "4f158b2836434c7ca6ee47e40a3ee56c",
+ "name": "autoscale"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://telemetry.uk-1.cloud.global.fujitsu.com",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "6ac15657fbc548d7ab2ed986b8d94192",
+ "name": "telemetry"
+ }
+ ],
+ "type": "metering",
+ "id": "54ee7596f0e1433cb8db6201be2cf772",
+ "name": "telemetry"
+ },
+ {
+ "endpoints": [],
+ "type": "cdn",
+ "id": "5954129d136e4a76b7cd6f3d1f3808b5",
+ "name": "cdn"
+ },
+ {
+ "endpoints": [],
+ "type": "oss",
+ "id": "5a252878ffd7402498b6b74b575a899a",
+ "name": "oss"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://rolemanagement.uk-1.cloud.global.fujitsu.com/v1",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "2d600a5de6ec42c6a5eab7b519832d87",
+ "name": "rolemanagement"
+ }
+ ],
+ "type": "rolemanagement",
+ "id": "5bc90099f0ad490c811239a6a3a8f853",
+ "name": "rolemanagement"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://compute-b.uk-1.cloud.global.fujitsu.com",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "768450282d5546409395d2cb35502dad",
+ "name": "compute-b"
+ }
+ ],
+ "type": "compute-b",
+ "id": "65f754202b6049578e9a292a801e28f7",
+ "name": "compute-b"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://networking.uk-1.cloud.global.fujitsu.com",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "675910513a7e466c84c39c5ca9445b81",
+ "name": "networking"
+ }
+ ],
+ "type": "network",
+ "id": "6cf37e33dc7140b9b032faabfa53a53e",
+ "name": "networking"
+ },
+ {
+ "endpoints": [],
+ "type": "dns",
+ "id": "7426c97af5174c1abdb8b84ba02227ce",
+ "name": "dns"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://database.uk-1.cloud.global.fujitsu.com/v1.0/2233c4d7d5c044b1b48e1bef25c1f305",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "6976cbeed14c464da15c13e949b41607",
+ "name": "database"
+ }
+ ],
+ "type": "database",
+ "id": "75c0280f15844d7a9eb22b1ad5a978e8",
+ "name": "database"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://identity.uk-1.cloud.global.fujitsu.com/v2.0",
+ "region": "uk-1",
+ "interface": "admin",
+ "id": "db15a7126d4a4f1f81903bb4d56be32b",
+ "name": "identity"
+ }
+ ],
+ "type": "identity",
+ "id": "79066fe949064550930a61b33a49eb53",
+ "name": "identity"
+ },
+ {
+ "endpoints": [],
+ "type": "intdns",
+ "id": "804190a423804019aab8fd934db0086e",
+ "name": "intdns"
+ },
+ {
+ "endpoints": [],
+ "type": "invoicing",
+ "id": "8d364df08cbc4d7188f0cf83744b0336",
+ "name": "invoicing"
+ },
+ {
+ "endpoints": [],
+ "type": "catalog",
+ "id": "9674ae5917af401397071c028ff33b68",
+ "name": "catalog"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://software.uk-1.cloud.global.fujitsu.com/v1.0",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "fd6g35fgknrzumut7bx6p6bwzehkfhrz",
+ "name": "software"
+ }
+ ],
+ "type": "software",
+ "id": "9760973e49b04b00b41e60c180a80562",
+ "name": "software"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://blockstorage.uk-1.cloud.global.fujitsu.com/v2/2233c4d7d5c044b1b48e1bef25c1f305",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "8c4ace3bbbd44883b5762a9ad8432a46",
+ "name": "blockstoragev2"
+ }
+ ],
+ "type": "volumev2",
+ "id": "9bf82d0466714eee86e304ab3301aec9",
+ "name": "blockstorage"
+ },
+ {
+ "endpoints": [],
+ "type": "dnsadmin",
+ "id": "a2b90094346c48deabb9ca645bacf588",
+ "name": "dnsadmin"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://vmimport.uk-1.cloud.global.fujitsu.com",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "225257ec50ef47668185587cc6edb95d",
+ "name": "vmimport"
+ }
+ ],
+ "type": "vmimport",
+ "id": "c73fa07c3b604b4f89d5a2b9c4621cf2",
+ "name": "vmimport"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://identity.uk-1.cloud.global.fujitsu.com/v3",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "27dc2bba1c5d4a14b68657fc8fdd4e3e",
+ "name": "identityv3"
+ }
+ ],
+ "type": "identityv3",
+ "id": "cc6f50d496884ef0a751acb2e1eceedd",
+ "name": "identityv3"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://applicationmanagement.uk-1.cloud.global.fujitsu.com",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "06fbcf8235434f23a08faed03b4af9ac",
+ "name": "appmanagement"
+ }
+ ],
+ "type": "appmanagement",
+ "id": "ce2f6bbe7a9f446b82d63725bd7bb484",
+ "name": "appmanagement"
+ },
+ {
+ "endpoints": [],
+ "type": "nosql",
+ "id": "d07aa581c0734b6bb85cd496115b5110",
+ "name": "nosql"
+ },
+ {
+ "endpoints": [],
+ "type": "baremetal",
+ "id": "d2f57dcae4c84466ac357220ff3d8900",
+ "name": "baremetal"
+ },
+ {
+ "endpoints": [],
+ "type": "mail",
+ "id": "d4601f51af8f43f3b0e3409e4cbac690",
+ "name": "mail"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://networking-ex.uk-1.cloud.global.fujitsu.com",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "bf356065e45349a5bde5e043c95a1923",
+ "name": "networking-ex"
+ }
+ ],
+ "type": "networking-ex",
+ "id": "d4937aa1275c41378bf2ae1dbe829c68",
+ "name": "networking-ex"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "jp-east-1",
+ "url": "https://identity.gls.cloud.global.fujitsu.com/v3",
+ "region": "jp-east-1",
+ "interface": "public",
+ "id": "dc2ebf9d6fc04f1facc263a733cf754d",
+ "name": "global-identity"
+ }
+ ],
+ "type": "global-identity",
+ "id": "e74b9c29d6504f10a8fb8e1495f3f5c6",
+ "name": "global-identity"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://image.uk-1.cloud.global.fujitsu.com",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "a832d640886b4ef89027339a2edf8fcd",
+ "name": "image"
+ }
+ ],
+ "type": "image",
+ "id": "ea850dab0e964e12a9f66787ee8623ae",
+ "name": "image"
+ },
+ {
+ "endpoints": [],
+ "type": "billing",
+ "id": "f1302a2477bf492bb3e867952175974a",
+ "name": "billing"
+ },
+ {
+ "endpoints": [
+ {
+ "region_id": "uk-1",
+ "url": "https://import-export.uk-1.cloud.global.fujitsu.com",
+ "region": "uk-1",
+ "interface": "public",
+ "id": "e8bde8fe61a14a88b414e5568fc17201",
+ "name": "import-export"
+ }
+ ],
+ "type": "import-export",
+ "id": "fc302725919645199373077fa299fc6e",
+ "name": "import-export"
+ }
+ ],
+ "extras": {},
+ "user": {
+ "domain": {
+ "id": "2347b158dcaf488496b44cc4edfd2bd8",
+ "name": "0kjFQF29"
+ },
+ "id": "f1f24aea666542eeb58dc129c29734f0",
+ "name": "cloudsoft"
+ },
+ "audit_ids": [
+ "kr9Qqe-1QFOOlrt2XP6AqA"
+ ],
+ "issued_at": "2017-12-10T08:48:46.546877Z"
+ }
+}
\ No newline at end of file
http://git-wip-us.apache.org/repos/asf/jclouds/blob/9e2b3815/providers/digitalocean2/src/test/resources/token.json
----------------------------------------------------------------------
diff --git a/providers/digitalocean2/src/test/resources/token.json b/providers/digitalocean2/src/test/resources/token.json
new file mode 100644
index 0000000..e69de29