mirror of https://github.com/apache/jclouds.git
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:
parent
05481efd71
commit
20912c9ad4
|
@ -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);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
|
@ -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);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue