mirror of https://github.com/apache/jclouds.git
added datacenter awareness to joyent-sdc
This commit is contained in:
parent
ff2c2fb3e3
commit
0ec72c4476
|
@ -22,6 +22,7 @@ import java.net.URI;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.jclouds.apis.ApiMetadata;
|
import org.jclouds.apis.ApiMetadata;
|
||||||
|
import org.jclouds.joyent.sdc.v6_5.config.DatacentersAreZonesModule;
|
||||||
import org.jclouds.joyent.sdc.v6_5.config.SDCRestClientModule;
|
import org.jclouds.joyent.sdc.v6_5.config.SDCRestClientModule;
|
||||||
import org.jclouds.rest.RestContext;
|
import org.jclouds.rest.RestContext;
|
||||||
import org.jclouds.rest.internal.BaseRestApiMetadata;
|
import org.jclouds.rest.internal.BaseRestApiMetadata;
|
||||||
|
@ -66,10 +67,15 @@ public class SDCApiMetadata extends BaseRestApiMetadata {
|
||||||
|
|
||||||
protected Builder() {
|
protected Builder() {
|
||||||
super(SDCClient.class, SDCAsyncClient.class);
|
super(SDCClient.class, SDCAsyncClient.class);
|
||||||
id("joyent-sdc").name("Joyent SDC API").identityName("username").credentialName("password")
|
id("joyent-sdc")
|
||||||
.documentation(URI.create("http://sdc.joyent.org/sdcapi.html")).version("~6.5")
|
.name("Joyent SDC API")
|
||||||
.defaultEndpoint("https://api.joyentcloud.com").defaultProperties(SDCApiMetadata.defaultProperties())
|
.identityName("username")
|
||||||
.defaultModules(ImmutableSet.<Class<? extends Module>> of(SDCRestClientModule.class));
|
.credentialName("password")
|
||||||
|
.documentation(URI.create("http://sdc.joyent.org/sdcapi.html"))
|
||||||
|
.version("~6.5")
|
||||||
|
.defaultEndpoint("https://api.joyentcloud.com")
|
||||||
|
.defaultProperties(SDCApiMetadata.defaultProperties())
|
||||||
|
.defaultModules(ImmutableSet.<Class<? extends Module>> of(DatacentersAreZonesModule.class, SDCRestClientModule.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -18,11 +18,19 @@
|
||||||
*/
|
*/
|
||||||
package org.jclouds.joyent.sdc.v6_5;
|
package org.jclouds.joyent.sdc.v6_5;
|
||||||
|
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import org.jclouds.javax.annotation.Nullable;
|
||||||
import org.jclouds.joyent.sdc.v6_5.features.DatacenterAsyncClient;
|
import org.jclouds.joyent.sdc.v6_5.features.DatacenterAsyncClient;
|
||||||
import org.jclouds.joyent.sdc.v6_5.features.DatasetAsyncClient;
|
import org.jclouds.joyent.sdc.v6_5.features.DatasetAsyncClient;
|
||||||
import org.jclouds.joyent.sdc.v6_5.features.MachineAsyncClient;
|
import org.jclouds.joyent.sdc.v6_5.features.MachineAsyncClient;
|
||||||
import org.jclouds.joyent.sdc.v6_5.features.PackageAsyncClient;
|
import org.jclouds.joyent.sdc.v6_5.features.PackageAsyncClient;
|
||||||
|
import org.jclouds.location.Zone;
|
||||||
|
import org.jclouds.location.functions.ZoneToEndpoint;
|
||||||
import org.jclouds.rest.annotations.Delegate;
|
import org.jclouds.rest.annotations.Delegate;
|
||||||
|
import org.jclouds.rest.annotations.EndpointParam;
|
||||||
|
|
||||||
|
import com.google.inject.Provides;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Provides asynchronous access to SDC via their REST API.
|
* Provides asynchronous access to SDC via their REST API.
|
||||||
|
@ -34,6 +42,14 @@ import org.jclouds.rest.annotations.Delegate;
|
||||||
*/
|
*/
|
||||||
public interface SDCAsyncClient {
|
public interface SDCAsyncClient {
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @return the datacenter codes configured
|
||||||
|
*/
|
||||||
|
@Provides
|
||||||
|
@Zone
|
||||||
|
Set<String> getConfiguredDatacenters();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Provides asynchronous access to Datacenter features.
|
* Provides asynchronous access to Datacenter features.
|
||||||
*/
|
*/
|
||||||
|
@ -44,17 +60,20 @@ public interface SDCAsyncClient {
|
||||||
* Provides asynchronous access to Machine features.
|
* Provides asynchronous access to Machine features.
|
||||||
*/
|
*/
|
||||||
@Delegate
|
@Delegate
|
||||||
MachineAsyncClient getMachineClient();
|
MachineAsyncClient getMachineClientForDatacenter(
|
||||||
|
@EndpointParam(parser = ZoneToEndpoint.class) @Nullable String datacenter);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Provides asynchronous access to Dataset features.
|
* Provides asynchronous access to Dataset features.
|
||||||
*/
|
*/
|
||||||
@Delegate
|
@Delegate
|
||||||
DatasetAsyncClient getDatasetClient();
|
DatasetAsyncClient getDatasetClientForDatacenter(
|
||||||
|
@EndpointParam(parser = ZoneToEndpoint.class) @Nullable String datacenter);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Provides asynchronous access to Package features.
|
* Provides asynchronous access to Package features.
|
||||||
*/
|
*/
|
||||||
@Delegate
|
@Delegate
|
||||||
PackageAsyncClient getPackageClient();
|
PackageAsyncClient getPackageClientForDatacenter(
|
||||||
|
@EndpointParam(parser = ZoneToEndpoint.class) @Nullable String datacenter);
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,14 +18,21 @@
|
||||||
*/
|
*/
|
||||||
package org.jclouds.joyent.sdc.v6_5;
|
package org.jclouds.joyent.sdc.v6_5;
|
||||||
|
|
||||||
|
import java.util.Set;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
import org.jclouds.concurrent.Timeout;
|
import org.jclouds.concurrent.Timeout;
|
||||||
|
import org.jclouds.javax.annotation.Nullable;
|
||||||
import org.jclouds.joyent.sdc.v6_5.features.DatacenterClient;
|
import org.jclouds.joyent.sdc.v6_5.features.DatacenterClient;
|
||||||
import org.jclouds.joyent.sdc.v6_5.features.DatasetClient;
|
import org.jclouds.joyent.sdc.v6_5.features.DatasetClient;
|
||||||
import org.jclouds.joyent.sdc.v6_5.features.MachineClient;
|
import org.jclouds.joyent.sdc.v6_5.features.MachineClient;
|
||||||
import org.jclouds.joyent.sdc.v6_5.features.PackageClient;
|
import org.jclouds.joyent.sdc.v6_5.features.PackageClient;
|
||||||
|
import org.jclouds.location.Zone;
|
||||||
|
import org.jclouds.location.functions.ZoneToEndpoint;
|
||||||
import org.jclouds.rest.annotations.Delegate;
|
import org.jclouds.rest.annotations.Delegate;
|
||||||
|
import org.jclouds.rest.annotations.EndpointParam;
|
||||||
|
|
||||||
|
import com.google.inject.Provides;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Provides synchronous access to SDC.
|
* Provides synchronous access to SDC.
|
||||||
|
@ -38,6 +45,14 @@ import org.jclouds.rest.annotations.Delegate;
|
||||||
@Timeout(duration = 60, timeUnit = TimeUnit.SECONDS)
|
@Timeout(duration = 60, timeUnit = TimeUnit.SECONDS)
|
||||||
public interface SDCClient {
|
public interface SDCClient {
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @return the datacenter codes configured
|
||||||
|
*/
|
||||||
|
@Provides
|
||||||
|
@Zone
|
||||||
|
Set<String> getConfiguredDatacenters();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Provides synchronous access to Datacenter features.
|
* Provides synchronous access to Datacenter features.
|
||||||
*/
|
*/
|
||||||
|
@ -48,17 +63,20 @@ public interface SDCClient {
|
||||||
* Provides synchronous access to Machine features.
|
* Provides synchronous access to Machine features.
|
||||||
*/
|
*/
|
||||||
@Delegate
|
@Delegate
|
||||||
MachineClient getMachineClient();
|
MachineClient getMachineClientForDatacenter(
|
||||||
|
@EndpointParam(parser = ZoneToEndpoint.class) @Nullable String datacenter);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Provides synchronous access to Dataset features.
|
* Provides synchronous access to Dataset features.
|
||||||
*/
|
*/
|
||||||
@Delegate
|
@Delegate
|
||||||
DatasetClient getDatasetClient();
|
DatasetClient getDatasetClientForDatacenter(
|
||||||
|
@EndpointParam(parser = ZoneToEndpoint.class) @Nullable String datacenter);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Provides synchronous access to Package features.
|
* Provides synchronous access to Package features.
|
||||||
*/
|
*/
|
||||||
@Delegate
|
@Delegate
|
||||||
PackageClient getPackageClient();
|
PackageClient getPackageClientForDatacenter(
|
||||||
|
@EndpointParam(parser = ZoneToEndpoint.class) @Nullable String datacenter);
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,49 @@
|
||||||
|
/**
|
||||||
|
* 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.joyent.sdc.v6_5.config;
|
||||||
|
|
||||||
|
import static org.jclouds.rest.config.BinderUtils.bindClientAndAsyncClient;
|
||||||
|
|
||||||
|
import org.jclouds.joyent.sdc.v6_5.features.DatacenterAsyncClient;
|
||||||
|
import org.jclouds.joyent.sdc.v6_5.features.DatacenterClient;
|
||||||
|
import org.jclouds.joyent.sdc.v6_5.suppliers.ZoneIdToURIFromDatacentersClient;
|
||||||
|
import org.jclouds.location.suppliers.ImplicitLocationSupplier;
|
||||||
|
import org.jclouds.location.suppliers.ZoneIdToURISupplier;
|
||||||
|
import org.jclouds.location.suppliers.ZoneIdsSupplier;
|
||||||
|
import org.jclouds.location.suppliers.derived.ZoneIdsFromZoneIdToURIKeySet;
|
||||||
|
import org.jclouds.location.suppliers.implicit.OnlyLocationOrFirstZone;
|
||||||
|
|
||||||
|
import com.google.inject.AbstractModule;
|
||||||
|
import com.google.inject.Scopes;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author Adrian Cole
|
||||||
|
*/
|
||||||
|
public class DatacentersAreZonesModule extends AbstractModule {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void configure() {
|
||||||
|
// datacenter client is needed for obtaining zone ids
|
||||||
|
bindClientAndAsyncClient(binder(), DatacenterClient.class, DatacenterAsyncClient.class);
|
||||||
|
bind(ImplicitLocationSupplier.class).to(OnlyLocationOrFirstZone.class).in(Scopes.SINGLETON);
|
||||||
|
bind(ZoneIdToURISupplier.class).to(ZoneIdToURIFromDatacentersClient.class).in(Scopes.SINGLETON);
|
||||||
|
bind(ZoneIdsSupplier.class).to(ZoneIdsFromZoneIdToURIKeySet.class).in(Scopes.SINGLETON);
|
||||||
|
}
|
||||||
|
}
|
|
@ -50,8 +50,10 @@ import com.google.common.collect.ImmutableMap;
|
||||||
@ConfiguresRestClient
|
@ConfiguresRestClient
|
||||||
public class SDCRestClientModule extends RestClientModule<SDCClient, SDCAsyncClient> {
|
public class SDCRestClientModule extends RestClientModule<SDCClient, SDCAsyncClient> {
|
||||||
public static final Map<Class<?>, Class<?>> DELEGATE_MAP = ImmutableMap.<Class<?>, Class<?>> builder()
|
public static final Map<Class<?>, Class<?>> DELEGATE_MAP = ImmutableMap.<Class<?>, Class<?>> builder()
|
||||||
.put(DatacenterClient.class, DatacenterAsyncClient.class).put(MachineClient.class, MachineAsyncClient.class)
|
.put(DatacenterClient.class, DatacenterAsyncClient.class)
|
||||||
.put(DatasetClient.class, DatasetAsyncClient.class).put(PackageClient.class, PackageAsyncClient.class).build();
|
.put(MachineClient.class, MachineAsyncClient.class)
|
||||||
|
.put(DatasetClient.class, DatasetAsyncClient.class)
|
||||||
|
.put(PackageClient.class, PackageAsyncClient.class).build();
|
||||||
|
|
||||||
public SDCRestClientModule() {
|
public SDCRestClientModule() {
|
||||||
super(DELEGATE_MAP);
|
super(DELEGATE_MAP);
|
||||||
|
@ -70,4 +72,5 @@ public class SDCRestClientModule extends RestClientModule<SDCClient, SDCAsyncCli
|
||||||
bind(HttpErrorHandler.class).annotatedWith(ClientError.class).to(SDCErrorHandler.class);
|
bind(HttpErrorHandler.class).annotatedWith(ClientError.class).to(SDCErrorHandler.class);
|
||||||
bind(HttpErrorHandler.class).annotatedWith(ServerError.class).to(SDCErrorHandler.class);
|
bind(HttpErrorHandler.class).annotatedWith(ServerError.class).to(SDCErrorHandler.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,35 @@
|
||||||
|
package org.jclouds.joyent.sdc.v6_5.suppliers;
|
||||||
|
|
||||||
|
import java.net.URI;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import javax.inject.Inject;
|
||||||
|
import javax.inject.Singleton;
|
||||||
|
|
||||||
|
import org.jclouds.joyent.sdc.v6_5.features.DatacenterClient;
|
||||||
|
import org.jclouds.location.suppliers.ZoneIdToURISupplier;
|
||||||
|
import org.jclouds.util.Suppliers2;
|
||||||
|
|
||||||
|
import com.google.common.base.Supplier;
|
||||||
|
import com.google.common.collect.Maps;
|
||||||
|
|
||||||
|
@Singleton
|
||||||
|
public class ZoneIdToURIFromDatacentersClient implements ZoneIdToURISupplier {
|
||||||
|
|
||||||
|
private final DatacenterClient client;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
public ZoneIdToURIFromDatacentersClient(DatacenterClient client) {
|
||||||
|
this.client = client;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Map<String, Supplier<URI>> get() {
|
||||||
|
return Maps.transformValues(client.getDatacenters(), Suppliers2.<URI> ofInstanceFunction());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "getDatacenters()";
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,47 @@
|
||||||
|
/**
|
||||||
|
* 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
|
||||||
|
*
|
||||||
|
* Unles 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 expres or implied. See the License for the
|
||||||
|
* specific language governing permisions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
package org.jclouds.joyent.sdc.v6_5;
|
||||||
|
|
||||||
|
import static org.testng.Assert.assertEquals;
|
||||||
|
|
||||||
|
import org.jclouds.joyent.sdc.v6_5.internal.BaseSDCClientExpectTest;
|
||||||
|
import org.testng.annotations.Test;
|
||||||
|
|
||||||
|
import com.google.common.collect.ImmutableSet;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Adrian Cole
|
||||||
|
*/
|
||||||
|
@Test(groups = "unit", testName = "SDCClientExpectTest")
|
||||||
|
public class SDCClientExpectTest extends BaseSDCClientExpectTest {
|
||||||
|
|
||||||
|
public void testGetConfiguredDatacenters() {
|
||||||
|
|
||||||
|
SDCClient clientWhenDatacentersExists = requestSendsResponse(getDatacenters, getDatacentersResponse);
|
||||||
|
|
||||||
|
assertEquals(
|
||||||
|
clientWhenDatacentersExists.getConfiguredDatacenters(),
|
||||||
|
ImmutableSet.<String> builder()
|
||||||
|
.add("us-east-1")
|
||||||
|
.add("us-west-1")
|
||||||
|
.add("us-sw-1")
|
||||||
|
.add("eu-ams-1").build());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,38 @@
|
||||||
|
/**
|
||||||
|
* 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.joyent.sdc.v6_5;
|
||||||
|
|
||||||
|
import static org.testng.Assert.assertEquals;
|
||||||
|
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import org.jclouds.joyent.sdc.v6_5.internal.BaseSDCClientLiveTest;
|
||||||
|
import org.testng.annotations.Test;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Adrian Cole
|
||||||
|
*/
|
||||||
|
@Test(groups = "live", testName = "SDCClientLiveTest")
|
||||||
|
public class SDCClientLiveTest extends BaseSDCClientLiveTest {
|
||||||
|
|
||||||
|
public void testGetDatacenters() {
|
||||||
|
Set<String> dcs = sdcContext.getApi().getConfiguredDatacenters();
|
||||||
|
assertEquals(dcs, sdcContext.getApi().getDatacenterClient().getDatacenters().keySet());
|
||||||
|
}
|
||||||
|
}
|
|
@ -22,32 +22,20 @@ import static org.testng.Assert.assertEquals;
|
||||||
|
|
||||||
import java.net.URI;
|
import java.net.URI;
|
||||||
|
|
||||||
import org.jclouds.http.HttpRequest;
|
|
||||||
import org.jclouds.http.HttpResponse;
|
import org.jclouds.http.HttpResponse;
|
||||||
import org.jclouds.joyent.sdc.v6_5.SDCClient;
|
import org.jclouds.joyent.sdc.v6_5.SDCClient;
|
||||||
import org.jclouds.joyent.sdc.v6_5.internal.BaseSDCClientExpectTest;
|
import org.jclouds.joyent.sdc.v6_5.internal.BaseSDCClientExpectTest;
|
||||||
import org.testng.annotations.Test;
|
import org.testng.annotations.Test;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
import com.google.common.collect.ImmutableMap;
|
||||||
import com.google.common.collect.ImmutableMultimap;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Adrian Cole
|
* @author Adrian Cole
|
||||||
*/
|
*/
|
||||||
@Test(groups = "unit", testName = "DatacenterClientExpectTest")
|
@Test(groups = "unit", testName = "DatacenterClientExpectTest")
|
||||||
public class DatacenterClientExpectTest extends BaseSDCClientExpectTest {
|
public class DatacenterClientExpectTest extends BaseSDCClientExpectTest {
|
||||||
HttpRequest getDatacenters = HttpRequest
|
|
||||||
.builder()
|
|
||||||
.method("GET")
|
|
||||||
.endpoint(URI.create("https://api.joyentcloud.com/my/datacenters"))
|
|
||||||
.headers(
|
|
||||||
ImmutableMultimap.<String, String> builder().put("X-Api-Version", "~6.5")
|
|
||||||
.put("Accept", "application/json").put("Authorization", "Basic aWRlbnRpdHk6Y3JlZGVudGlhbA==")
|
|
||||||
.build()).build();
|
|
||||||
|
|
||||||
public void testGetDatacentersWhenResponseIs2xx() {
|
public void testGetDatacentersWhenResponseIs2xx() {
|
||||||
HttpResponse getDatacentersResponse = HttpResponse.builder().statusCode(200)
|
|
||||||
.payload(payloadFromResource("/datacenters.json")).build();
|
|
||||||
|
|
||||||
SDCClient clientWhenDatacentersExists = requestSendsResponse(getDatacenters, getDatacentersResponse);
|
SDCClient clientWhenDatacentersExists = requestSendsResponse(getDatacenters, getDatacentersResponse);
|
||||||
|
|
||||||
|
|
|
@ -38,7 +38,7 @@ import com.google.common.collect.ImmutableSet;
|
||||||
@Test(groups = "unit", testName = "DatasetClientExpectTest")
|
@Test(groups = "unit", testName = "DatasetClientExpectTest")
|
||||||
public class DatasetClientExpectTest extends BaseSDCClientExpectTest {
|
public class DatasetClientExpectTest extends BaseSDCClientExpectTest {
|
||||||
HttpRequest listDatasets = HttpRequest.builder().method("GET").endpoint(
|
HttpRequest listDatasets = HttpRequest.builder().method("GET").endpoint(
|
||||||
URI.create("https://api.joyentcloud.com/my/datasets")).headers(
|
URI.create("https://us-sw-1.api.joyentcloud.com/my/datasets")).headers(
|
||||||
ImmutableMultimap.<String, String> builder().put("X-Api-Version", "~6.5").put("Accept", "application/json")
|
ImmutableMultimap.<String, String> builder().put("X-Api-Version", "~6.5").put("Accept", "application/json")
|
||||||
.put("Authorization", "Basic aWRlbnRpdHk6Y3JlZGVudGlhbA==").build()).build();
|
.put("Authorization", "Basic aWRlbnRpdHk6Y3JlZGVudGlhbA==").build()).build();
|
||||||
|
|
||||||
|
@ -46,18 +46,18 @@ public class DatasetClientExpectTest extends BaseSDCClientExpectTest {
|
||||||
HttpResponse listDatasetsResponse = HttpResponse.builder().statusCode(200).payload(
|
HttpResponse listDatasetsResponse = HttpResponse.builder().statusCode(200).payload(
|
||||||
payloadFromResource("/dataset_list.json")).build();
|
payloadFromResource("/dataset_list.json")).build();
|
||||||
|
|
||||||
SDCClient clientWhenDatasetsExists = requestSendsResponse(listDatasets, listDatasetsResponse);
|
SDCClient clientWhenDatasetsExists = requestsSendResponses(getDatacenters, getDatacentersResponse, listDatasets, listDatasetsResponse);
|
||||||
|
|
||||||
assertEquals(clientWhenDatasetsExists.getDatasetClient().listDatasets().toString(), new ParseDatasetListTest()
|
assertEquals(clientWhenDatasetsExists.getDatasetClientForDatacenter("us-sw-1").listDatasets().toString(), new ParseDatasetListTest()
|
||||||
.expected().toString());
|
.expected().toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testListDatasetsWhenResponseIs404() {
|
public void testListDatasetsWhenResponseIs404() {
|
||||||
HttpResponse listDatasetsResponse = HttpResponse.builder().statusCode(404).build();
|
HttpResponse listDatasetsResponse = HttpResponse.builder().statusCode(404).build();
|
||||||
|
|
||||||
SDCClient listDatasetsWhenNone = requestSendsResponse(listDatasets, listDatasetsResponse);
|
SDCClient listDatasetsWhenNone = requestsSendResponses(getDatacenters, getDatacentersResponse, listDatasets, listDatasetsResponse);
|
||||||
|
|
||||||
assertEquals(listDatasetsWhenNone.getDatasetClient().listDatasets(), ImmutableSet.of());
|
assertEquals(listDatasetsWhenNone.getDatasetClientForDatacenter("us-sw-1").listDatasets(), ImmutableSet.of());
|
||||||
}
|
}
|
||||||
|
|
||||||
// [id=e4cd7b9e-4330-11e1-81cf-3bb50a972bda, name=centos-6, type=VIRTUALMACHINE, version=1.0.1,
|
// [id=e4cd7b9e-4330-11e1-81cf-3bb50a972bda, name=centos-6, type=VIRTUALMACHINE, version=1.0.1,
|
||||||
|
|
|
@ -18,9 +18,7 @@
|
||||||
*/
|
*/
|
||||||
package org.jclouds.joyent.sdc.v6_5.features;
|
package org.jclouds.joyent.sdc.v6_5.features;
|
||||||
|
|
||||||
import static org.testng.Assert.assertNotNull;
|
import static org.testng.Assert.assertEquals;
|
||||||
import static org.testng.Assert.assertTrue;
|
|
||||||
import static org.testng.AssertJUnit.assertEquals;
|
|
||||||
|
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
@ -34,16 +32,22 @@ import org.testng.annotations.Test;
|
||||||
@Test(groups = "live", testName = "DatasetClientLiveTest")
|
@Test(groups = "live", testName = "DatasetClientLiveTest")
|
||||||
public class DatasetClientLiveTest extends BaseSDCClientLiveTest {
|
public class DatasetClientLiveTest extends BaseSDCClientLiveTest {
|
||||||
|
|
||||||
public void testListDatasets() {
|
@Test
|
||||||
Set<Dataset> datasets = sdcContext.getApi().getDatasetClient().listDatasets();
|
public void testListAndGetDatasets() throws Exception {
|
||||||
assertNotNull(datasets);
|
for (String datacenterId : sdcContext.getApi().getConfiguredDatacenters()) {
|
||||||
assertTrue(datasets.size() > 0);
|
DatasetClient client = sdcContext.getApi().getDatasetClientForDatacenter(datacenterId);
|
||||||
|
Set<Dataset> response = client.listDatasets();
|
||||||
|
assert null != response;
|
||||||
|
for (Dataset dataset : response) {
|
||||||
|
Dataset newDetails = client.getDataset(dataset.getId());
|
||||||
|
assertEquals(newDetails.getId(), dataset.getId());
|
||||||
|
assertEquals(newDetails.getName(), dataset.getName());
|
||||||
|
assertEquals(newDetails.getType(), dataset.getType());
|
||||||
|
assertEquals(newDetails.getVersion(), dataset.getVersion());
|
||||||
|
assertEquals(newDetails.getUrn(), dataset.getUrn());
|
||||||
|
assertEquals(newDetails.getCreated(), dataset.getCreated());
|
||||||
|
assertEquals(newDetails.isDefault(), dataset.isDefault());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testGetDataset() {
|
|
||||||
final String id = "e4cd7b9e-4330-11e1-81cf-3bb50a972bda";
|
|
||||||
Dataset dataset = sdcContext.getApi().getDatasetClient().getDataset(id);
|
|
||||||
assertNotNull(dataset);
|
|
||||||
assertEquals(dataset.getId(), id);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -39,7 +39,7 @@ import com.google.common.collect.ImmutableSet;
|
||||||
@Test(groups = "unit", testName = "MachineClientExpectTest")
|
@Test(groups = "unit", testName = "MachineClientExpectTest")
|
||||||
public class MachineClientExpectTest extends BaseSDCClientExpectTest {
|
public class MachineClientExpectTest extends BaseSDCClientExpectTest {
|
||||||
HttpRequest listMachines = HttpRequest.builder().method("GET").endpoint(
|
HttpRequest listMachines = HttpRequest.builder().method("GET").endpoint(
|
||||||
URI.create("https://api.joyentcloud.com/my/machines")).headers(
|
URI.create("https://us-sw-1.api.joyentcloud.com/my/machines")).headers(
|
||||||
ImmutableMultimap.<String, String> builder().put("X-Api-Version", "~6.5").put("Accept", "application/json")
|
ImmutableMultimap.<String, String> builder().put("X-Api-Version", "~6.5").put("Accept", "application/json")
|
||||||
.put("Authorization", "Basic aWRlbnRpdHk6Y3JlZGVudGlhbA==").build()).build();
|
.put("Authorization", "Basic aWRlbnRpdHk6Y3JlZGVudGlhbA==").build()).build();
|
||||||
|
|
||||||
|
@ -47,24 +47,24 @@ public class MachineClientExpectTest extends BaseSDCClientExpectTest {
|
||||||
HttpResponse listMachinesResponse = HttpResponse.builder().statusCode(200).payload(
|
HttpResponse listMachinesResponse = HttpResponse.builder().statusCode(200).payload(
|
||||||
payloadFromResource("/machine_list.json")).build();
|
payloadFromResource("/machine_list.json")).build();
|
||||||
|
|
||||||
SDCClient clientWhenMachinesExists = requestSendsResponse(listMachines, listMachinesResponse);
|
SDCClient clientWhenMachinesExists = requestsSendResponses(getDatacenters, getDatacentersResponse, listMachines, listMachinesResponse);
|
||||||
|
|
||||||
assertEquals(clientWhenMachinesExists.getMachineClient().listMachines(), new ParseMachineListTest().expected());
|
assertEquals(clientWhenMachinesExists.getMachineClientForDatacenter("us-sw-1").listMachines(), new ParseMachineListTest().expected());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testListMachinesWhenResponseIs404() {
|
public void testListMachinesWhenResponseIs404() {
|
||||||
HttpResponse listMachinesResponse = HttpResponse.builder().statusCode(404).build();
|
HttpResponse listMachinesResponse = HttpResponse.builder().statusCode(404).build();
|
||||||
|
|
||||||
SDCClient listMachinesWhenNone = requestSendsResponse(listMachines, listMachinesResponse);
|
SDCClient listMachinesWhenNone = requestsSendResponses(getDatacenters, getDatacentersResponse, listMachines, listMachinesResponse);
|
||||||
|
|
||||||
assertEquals(listMachinesWhenNone.getMachineClient().listMachines(), ImmutableSet.of());
|
assertEquals(listMachinesWhenNone.getMachineClientForDatacenter("us-sw-1").listMachines(), ImmutableSet.of());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testCreateMachineWhenResponseIs202() throws Exception {
|
public void testCreateMachineWhenResponseIs202() throws Exception {
|
||||||
HttpRequest createMachine = HttpRequest
|
HttpRequest createMachine = HttpRequest
|
||||||
.builder()
|
.builder()
|
||||||
.method("POST")
|
.method("POST")
|
||||||
.endpoint(URI.create("https://api.joyentcloud.com/my/machines"))
|
.endpoint(URI.create("https://us-sw-1.api.joyentcloud.com/my/machines"))
|
||||||
.headers(
|
.headers(
|
||||||
ImmutableMultimap.<String, String> builder().put("X-Api-Version", "~6.5").put("Accept",
|
ImmutableMultimap.<String, String> builder().put("X-Api-Version", "~6.5").put("Accept",
|
||||||
"application/json").put("Authorization", "Basic aWRlbnRpdHk6Y3JlZGVudGlhbA==").build())
|
"application/json").put("Authorization", "Basic aWRlbnRpdHk6Y3JlZGVudGlhbA==").build())
|
||||||
|
@ -77,9 +77,9 @@ public class MachineClientExpectTest extends BaseSDCClientExpectTest {
|
||||||
.payload(payloadFromResourceWithContentType("/new_machine.json", "application/json; charset=UTF-8"))
|
.payload(payloadFromResourceWithContentType("/new_machine.json", "application/json; charset=UTF-8"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
SDCClient clientWithNewMachine = requestSendsResponse(createMachine, createMachineResponse);
|
SDCClient clientWithNewMachine = requestsSendResponses(getDatacenters, getDatacentersResponse, createMachine, createMachineResponse);
|
||||||
|
|
||||||
assertEquals(clientWithNewMachine.getMachineClient().createMachine("testJClouds", "Small 1GB",
|
assertEquals(clientWithNewMachine.getMachineClientForDatacenter("us-sw-1").createMachine("testJClouds", "Small 1GB",
|
||||||
"sdc:sdc:centos-5.7:1.2.1").toString(), new ParseCreatedMachineTest().expected().toString());
|
"sdc:sdc:centos-5.7:1.2.1").toString(), new ParseCreatedMachineTest().expected().toString());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,8 +19,6 @@
|
||||||
package org.jclouds.joyent.sdc.v6_5.features;
|
package org.jclouds.joyent.sdc.v6_5.features;
|
||||||
|
|
||||||
import static org.testng.Assert.assertEquals;
|
import static org.testng.Assert.assertEquals;
|
||||||
import static org.testng.Assert.assertNotNull;
|
|
||||||
import static org.testng.Assert.assertTrue;
|
|
||||||
|
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
@ -34,16 +32,26 @@ import org.testng.annotations.Test;
|
||||||
@Test(groups = "live", testName = "MachineClientLiveTest")
|
@Test(groups = "live", testName = "MachineClientLiveTest")
|
||||||
public class MachineClientLiveTest extends BaseSDCClientLiveTest {
|
public class MachineClientLiveTest extends BaseSDCClientLiveTest {
|
||||||
|
|
||||||
public void testListMachines() {
|
@Test
|
||||||
Set<Machine> machines = sdcContext.getApi().getMachineClient().listMachines();
|
public void testListAndGetMachines() throws Exception {
|
||||||
assertNotNull(machines);
|
for (String datacenterId : sdcContext.getApi().getConfiguredDatacenters()) {
|
||||||
assertTrue(machines.size() > 0);
|
MachineClient client = sdcContext.getApi().getMachineClientForDatacenter(datacenterId);
|
||||||
|
Set<Machine> response = client.listMachines();
|
||||||
|
assert null != response;
|
||||||
|
for (Machine machine : response) {
|
||||||
|
Machine newDetails = client.getMachine(machine.getId());
|
||||||
|
assertEquals(newDetails.getId(), machine.getId());
|
||||||
|
assertEquals(newDetails.getName(), machine.getName());
|
||||||
|
assertEquals(newDetails.getType(), machine.getType());
|
||||||
|
assertEquals(newDetails.getState(), machine.getState());
|
||||||
|
assertEquals(newDetails.getDataset(), machine.getDataset());
|
||||||
|
assertEquals(newDetails.getMemorySizeMb(), machine.getMemorySizeMb());
|
||||||
|
assertEquals(newDetails.getDiskSizeGb(), machine.getDiskSizeGb());
|
||||||
|
assertEquals(newDetails.getIps(), machine.getIps());
|
||||||
|
assertEquals(newDetails.getCreated(), machine.getCreated());
|
||||||
|
assertEquals(newDetails.getUpdated(), machine.getUpdated());
|
||||||
|
assertEquals(newDetails.getMetadata(), machine.getMetadata());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testGetMachine() {
|
|
||||||
final String id = "d73cb0b0-7d1f-44ef-8c40-e040eef0f726";
|
|
||||||
Machine machine = sdcContext.getApi().getMachineClient().getMachine(id);
|
|
||||||
assertNotNull(machine);
|
|
||||||
assertEquals(machine.getId(), id);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -40,7 +40,7 @@ public class PackageClientExpectTest extends BaseSDCClientExpectTest {
|
||||||
HttpRequest listPackages = HttpRequest
|
HttpRequest listPackages = HttpRequest
|
||||||
.builder()
|
.builder()
|
||||||
.method("GET")
|
.method("GET")
|
||||||
.endpoint(URI.create("https://api.joyentcloud.com/my/packages"))
|
.endpoint(URI.create("https://us-sw-1.api.joyentcloud.com/my/packages"))
|
||||||
.headers(
|
.headers(
|
||||||
ImmutableMultimap.<String, String> builder().put("X-Api-Version", "~6.5")
|
ImmutableMultimap.<String, String> builder().put("X-Api-Version", "~6.5")
|
||||||
.put("Accept", "application/json").put("Authorization", "Basic aWRlbnRpdHk6Y3JlZGVudGlhbA==")
|
.put("Accept", "application/json").put("Authorization", "Basic aWRlbnRpdHk6Y3JlZGVudGlhbA==")
|
||||||
|
@ -50,16 +50,16 @@ public class PackageClientExpectTest extends BaseSDCClientExpectTest {
|
||||||
HttpResponse listPackagesResponse = HttpResponse.builder().statusCode(200)
|
HttpResponse listPackagesResponse = HttpResponse.builder().statusCode(200)
|
||||||
.payload(payloadFromResource("/package_list.json")).build();
|
.payload(payloadFromResource("/package_list.json")).build();
|
||||||
|
|
||||||
SDCClient clientWhenPackagesExists = requestSendsResponse(listPackages, listPackagesResponse);
|
SDCClient clientWhenPackagesExists = requestsSendResponses(getDatacenters, getDatacentersResponse, listPackages, listPackagesResponse);
|
||||||
|
|
||||||
assertEquals(clientWhenPackagesExists.getPackageClient().listPackages(), new ParsePackageListTest().expected());
|
assertEquals(clientWhenPackagesExists.getPackageClientForDatacenter("us-sw-1").listPackages(), new ParsePackageListTest().expected());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testListPackagesWhenResponseIs404() {
|
public void testListPackagesWhenResponseIs404() {
|
||||||
HttpResponse listPackagesResponse = HttpResponse.builder().statusCode(404).build();
|
HttpResponse listPackagesResponse = HttpResponse.builder().statusCode(404).build();
|
||||||
|
|
||||||
SDCClient listPackagesWhenNone = requestSendsResponse(listPackages, listPackagesResponse);
|
SDCClient listPackagesWhenNone = requestsSendResponses(getDatacenters, getDatacentersResponse, listPackages, listPackagesResponse);
|
||||||
|
|
||||||
assertEquals(listPackagesWhenNone.getPackageClient().listPackages(), ImmutableSet.of());
|
assertEquals(listPackagesWhenNone.getPackageClientForDatacenter("us-sw-1").listPackages(), ImmutableSet.of());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,12 +18,11 @@
|
||||||
*/
|
*/
|
||||||
package org.jclouds.joyent.sdc.v6_5.features;
|
package org.jclouds.joyent.sdc.v6_5.features;
|
||||||
|
|
||||||
import static org.testng.Assert.assertNotNull;
|
import static org.testng.Assert.assertEquals;
|
||||||
import static org.testng.Assert.assertTrue;
|
|
||||||
import static org.testng.AssertJUnit.assertEquals;
|
|
||||||
|
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
import org.jclouds.joyent.sdc.v6_5.domain.Package;
|
||||||
import org.jclouds.joyent.sdc.v6_5.internal.BaseSDCClientLiveTest;
|
import org.jclouds.joyent.sdc.v6_5.internal.BaseSDCClientLiveTest;
|
||||||
import org.testng.annotations.Test;
|
import org.testng.annotations.Test;
|
||||||
|
|
||||||
|
@ -33,16 +32,20 @@ import org.testng.annotations.Test;
|
||||||
@Test(groups = "live", testName = "PackageClientLiveTest")
|
@Test(groups = "live", testName = "PackageClientLiveTest")
|
||||||
public class PackageClientLiveTest extends BaseSDCClientLiveTest {
|
public class PackageClientLiveTest extends BaseSDCClientLiveTest {
|
||||||
|
|
||||||
public void testListPackages() {
|
@Test
|
||||||
Set<org.jclouds.joyent.sdc.v6_5.domain.Package> packages = sdcContext.getApi().getPackageClient().listPackages();
|
public void testListAndGetPackages() throws Exception {
|
||||||
assertNotNull(packages);
|
for (String datacenterId : sdcContext.getApi().getConfiguredDatacenters()) {
|
||||||
assertTrue(packages.size() > 0);
|
PackageClient client = sdcContext.getApi().getPackageClientForDatacenter(datacenterId);
|
||||||
|
Set<Package> response = client.listPackages();
|
||||||
|
assert null != response;
|
||||||
|
for (Package pkg : response) {
|
||||||
|
Package newDetails = client.getPackage(pkg.getName());
|
||||||
|
assertEquals(newDetails.getName(), pkg.getName());
|
||||||
|
assertEquals(newDetails.getMemorySizeMb(), pkg.getMemorySizeMb());
|
||||||
|
assertEquals(newDetails.getDiskSizeGb(), pkg.getDiskSizeGb());
|
||||||
|
assertEquals(newDetails.getSwapSizeMb(), pkg.getSwapSizeMb());
|
||||||
|
assertEquals(newDetails.isDefault(), pkg.isDefault());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testGetPackage() {
|
|
||||||
final String name = "Small 1GB";
|
|
||||||
org.jclouds.joyent.sdc.v6_5.domain.Package packageSDC = sdcContext.getApi().getPackageClient().getPackage(name);
|
|
||||||
assertNotNull(packageSDC);
|
|
||||||
assertEquals(packageSDC.getName(), name);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,13 +18,31 @@
|
||||||
*/
|
*/
|
||||||
package org.jclouds.joyent.sdc.v6_5.internal;
|
package org.jclouds.joyent.sdc.v6_5.internal;
|
||||||
|
|
||||||
|
import java.net.URI;
|
||||||
|
|
||||||
|
import org.jclouds.http.HttpRequest;
|
||||||
|
import org.jclouds.http.HttpResponse;
|
||||||
import org.jclouds.joyent.sdc.v6_5.SDCClient;
|
import org.jclouds.joyent.sdc.v6_5.SDCClient;
|
||||||
|
|
||||||
|
import com.google.common.collect.ImmutableMultimap;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Base class for writing KeyStone Rest Client Expect tests
|
* Base class for writing KeyStone Rest Client Expect tests
|
||||||
*
|
*
|
||||||
* @author Adrian Cole
|
* @author Adrian Cole
|
||||||
*/
|
*/
|
||||||
public class BaseSDCClientExpectTest extends BaseSDCExpectTest<SDCClient> {
|
public class BaseSDCClientExpectTest extends BaseSDCExpectTest<SDCClient> {
|
||||||
|
protected HttpRequest getDatacenters = HttpRequest
|
||||||
|
.builder()
|
||||||
|
.method("GET")
|
||||||
|
.endpoint(URI.create("https://api.joyentcloud.com/my/datacenters"))
|
||||||
|
.headers(
|
||||||
|
ImmutableMultimap.<String, String> builder()
|
||||||
|
.put("X-Api-Version", "~6.5")
|
||||||
|
.put("Accept", "application/json")
|
||||||
|
.put("Authorization", "Basic aWRlbnRpdHk6Y3JlZGVudGlhbA==")
|
||||||
|
.build()).build();
|
||||||
|
|
||||||
|
protected HttpResponse getDatacentersResponse = HttpResponse.builder().statusCode(200)
|
||||||
|
.payload(payloadFromResource("/datacenters.json")).build();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue