Enabled base Chef api tests in Private Chef

* Refactored BaseChefClientLiveTest to allow the use of different
  context types such as PrivateChefContext, etc.
* Added delegate methods to PrivateChef*Clients to access the
  Chef*Clients.
* Removed the hardcoded Chef Server version in tests and read it from
 the system properties.
This commit is contained in:
Ignasi Barrera 2012-07-02 16:17:05 +02:00
parent 05481efd71
commit 20912c9ad4
10 changed files with 224 additions and 107 deletions

View File

@ -18,16 +18,38 @@
*/ */
package org.jclouds.chef; package org.jclouds.chef;
import static org.testng.Assert.assertNotNull;
import org.jclouds.chef.domain.CookbookVersion;
import org.jclouds.chef.internal.BaseChefClientLiveTest; import org.jclouds.chef.internal.BaseChefClientLiveTest;
import org.testng.annotations.Test; import org.testng.annotations.Test;
import com.google.common.reflect.TypeToken;
/** /**
* Tests behavior of {@code ChefClient} against a Chef Server <= 0.9.8. * Tests behavior of {@code ChefClient} against a Chef Server <= 0.9.8.
* *
* @author Adrian Cole * @author Adrian Cole
*/ */
@Test(groups = { "live" }) @Test(groups = { "live" })
public class ChefClientLiveTest extends BaseChefClientLiveTest { public class ChefClientLiveTest extends BaseChefClientLiveTest<ChefContext> {
@Test
public void testListCookbookVersionsWithChefService() throws Exception {
Iterable<? extends CookbookVersion> cookbooks = context.getChefService().listCookbookVersions();
assertNotNull(cookbooks);
}
@Override
protected ChefClient getChefClient(ChefContext context)
{
return context.getApi();
}
@Override
protected TypeToken<ChefContext> contextType()
{
return TypeToken.of(ChefContext.class);
}
} }

View File

@ -30,7 +30,8 @@ import java.util.List;
import java.util.Properties; import java.util.Properties;
import java.util.Set; import java.util.Set;
import org.jclouds.chef.ChefContext; import org.jclouds.Context;
import org.jclouds.chef.ChefClient;
import org.jclouds.chef.domain.ChecksumStatus; import org.jclouds.chef.domain.ChecksumStatus;
import org.jclouds.chef.domain.Client; import org.jclouds.chef.domain.Client;
import org.jclouds.chef.domain.CookbookVersion; import org.jclouds.chef.domain.CookbookVersion;
@ -62,25 +63,22 @@ import com.google.common.primitives.Bytes;
* @author Adrian Cole * @author Adrian Cole
*/ */
@Test(groups = { "live", "integration" }) @Test(groups = { "live", "integration" })
public abstract class BaseChefClientLiveTest extends BaseChefContextLiveTest { public abstract class BaseChefClientLiveTest<C extends Context> extends BaseChefContextLiveTest<C> {
public static final String PREFIX = System.getProperty("user.name") + "-jcloudstest"; public static final String PREFIX = System.getProperty("user.name") + "-jcloudstest";
public static final String ADMIN_PREFIX = System.getProperty("user.name") + "-jcloudstest-adm"; public static final String ADMIN_PREFIX = System.getProperty("user.name") + "-jcloudstest-adm";
public static final String VALIDATOR_PREFIX = System.getProperty("user.name") + "-jcloudstest-val"; public static final String VALIDATOR_PREFIX = System.getProperty("user.name") + "-jcloudstest-val";
private String validatorIdentity; private String validatorIdentity;
private String validatorCredential; private String validatorCredential;
protected ChefContext validatorContext; private C validatorContext;
private ChefClient validatorClient;
@Override protected ChefClient chefClient;
protected Properties setupProperties() {
Properties overrides = super.setupProperties();
validatorIdentity = setIfTestSystemPropertyPresent(overrides, provider + ".validator.identity");
validatorCredential = setCredentialFromPemFile(overrides, validatorIdentity, provider + ".validator.credential");
return overrides;
}
protected Properties setupValidatorProperties() { protected Properties setupValidatorProperties() {
Properties overrides = setupProperties(); Properties overrides = setupProperties();
validatorIdentity = setIfTestSystemPropertyPresent(overrides, provider + ".validator.identity");
validatorCredential = setCredentialFromPemFile(overrides, validatorIdentity, provider + ".validator.credential");
overrides.setProperty(provider + ".identity", validatorIdentity); overrides.setProperty(provider + ".identity", validatorIdentity);
overrides.setProperty(provider + ".credential", validatorCredential); overrides.setProperty(provider + ".credential", validatorCredential);
return overrides; return overrides;
@ -91,6 +89,8 @@ public abstract class BaseChefClientLiveTest extends BaseChefContextLiveTest {
public void setupContext() { public void setupContext() {
super.setupContext(); super.setupContext();
validatorContext = createContext(setupValidatorProperties(), setupModules()); validatorContext = createContext(setupValidatorProperties(), setupModules());
chefClient = getChefClient(context);
validatorClient = getChefClient(validatorContext);
} }
private Node node; private Node node;
@ -112,7 +112,7 @@ public abstract class BaseChefClientLiveTest extends BaseChefContextLiveTest {
List<Byte> md5 = Bytes.asList(content.getContentMetadata().getContentMD5()); List<Byte> md5 = Bytes.asList(content.getContentMetadata().getContentMD5());
// request an upload site for this file // request an upload site for this file
UploadSandbox site = context.getApi().getUploadSandboxForChecksums(ImmutableSet.of(md5)); UploadSandbox site = chefClient.getUploadSandboxForChecksums(ImmutableSet.of(md5));
try { try {
assert site.getChecksums().containsKey(md5) : md5 + " not in " + site.getChecksums(); assert site.getChecksums().containsKey(md5) : md5 + " not in " + site.getChecksums();
@ -120,13 +120,13 @@ public abstract class BaseChefClientLiveTest extends BaseChefContextLiveTest {
ChecksumStatus status = site.getChecksums().get(md5); ChecksumStatus status = site.getChecksums().get(md5);
if (status.needsUpload()) { if (status.needsUpload()) {
//context.utils().http().put(status.getUrl(), content); //context.utils().http().put(status.getUrl(), content);
context.getApi().uploadContent(status.getUrl(), content); chefClient.uploadContent(status.getUrl(), content);
} }
context.getApi().commitSandbox(site.getSandboxId(), true); chefClient.commitSandbox(site.getSandboxId(), true);
} catch (RuntimeException e) { } catch (RuntimeException e) {
context.getApi().commitSandbox(site.getSandboxId(), false); chefClient.commitSandbox(site.getSandboxId(), false);
} }
// create a new cookbook // create a new cookbook
@ -134,29 +134,29 @@ public abstract class BaseChefClientLiveTest extends BaseChefContextLiveTest {
cookbook.getRootFiles().add(new Resource(content)); cookbook.getRootFiles().add(new Resource(content));
// upload the cookbook to the remote server // upload the cookbook to the remote server
context.getApi().updateCookbook("test3", "0.0.0", cookbook); chefClient.updateCookbook("test3", "0.0.0", cookbook);
} }
@Test(dependsOnMethods = "testCreateClient") @Test(dependsOnMethods = "testCreateClient")
public void testGenerateKeyForClient() throws Exception { public void testGenerateKeyForClient() throws Exception {
String credential = Pems.pem(context.getApi().generateKeyForClient(PREFIX).getPrivateKey()); String credential = Pems.pem(chefClient.generateKeyForClient(PREFIX).getPrivateKey());
assertClientCreated(PREFIX, credential); assertClientCreated(PREFIX, credential);
} }
@Test @Test
public void testListCookbooks() throws Exception { public void testListCookbooks() throws Exception {
Set<String> cookbookNames = context.getApi().listCookbooks(); Set<String> cookbookNames = chefClient.listCookbooks();
assertFalse(cookbookNames.isEmpty()); assertFalse(cookbookNames.isEmpty());
for (String cookbook : cookbookNames) for (String cookbook : cookbookNames)
for (String version : context.getApi().getVersionsOfCookbook(cookbook)) { for (String version : chefClient.getVersionsOfCookbook(cookbook)) {
CookbookVersion cookbookO = context.getApi().getCookbook(cookbook, version); CookbookVersion cookbookO = chefClient.getCookbook(cookbook, version);
for (Resource resource : ImmutableList.<Resource> builder().addAll(cookbookO.getDefinitions()).addAll( for (Resource resource : ImmutableList.<Resource> builder().addAll(cookbookO.getDefinitions()).addAll(
cookbookO.getFiles()).addAll(cookbookO.getLibraries()).addAll(cookbookO.getSuppliers()).addAll( cookbookO.getFiles()).addAll(cookbookO.getLibraries()).addAll(cookbookO.getSuppliers()).addAll(
cookbookO.getRecipes()).addAll(cookbookO.getResources()).addAll(cookbookO.getRootFiles()).addAll( cookbookO.getRecipes()).addAll(cookbookO.getResources()).addAll(cookbookO.getRootFiles()).addAll(
cookbookO.getTemplates()).build()) { cookbookO.getTemplates()).build()) {
try { try {
InputStream stream = context.getApi().getResourceContents(resource); InputStream stream = chefClient.getResourceContents(resource);
byte[] md5 = CryptoStreams.md5(InputSuppliers.of(stream)); byte[] md5 = CryptoStreams.md5(InputSuppliers.of(stream));
assertEquals(md5, resource.getChecksum()); assertEquals(md5, resource.getChecksum());
} catch (NullPointerException e) { } catch (NullPointerException e) {
@ -168,102 +168,100 @@ public abstract class BaseChefClientLiveTest extends BaseChefContextLiveTest {
@Test(dependsOnMethods = "testCreateNewCookbook") @Test(dependsOnMethods = "testCreateNewCookbook")
public void testUpdateCookbook() throws Exception { public void testUpdateCookbook() throws Exception {
for (String cookbook : context.getApi().listCookbooks()) for (String cookbook : chefClient.listCookbooks())
for (String version : context.getApi().getVersionsOfCookbook(cookbook)) { for (String version : chefClient.getVersionsOfCookbook(cookbook)) {
System.err.printf("%s/%s:%n", cookbook, version); CookbookVersion cook = chefClient.getCookbook(cookbook, version);
CookbookVersion cook = context.getApi().getCookbook(cookbook, version); chefClient.updateCookbook(cookbook, version, cook);
context.getApi().updateCookbook(cookbook, version, cook);
} }
} }
@Test(dependsOnMethods = {"testCreateNewCookbook", "testUpdateCookbook"}, enabled = false) @Test(dependsOnMethods = {"testCreateNewCookbook", "testUpdateCookbook"}, enabled = false)
public void testCreateCookbook() throws Exception { public void testCreateCookbook() throws Exception {
for (String cookbook : context.getApi().listCookbooks()) for (String cookbook : chefClient.listCookbooks())
for (String version : context.getApi().getVersionsOfCookbook(cookbook)) { for (String version : chefClient.getVersionsOfCookbook(cookbook)) {
System.err.printf("%s/%s:%n", cookbook, version); CookbookVersion cook = chefClient.getCookbook(cookbook, version);
CookbookVersion cook = context.getApi().getCookbook(cookbook, version); chefClient.deleteCookbook(cookbook, version);
context.getApi().deleteCookbook(cookbook, version); assert chefClient.getCookbook(cookbook, version) == null : cookbook + version;
assert context.getApi().getCookbook(cookbook, version) == null : cookbook + version; chefClient.updateCookbook(cookbook, version, cook);
context.getApi().updateCookbook(cookbook, version, cook);
} }
} }
@Test(expectedExceptions = AuthorizationException.class) @Test(expectedExceptions = AuthorizationException.class)
public void testValidatorCannotListClients() throws Exception { public void testValidatorCannotListClients() throws Exception {
for (String client : validatorContext.getApi().listClients()) for (String client : validatorClient.listClients())
assertNotNull(validatorContext.getApi().getClient(client)); assertNotNull(validatorClient.getClient(client));
} }
@Test(expectedExceptions = AuthorizationException.class) @Test(expectedExceptions = AuthorizationException.class)
public void testValidatorCannotDeleteClient() throws Exception { public void testValidatorCannotDeleteClient() throws Exception {
validatorContext.getApi().deleteClient(PREFIX); validatorClient.deleteClient(PREFIX);
} }
@Test @Test
public void testValidatorCanCreateClient() throws Exception { public void testValidatorCreateClient() throws Exception {
String credential = Pems.pem(validatorContext.getApi().createClient(VALIDATOR_PREFIX).getPrivateKey()); String credential = Pems.pem(validatorClient.createClient(VALIDATOR_PREFIX).getPrivateKey());
assertClientCreated(VALIDATOR_PREFIX, credential); assertClientCreated(VALIDATOR_PREFIX, credential);
} }
@Test @Test
public void testCreateClient() throws Exception { public void testCreateClient() throws Exception {
String credential = Pems.pem(context.getApi().createClient(PREFIX).getPrivateKey()); String credential = Pems.pem(chefClient.createClient(PREFIX).getPrivateKey());
assertClientCreated(PREFIX, credential); assertClientCreated(PREFIX, credential);
} }
@Test @Test
public void testCreateAdminClient() throws Exception { public void testCreateAdminClient() throws Exception {
String credential = Pems.pem(context.getApi().createClient(ADMIN_PREFIX, CreateClientOptions.Builder.admin()) String credential = Pems.pem(chefClient.createClient(ADMIN_PREFIX, CreateClientOptions.Builder.admin())
.getPrivateKey()); .getPrivateKey());
assertClientCreated(ADMIN_PREFIX, credential); assertClientCreated(ADMIN_PREFIX, credential);
} }
@Test @Test
public void testClientExists() throws Exception { public void testClientExists() throws Exception {
assertNotNull(context.getApi().clientExists(validatorIdentity)); assertNotNull(chefClient.clientExists(validatorIdentity));
} }
@Test @Test
public void testListNodes() throws Exception { public void testListNodes() throws Exception {
Set<String> nodes = context.getApi().listNodes(); Set<String> nodes = chefClient.listNodes();
assertNotNull(nodes); assertNotNull(nodes);
} }
@Test(dependsOnMethods = "testCreateRole") @Test(dependsOnMethods = "testCreateRole")
public void testCreateNode() throws Exception { public void testCreateNode() throws Exception {
context.getApi().deleteNode(PREFIX); chefClient.deleteNode(PREFIX);
context.getApi().createNode(new Node(PREFIX, Collections.singleton("role[" + PREFIX + "]"))); chefClient.createNode(new Node(PREFIX, Collections.singleton("role[" + PREFIX + "]")));
node = context.getApi().getNode(PREFIX); node = chefClient.getNode(PREFIX);
// TODO check recipes // TODO check recipes
assertNotNull(node); assertNotNull(node);
Set<String> nodes = context.getApi().listNodes(); Set<String> nodes = chefClient.listNodes();
assert nodes.contains(PREFIX) : String.format("node %s not in %s", PREFIX, nodes); assert nodes.contains(PREFIX) : String.format("node %s not in %s", PREFIX, nodes);
} }
@Test(dependsOnMethods = "testCreateNode") @Test(dependsOnMethods = "testCreateNode")
public void testNodeExists() throws Exception { public void testNodeExists() throws Exception {
assertNotNull(context.getApi().nodeExists(PREFIX)); assertNotNull(chefClient.nodeExists(PREFIX));
} }
@Test(dependsOnMethods = "testNodeExists") @Test(dependsOnMethods = "testNodeExists")
public void testUpdateNode() throws Exception { public void testUpdateNode() throws Exception {
for (String nodename : context.getApi().listNodes()) { for (String nodename : chefClient.listNodes()) {
Node node = context.getApi().getNode(nodename); Node node = chefClient.getNode(nodename);
context.getApi().updateNode(node); chefClient.updateNode(node);
} }
} }
@Test @Test
public void testListRoles() throws Exception { public void testListRoles() throws Exception {
Set<String> roles = context.getApi().listRoles(); Set<String> roles = chefClient.listRoles();
assertNotNull(roles); assertNotNull(roles);
} }
@Test @Test
public void testCreateRole() throws Exception { public void testCreateRole() throws Exception {
context.getApi().deleteRole(PREFIX); chefClient.deleteRole(PREFIX);
context.getApi().createRole(new Role(PREFIX, Collections.singleton("recipe[java]"))); chefClient.createRole(new Role(PREFIX, Collections.singleton("recipe[java]")));
role = context.getApi().getRole(PREFIX); role = chefClient.getRole(PREFIX);
assertNotNull(role); assertNotNull(role);
assertEquals(role.getName(), PREFIX); assertEquals(role.getName(), PREFIX);
assertEquals(role.getRunList(), Collections.singleton("recipe[java]")); assertEquals(role.getRunList(), Collections.singleton("recipe[java]"));
@ -271,37 +269,37 @@ public abstract class BaseChefClientLiveTest extends BaseChefContextLiveTest {
@Test(dependsOnMethods = "testCreateRole") @Test(dependsOnMethods = "testCreateRole")
public void testRoleExists() throws Exception { public void testRoleExists() throws Exception {
assertNotNull(context.getApi().roleExists(PREFIX)); assertNotNull(chefClient.roleExists(PREFIX));
} }
@Test(dependsOnMethods = "testRoleExists") @Test(dependsOnMethods = "testRoleExists")
public void testUpdateRole() throws Exception { public void testUpdateRole() throws Exception {
for (String rolename : context.getApi().listRoles()) { for (String rolename : chefClient.listRoles()) {
Role role = context.getApi().getRole(rolename); Role role = chefClient.getRole(rolename);
context.getApi().updateRole(role); chefClient.updateRole(role);
} }
} }
@Test @Test
public void testListDatabags() throws Exception { public void testListDatabags() throws Exception {
Set<String> databags = context.getApi().listDatabags(); Set<String> databags = chefClient.listDatabags();
assertNotNull(databags); assertNotNull(databags);
} }
@Test @Test
public void testCreateDatabag() throws Exception { public void testCreateDatabag() throws Exception {
context.getApi().deleteDatabag(PREFIX); chefClient.deleteDatabag(PREFIX);
context.getApi().createDatabag(PREFIX); chefClient.createDatabag(PREFIX);
} }
@Test(dependsOnMethods = "testCreateDatabag") @Test(dependsOnMethods = "testCreateDatabag")
public void testDatabagExists() throws Exception { public void testDatabagExists() throws Exception {
assertNotNull(context.getApi().databagExists(PREFIX)); assertNotNull(chefClient.databagExists(PREFIX));
} }
@Test(dependsOnMethods = "testCreateDatabagItem") @Test(dependsOnMethods = "testCreateDatabagItem")
public void testListDatabagItems() throws Exception { public void testListDatabagItems() throws Exception {
Set<String> databagItems = context.getApi().listDatabagItems(PREFIX); Set<String> databagItems = chefClient.listDatabagItems(PREFIX);
assertNotNull(databagItems); assertNotNull(databagItems);
} }
@ -309,8 +307,8 @@ public abstract class BaseChefClientLiveTest extends BaseChefContextLiveTest {
public void testCreateDatabagItem() throws Exception { public void testCreateDatabagItem() throws Exception {
Properties config = new Properties(); Properties config = new Properties();
config.setProperty("foo", "bar"); config.setProperty("foo", "bar");
context.getApi().deleteDatabagItem(PREFIX, PREFIX); chefClient.deleteDatabagItem(PREFIX, PREFIX);
databagItem = context.getApi().createDatabagItem(PREFIX, databagItem = chefClient.createDatabagItem(PREFIX,
new DatabagItem("config", context.utils().json().toJson(config))); new DatabagItem("config", context.utils().json().toJson(config)));
assertNotNull(databagItem); assertNotNull(databagItem);
assertEquals(databagItem.getId(), "config"); assertEquals(databagItem.getId(), "config");
@ -325,20 +323,20 @@ public abstract class BaseChefClientLiveTest extends BaseChefContextLiveTest {
@Test(dependsOnMethods = "testCreateDatabagItem") @Test(dependsOnMethods = "testCreateDatabagItem")
public void testDatabagItemExists() throws Exception { public void testDatabagItemExists() throws Exception {
assertNotNull(context.getApi().databagItemExists(PREFIX, PREFIX)); assertNotNull(chefClient.databagItemExists(PREFIX, PREFIX));
} }
@Test(dependsOnMethods = "testDatabagItemExists") @Test(dependsOnMethods = "testDatabagItemExists")
public void testUpdateDatabagItem() throws Exception { public void testUpdateDatabagItem() throws Exception {
for (String databagItemId : context.getApi().listDatabagItems(PREFIX)) { for (String databagItemId : chefClient.listDatabagItems(PREFIX)) {
DatabagItem databagItem = context.getApi().getDatabagItem(PREFIX, databagItemId); DatabagItem databagItem = chefClient.getDatabagItem(PREFIX, databagItemId);
context.getApi().updateDatabagItem(PREFIX, databagItem); chefClient.updateDatabagItem(PREFIX, databagItem);
} }
} }
@Test @Test
public void testListSearchIndexes() throws Exception { public void testListSearchIndexes() throws Exception {
Set<String> indexes = context.getApi().listSearchIndexes(); Set<String> indexes = chefClient.listSearchIndexes();
assertNotNull(indexes); assertNotNull(indexes);
assert indexes.contains("node") : indexes; assert indexes.contains("node") : indexes;
assert indexes.contains("client") : indexes; assert indexes.contains("client") : indexes;
@ -347,50 +345,44 @@ public abstract class BaseChefClientLiveTest extends BaseChefContextLiveTest {
@Test @Test
public void testSearchNodes() throws Exception { public void testSearchNodes() throws Exception {
SearchResult<? extends Node> results = context.getApi().searchNodes(); SearchResult<? extends Node> results = chefClient.searchNodes();
assertNotNull(results); assertNotNull(results);
} }
@Test @Test
public void testSearchClients() throws Exception { public void testSearchClients() throws Exception {
SearchResult<? extends Client> results = context.getApi().searchClients(); SearchResult<? extends Client> results = chefClient.searchClients();
assertNotNull(results); assertNotNull(results);
} }
@Test @Test
public void testSearchRoles() throws Exception { public void testSearchRoles() throws Exception {
SearchResult<? extends Role> results = context.getApi().searchRoles(); SearchResult<? extends Role> results = chefClient.searchRoles();
assertNotNull(results); assertNotNull(results);
} }
@Test(dependsOnMethods = "testDatabagItemExists") @Test(dependsOnMethods = "testDatabagItemExists")
public void testSearchDatabag() throws Exception { public void testSearchDatabag() throws Exception {
SearchResult<? extends DatabagItem> results = context.getApi().searchDatabag(PREFIX); SearchResult<? extends DatabagItem> results = chefClient.searchDatabag(PREFIX);
assertNotNull(results); assertNotNull(results);
} }
@Test(expectedExceptions = ResourceNotFoundException.class) @Test(expectedExceptions = ResourceNotFoundException.class)
public void testSearchDatabagNotFound() throws Exception { public void testSearchDatabagNotFound() throws Exception {
SearchResult<? extends DatabagItem> results = context.getApi().searchDatabag("whoopie"); SearchResult<? extends DatabagItem> results = chefClient.searchDatabag("whoopie");
assertNotNull(results); assertNotNull(results);
} }
@Test
public void testListCookbookVersionsWithChefService() throws Exception {
Iterable<? extends CookbookVersion> cookbooks = context.getChefService().listCookbookVersions();
assertNotNull(cookbooks);
}
@AfterClass(groups = { "live", "integration" }) @AfterClass(groups = { "live", "integration" })
@Override @Override
public void tearDownContext() { public void tearDownContext() {
Closeables.closeQuietly(validatorContext); Closeables.closeQuietly(validatorContext);
context.getApi().deleteClient(PREFIX); chefClient.deleteClient(PREFIX);
context.getApi().deleteClient(ADMIN_PREFIX); chefClient.deleteClient(ADMIN_PREFIX);
context.getApi().deleteClient(VALIDATOR_PREFIX); chefClient.deleteClient(VALIDATOR_PREFIX);
context.getApi().deleteNode(PREFIX); chefClient.deleteNode(PREFIX);
context.getApi().deleteRole(PREFIX); chefClient.deleteRole(PREFIX);
context.getApi().deleteDatabag(PREFIX); chefClient.deleteDatabag(PREFIX);
super.tearDownContext(); super.tearDownContext();
} }
@ -399,14 +391,16 @@ public abstract class BaseChefClientLiveTest extends BaseChefContextLiveTest {
overrides.setProperty(provider + ".identity", identity); overrides.setProperty(provider + ".identity", identity);
overrides.setProperty(provider + ".credential", credential); overrides.setProperty(provider + ".credential", credential);
ChefContext clientContext = createContext(overrides, setupModules()); C clientContext = createContext(overrides, setupModules());
try { try {
Client client = clientContext.getApi().getClient(identity); Client client = getChefClient(clientContext).getClient(identity);
assertNotNull(client); assertNotNull(client);
} finally { } finally {
Closeables.closeQuietly(clientContext); Closeables.closeQuietly(clientContext);
} }
} }
} }

View File

@ -22,26 +22,28 @@ import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.util.Properties; import java.util.Properties;
import org.jclouds.Context;
import org.jclouds.apis.BaseContextLiveTest; import org.jclouds.apis.BaseContextLiveTest;
import org.jclouds.chef.ChefContext; import org.jclouds.chef.ChefClient;
import org.testng.annotations.Test; import org.testng.annotations.Test;
import com.google.common.base.Charsets; import com.google.common.base.Charsets;
import com.google.common.base.Throwables; import com.google.common.base.Throwables;
import com.google.common.io.Files; import com.google.common.io.Files;
import com.google.common.reflect.TypeToken;
/** /**
* *
* @author Adrian Cole * @author Adrian Cole
*/ */
@Test(groups = "live") @Test(groups = "live")
public class BaseChefContextLiveTest extends BaseContextLiveTest<ChefContext> { public abstract class BaseChefContextLiveTest<C extends Context> extends BaseContextLiveTest<C> {
public BaseChefContextLiveTest() { public BaseChefContextLiveTest() {
provider = "chef"; provider = "chef";
} }
protected abstract ChefClient getChefClient(C context);
/** /**
* the credential is a path to the pem file. * the credential is a path to the pem file.
*/ */
@ -69,9 +71,4 @@ public class BaseChefContextLiveTest extends BaseContextLiveTest<ChefContext> {
return credentialFromFile; return credentialFromFile;
} }
@Override
protected TypeToken<ChefContext> contextType() {
return TypeToken.of(ChefContext.class);
}
} }

View File

@ -22,6 +22,8 @@ import java.util.Map;
import org.jclouds.apis.ApiMetadata; import org.jclouds.apis.ApiMetadata;
import org.jclouds.chef.ChefApiMetadata; import org.jclouds.chef.ChefApiMetadata;
import org.jclouds.chef.ChefClient;
import org.jclouds.chef.ChefContext;
import org.jclouds.chef.config.ChefParserModule; import org.jclouds.chef.config.ChefParserModule;
import org.jclouds.chef.config.ChefRestClientModule; import org.jclouds.chef.config.ChefRestClientModule;
import org.jclouds.domain.JsonBall; import org.jclouds.domain.JsonBall;
@ -34,6 +36,7 @@ import com.google.common.base.Supplier;
import com.google.common.base.Suppliers; import com.google.common.base.Suppliers;
import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableMap;
import com.google.common.collect.ImmutableSet; import com.google.common.collect.ImmutableSet;
import com.google.common.reflect.TypeToken;
import com.google.inject.Module; import com.google.inject.Module;
/** /**
@ -41,7 +44,8 @@ import com.google.inject.Module;
* @author Adrian Cole * @author Adrian Cole
*/ */
@Test(groups = "live") @Test(groups = "live")
public class BaseStubbedOhaiLiveTest extends BaseChefContextLiveTest { @Deprecated
public class BaseStubbedOhaiLiveTest extends BaseChefContextLiveTest<ChefContext> {
@ConfiguresOhai @ConfiguresOhai
static class TestOhaiModule extends OhaiModule { static class TestOhaiModule extends OhaiModule {
@ -57,4 +61,16 @@ public class BaseStubbedOhaiLiveTest extends BaseChefContextLiveTest {
return new ChefApiMetadata().toBuilder().defaultModules( return new ChefApiMetadata().toBuilder().defaultModules(
ImmutableSet.<Class<? extends Module>> of(ChefRestClientModule.class, ChefParserModule.class, TestOhaiModule.class)).build(); ImmutableSet.<Class<? extends Module>> of(ChefRestClientModule.class, ChefParserModule.class, TestOhaiModule.class)).build();
} }
@Override
protected ChefClient getChefClient(ChefContext context)
{
return context.getApi();
}
@Override
protected TypeToken<ChefContext> contextType()
{
return TypeToken.of(ChefContext.class);
}
} }

View File

@ -18,11 +18,14 @@
*/ */
package org.jclouds.chef.strategy.internal; package org.jclouds.chef.strategy.internal;
import org.jclouds.chef.ChefClient;
import org.jclouds.chef.ChefContext;
import org.jclouds.chef.internal.BaseChefContextLiveTest; import org.jclouds.chef.internal.BaseChefContextLiveTest;
import org.testng.annotations.BeforeClass; import org.testng.annotations.BeforeClass;
import org.testng.annotations.Test; import org.testng.annotations.Test;
import com.google.common.collect.ImmutableSet; import com.google.common.collect.ImmutableSet;
import com.google.common.reflect.TypeToken;
/** /**
* Tests behavior of {@code CleanupStaleNodesAndClientsImpl} strategies * Tests behavior of {@code CleanupStaleNodesAndClientsImpl} strategies
@ -30,7 +33,7 @@ import com.google.common.collect.ImmutableSet;
* @author Adrian Cole * @author Adrian Cole
*/ */
@Test(groups = "live", testName = "CleanupStaleNodesAndClientsImplLiveTest") @Test(groups = "live", testName = "CleanupStaleNodesAndClientsImplLiveTest")
public class CleanupStaleNodesAndClientsImplLiveTest extends BaseChefContextLiveTest { public class CleanupStaleNodesAndClientsImplLiveTest extends BaseChefContextLiveTest<ChefContext> {
private CreateNodeAndPopulateAutomaticAttributesImpl creater; private CreateNodeAndPopulateAutomaticAttributesImpl creater;
private CleanupStaleNodesAndClientsImpl strategy; private CleanupStaleNodesAndClientsImpl strategy;
@ -60,4 +63,16 @@ public class CleanupStaleNodesAndClientsImplLiveTest extends BaseChefContextLive
} }
} }
@Override
protected ChefClient getChefClient(ChefContext context)
{
return context.getApi();
}
@Override
protected TypeToken<ChefContext> contextType()
{
return TypeToken.of(ChefContext.class);
}
} }

View File

@ -22,6 +22,8 @@ import static org.testng.Assert.assertEquals;
import java.util.Set; import java.util.Set;
import org.jclouds.chef.ChefClient;
import org.jclouds.chef.ChefContext;
import org.jclouds.chef.domain.Node; import org.jclouds.chef.domain.Node;
import org.jclouds.chef.internal.BaseChefContextLiveTest; import org.jclouds.chef.internal.BaseChefContextLiveTest;
import org.jclouds.ohai.config.OhaiModule.CurrentUserProvider; import org.jclouds.ohai.config.OhaiModule.CurrentUserProvider;
@ -29,6 +31,7 @@ import org.testng.annotations.BeforeClass;
import org.testng.annotations.Test; import org.testng.annotations.Test;
import com.google.common.collect.ImmutableSet; import com.google.common.collect.ImmutableSet;
import com.google.common.reflect.TypeToken;
/** /**
* Tests behavior of {@code CreateNodeAndPopulateAutomaticAttributesImpl} strategies * Tests behavior of {@code CreateNodeAndPopulateAutomaticAttributesImpl} strategies
@ -36,7 +39,7 @@ import com.google.common.collect.ImmutableSet;
* @author Adrian Cole * @author Adrian Cole
*/ */
@Test(groups = "live", testName = "CreateNodeAndPopulateAutomaticAttributesImplLiveTest") @Test(groups = "live", testName = "CreateNodeAndPopulateAutomaticAttributesImplLiveTest")
public class CreateNodeAndPopulateAutomaticAttributesImplLiveTest extends BaseChefContextLiveTest { public class CreateNodeAndPopulateAutomaticAttributesImplLiveTest extends BaseChefContextLiveTest<ChefContext> {
private CurrentUserProvider currentUserProvider; private CurrentUserProvider currentUserProvider;
@ -62,4 +65,16 @@ public class CreateNodeAndPopulateAutomaticAttributesImplLiveTest extends BaseCh
} }
} }
@Override
protected ChefClient getChefClient(ChefContext context)
{
return context.getApi();
}
@Override
protected TypeToken<ChefContext> contextType()
{
return TypeToken.of(ChefContext.class);
}
} }

View File

@ -19,11 +19,13 @@
package org.jclouds.chef.strategy.internal; package org.jclouds.chef.strategy.internal;
import org.jclouds.chef.ChefClient; import org.jclouds.chef.ChefClient;
import org.jclouds.chef.ChefContext;
import org.jclouds.chef.internal.BaseChefContextLiveTest; import org.jclouds.chef.internal.BaseChefContextLiveTest;
import org.testng.annotations.BeforeClass; import org.testng.annotations.BeforeClass;
import org.testng.annotations.Test; import org.testng.annotations.Test;
import com.google.common.collect.ImmutableSet; import com.google.common.collect.ImmutableSet;
import com.google.common.reflect.TypeToken;
/** /**
* Tests behavior of {@code DeleteAllClientsAndNodesInListImpl} strategies * Tests behavior of {@code DeleteAllClientsAndNodesInListImpl} strategies
@ -31,7 +33,7 @@ import com.google.common.collect.ImmutableSet;
* @author Adrian Cole * @author Adrian Cole
*/ */
@Test(groups = "live", testName = "DeleteAllClientsAndNodesInListImplLiveTest") @Test(groups = "live", testName = "DeleteAllClientsAndNodesInListImplLiveTest")
public class DeleteAllClientsAndNodesInListImplLiveTest extends BaseChefContextLiveTest { public class DeleteAllClientsAndNodesInListImplLiveTest extends BaseChefContextLiveTest<ChefContext> {
private DeleteAllNodesInListImpl strategy; private DeleteAllNodesInListImpl strategy;
private CreateNodeAndPopulateAutomaticAttributesImpl creater; private CreateNodeAndPopulateAutomaticAttributesImpl creater;
@ -65,4 +67,16 @@ public class DeleteAllClientsAndNodesInListImplLiveTest extends BaseChefContextL
chef.deleteNode(prefix + 1); chef.deleteNode(prefix + 1);
} }
} }
@Override
protected ChefClient getChefClient(ChefContext context)
{
return context.getApi();
}
@Override
protected TypeToken<ChefContext> contextType()
{
return TypeToken.of(ChefContext.class);
}
} }

View File

@ -22,6 +22,7 @@ import static com.google.common.collect.Iterables.size;
import static org.testng.Assert.assertEquals; import static org.testng.Assert.assertEquals;
import org.jclouds.chef.ChefClient; import org.jclouds.chef.ChefClient;
import org.jclouds.chef.ChefContext;
import org.jclouds.chef.internal.BaseChefContextLiveTest; import org.jclouds.chef.internal.BaseChefContextLiveTest;
import org.testng.annotations.AfterClass; import org.testng.annotations.AfterClass;
import org.testng.annotations.BeforeClass; import org.testng.annotations.BeforeClass;
@ -29,6 +30,7 @@ import org.testng.annotations.Test;
import com.google.common.base.Predicate; import com.google.common.base.Predicate;
import com.google.common.collect.ImmutableSet; import com.google.common.collect.ImmutableSet;
import com.google.common.reflect.TypeToken;
/** /**
* Tests behavior of {@code GetNodesImpl} strategies * Tests behavior of {@code GetNodesImpl} strategies
@ -36,7 +38,7 @@ import com.google.common.collect.ImmutableSet;
* @author Adrian Cole * @author Adrian Cole
*/ */
@Test(groups = "live", testName = "GetNodesImplLiveTest") @Test(groups = "live", testName = "GetNodesImplLiveTest")
public class GetNodesImplLiveTest extends BaseChefContextLiveTest { public class GetNodesImplLiveTest extends BaseChefContextLiveTest<ChefContext> {
private ListNodesImpl strategy; private ListNodesImpl strategy;
private CreateNodeAndPopulateAutomaticAttributesImpl creater; private CreateNodeAndPopulateAutomaticAttributesImpl creater;
@ -83,4 +85,16 @@ public class GetNodesImplLiveTest extends BaseChefContextLiveTest {
assertEquals(size(strategy.execute(ImmutableSet.of(prefix, prefix + 1))), 2); assertEquals(size(strategy.execute(ImmutableSet.of(prefix, prefix + 1))), 2);
} }
@Override
protected ChefClient getChefClient(ChefContext context)
{
return context.getApi();
}
@Override
protected TypeToken<ChefContext> contextType()
{
return TypeToken.of(ChefContext.class);
}
} }

View File

@ -22,6 +22,8 @@ import static org.testng.Assert.assertEquals;
import java.util.Set; import java.util.Set;
import org.jclouds.chef.ChefClient;
import org.jclouds.chef.ChefContext;
import org.jclouds.chef.domain.Node; import org.jclouds.chef.domain.Node;
import org.jclouds.chef.internal.BaseChefContextLiveTest; import org.jclouds.chef.internal.BaseChefContextLiveTest;
import org.jclouds.ohai.config.OhaiModule.CurrentUserProvider; import org.jclouds.ohai.config.OhaiModule.CurrentUserProvider;
@ -29,6 +31,7 @@ import org.testng.annotations.BeforeClass;
import org.testng.annotations.Test; import org.testng.annotations.Test;
import com.google.common.collect.ImmutableSet; import com.google.common.collect.ImmutableSet;
import com.google.common.reflect.TypeToken;
/** /**
* Tests behavior of {@code UpdateAutomaticAttributesOnNodeImpl} strategies * Tests behavior of {@code UpdateAutomaticAttributesOnNodeImpl} strategies
@ -36,7 +39,7 @@ import com.google.common.collect.ImmutableSet;
* @author Adrian Cole * @author Adrian Cole
*/ */
@Test(groups = "live", testName = "UpdateAutomaticAttributesOnNodeImplLiveTest") @Test(groups = "live", testName = "UpdateAutomaticAttributesOnNodeImplLiveTest")
public class UpdateAutomaticAttributesOnNodeImplLiveTest extends BaseChefContextLiveTest { public class UpdateAutomaticAttributesOnNodeImplLiveTest extends BaseChefContextLiveTest<ChefContext> {
private CurrentUserProvider currentUserProvider; private CurrentUserProvider currentUserProvider;
@ -60,4 +63,16 @@ public class UpdateAutomaticAttributesOnNodeImplLiveTest extends BaseChefContext
context.getApi().deleteNode(prefix); context.getApi().deleteNode(prefix);
} }
} }
@Override
protected ChefClient getChefClient(ChefContext context)
{
return context.getApi();
}
@Override
protected TypeToken<ChefContext> contextType()
{
return TypeToken.of(ChefContext.class);
}
} }

View File

@ -23,12 +23,15 @@ import static org.testng.Assert.assertNotNull;
import java.util.Properties; import java.util.Properties;
import org.jclouds.chef.ChefClient;
import org.jclouds.chef.ChefContext;
import org.jclouds.chef.domain.DatabagItem; import org.jclouds.chef.domain.DatabagItem;
import org.jclouds.chef.internal.BaseChefContextLiveTest; import org.jclouds.chef.internal.BaseChefContextLiveTest;
import org.testng.annotations.AfterClass; import org.testng.annotations.AfterClass;
import org.testng.annotations.Test; import org.testng.annotations.Test;
import com.google.common.io.Closeables; import com.google.common.io.Closeables;
import com.google.common.reflect.TypeToken;
/** /**
* Tests behavior of {@code TransientChefClient} * Tests behavior of {@code TransientChefClient}
@ -36,7 +39,7 @@ import com.google.common.io.Closeables;
* @author Adrian Cole * @author Adrian Cole
*/ */
@Test(groups = { "integration" }) @Test(groups = { "integration" })
public class TransientChefClientIntegrationTest extends BaseChefContextLiveTest { public class TransientChefClientIntegrationTest extends BaseChefContextLiveTest<ChefContext> {
public static final String PREFIX = System.getProperty("user.name") + "-jcloudstest"; public static final String PREFIX = System.getProperty("user.name") + "-jcloudstest";
private DatabagItem databagItem; private DatabagItem databagItem;
@ -88,4 +91,16 @@ public class TransientChefClientIntegrationTest extends BaseChefContextLiveTest
context.getApi().updateDatabagItem(PREFIX, databagItem); context.getApi().updateDatabagItem(PREFIX, databagItem);
} }
} }
@Override
protected ChefClient getChefClient(ChefContext context)
{
return context.getApi();
}
@Override
protected TypeToken<ChefContext> contextType()
{
return TypeToken.of(ChefContext.class);
}
} }