mirror of https://github.com/apache/jclouds.git
added state predicates to cloudstack
This commit is contained in:
parent
2bc4babe81
commit
ff1f46ca2c
|
@ -0,0 +1,65 @@
|
|||
/**
|
||||
*
|
||||
* Copyright (C) 2010 Cloud Conscious, LLC. <info@cloudconscious.com>
|
||||
*
|
||||
* ====================================================================
|
||||
* Licensed 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.cloudstack.predicates;
|
||||
|
||||
import static com.google.common.base.Preconditions.checkNotNull;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
import javax.inject.Singleton;
|
||||
|
||||
import org.jclouds.cloudstack.CloudStackClient;
|
||||
import org.jclouds.cloudstack.domain.AsyncJob;
|
||||
import org.jclouds.logging.Logger;
|
||||
|
||||
import com.google.common.base.Predicate;
|
||||
import com.google.inject.Inject;
|
||||
|
||||
/**
|
||||
*
|
||||
* Tests to see if a job is in progress.
|
||||
*
|
||||
* @author Adrian Cole
|
||||
*/
|
||||
@Singleton
|
||||
public class JobComplete implements Predicate<Long> {
|
||||
|
||||
private final CloudStackClient client;
|
||||
|
||||
@Resource
|
||||
protected Logger logger = Logger.NULL;
|
||||
|
||||
@Inject
|
||||
public JobComplete(CloudStackClient client) {
|
||||
this.client = client;
|
||||
}
|
||||
|
||||
public boolean apply(Long jobId) {
|
||||
logger.trace("looking for status on job %s", checkNotNull(jobId, "jobId"));
|
||||
AsyncJob job = refresh(jobId);
|
||||
if (job == null)
|
||||
return false;
|
||||
logger.trace("%s: looking for job status %s: currently: %s", job.getId(), 1, job.getStatus());
|
||||
return job.getStatus() > 0;
|
||||
}
|
||||
|
||||
private AsyncJob refresh(Long jobId) {
|
||||
return client.getAsyncJobClient().getAsyncJob(jobId);
|
||||
}
|
||||
}
|
|
@ -0,0 +1,67 @@
|
|||
/**
|
||||
*
|
||||
* Copyright (C) 2010 Cloud Conscious, LLC. <info@cloudconscious.com>
|
||||
*
|
||||
* ====================================================================
|
||||
* Licensed 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.cloudstack.predicates;
|
||||
|
||||
import static com.google.common.base.Preconditions.checkNotNull;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
import javax.inject.Singleton;
|
||||
|
||||
import org.jclouds.cloudstack.CloudStackClient;
|
||||
import org.jclouds.cloudstack.domain.VirtualMachine;
|
||||
import org.jclouds.cloudstack.domain.VirtualMachine.State;
|
||||
import org.jclouds.logging.Logger;
|
||||
|
||||
import com.google.common.base.Predicate;
|
||||
import com.google.inject.Inject;
|
||||
|
||||
/**
|
||||
*
|
||||
* Tests to see if a virtualMachine is running
|
||||
*
|
||||
* @author Adrian Cole
|
||||
*/
|
||||
@Singleton
|
||||
public class VirtualMachineDestroyed implements Predicate<VirtualMachine> {
|
||||
|
||||
private final CloudStackClient client;
|
||||
|
||||
@Resource
|
||||
protected Logger logger = Logger.NULL;
|
||||
|
||||
@Inject
|
||||
public VirtualMachineDestroyed(CloudStackClient client) {
|
||||
this.client = client;
|
||||
}
|
||||
|
||||
public boolean apply(VirtualMachine virtualMachine) {
|
||||
logger.trace("looking for state on virtualMachine %s", checkNotNull(virtualMachine, "virtualMachine"));
|
||||
virtualMachine = refresh(virtualMachine);
|
||||
if (virtualMachine == null)
|
||||
return true;
|
||||
logger.trace("%s: looking for virtualMachine state %s: currently: %s", virtualMachine.getId(), State.DESTROYED,
|
||||
virtualMachine.getState());
|
||||
return virtualMachine.getState() == State.DESTROYED;
|
||||
}
|
||||
|
||||
private VirtualMachine refresh(VirtualMachine virtualMachine) {
|
||||
return client.getVirtualMachineClient().getVirtualMachine(virtualMachine.getId());
|
||||
}
|
||||
}
|
|
@ -0,0 +1,69 @@
|
|||
/**
|
||||
*
|
||||
* Copyright (C) 2010 Cloud Conscious, LLC. <info@cloudconscious.com>
|
||||
*
|
||||
* ====================================================================
|
||||
* Licensed 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.cloudstack.predicates;
|
||||
|
||||
import static com.google.common.base.Preconditions.checkNotNull;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
import javax.inject.Singleton;
|
||||
|
||||
import org.jclouds.cloudstack.CloudStackClient;
|
||||
import org.jclouds.cloudstack.domain.VirtualMachine;
|
||||
import org.jclouds.cloudstack.domain.VirtualMachine.State;
|
||||
import org.jclouds.logging.Logger;
|
||||
|
||||
import com.google.common.base.Predicate;
|
||||
import com.google.inject.Inject;
|
||||
|
||||
/**
|
||||
*
|
||||
* Tests to see if a virtualMachine is running
|
||||
*
|
||||
* @author Adrian Cole
|
||||
*/
|
||||
@Singleton
|
||||
public class VirtualMachineRunning implements Predicate<VirtualMachine> {
|
||||
|
||||
private final CloudStackClient client;
|
||||
|
||||
@Resource
|
||||
protected Logger logger = Logger.NULL;
|
||||
|
||||
@Inject
|
||||
public VirtualMachineRunning(CloudStackClient client) {
|
||||
this.client = client;
|
||||
}
|
||||
|
||||
public boolean apply(VirtualMachine virtualMachine) {
|
||||
logger.trace("looking for state on virtualMachine %s", checkNotNull(virtualMachine, "virtualMachine"));
|
||||
virtualMachine = refresh(virtualMachine);
|
||||
if (virtualMachine == null)
|
||||
return false;
|
||||
logger.trace("%s: looking for virtualMachine state %s: currently: %s", virtualMachine.getId(), State.RUNNING,
|
||||
virtualMachine.getState());
|
||||
if (virtualMachine.getState() == State.ERROR)
|
||||
throw new IllegalStateException("virtualMachine in error state: " + virtualMachine);
|
||||
return virtualMachine.getState() == State.RUNNING;
|
||||
}
|
||||
|
||||
private VirtualMachine refresh(VirtualMachine virtualMachine) {
|
||||
return client.getVirtualMachineClient().getVirtualMachine(virtualMachine.getId());
|
||||
}
|
||||
}
|
|
@ -19,8 +19,6 @@
|
|||
|
||||
package org.jclouds.cloudstack.features;
|
||||
|
||||
import static com.google.common.base.Predicates.equalTo;
|
||||
import static com.google.common.base.Predicates.or;
|
||||
import static com.google.common.collect.Iterables.find;
|
||||
import static com.google.common.collect.Iterables.get;
|
||||
import static com.google.common.collect.Iterables.getOnlyElement;
|
||||
|
@ -28,19 +26,26 @@ import static org.testng.Assert.assertEquals;
|
|||
import static org.testng.Assert.assertTrue;
|
||||
|
||||
import java.util.Set;
|
||||
import java.util.concurrent.TimeUnit;
|
||||
|
||||
import org.jclouds.cloudstack.domain.AsyncCreateResponse;
|
||||
import org.jclouds.cloudstack.domain.GuestIPType;
|
||||
import org.jclouds.cloudstack.domain.NIC;
|
||||
import org.jclouds.cloudstack.domain.Network;
|
||||
import org.jclouds.cloudstack.domain.NetworkType;
|
||||
import org.jclouds.cloudstack.domain.SecurityGroup;
|
||||
import org.jclouds.cloudstack.domain.ServiceOffering;
|
||||
import org.jclouds.cloudstack.domain.Template;
|
||||
import org.jclouds.cloudstack.domain.VirtualMachine;
|
||||
import org.jclouds.cloudstack.domain.Zone;
|
||||
import org.jclouds.cloudstack.options.DeployVirtualMachineOptions;
|
||||
import org.jclouds.cloudstack.options.ListVirtualMachinesOptions;
|
||||
import org.jclouds.cloudstack.predicates.JobComplete;
|
||||
import org.jclouds.cloudstack.predicates.VirtualMachineDestroyed;
|
||||
import org.jclouds.cloudstack.predicates.VirtualMachineRunning;
|
||||
import org.jclouds.predicates.RetryablePredicate;
|
||||
import org.testng.annotations.AfterGroups;
|
||||
import org.testng.annotations.BeforeGroups;
|
||||
import org.testng.annotations.Test;
|
||||
|
||||
import com.google.common.base.Predicate;
|
||||
|
@ -54,12 +59,25 @@ import com.google.common.collect.Ordering;
|
|||
*/
|
||||
@Test(groups = "live", sequential = true, testName = "VirtualMachineClientLiveTest")
|
||||
public class VirtualMachineClientLiveTest extends BaseCloudStackClientLiveTest {
|
||||
VirtualMachine vm = null;
|
||||
private VirtualMachine vm = null;
|
||||
private RetryablePredicate<Long> jobComplete;
|
||||
private RetryablePredicate<VirtualMachine> virtualMachineRunning;
|
||||
private RetryablePredicate<VirtualMachine> virtualMachineDestroyed;
|
||||
|
||||
@BeforeGroups(groups = "live")
|
||||
public void setupClient() {
|
||||
super.setupClient();
|
||||
jobComplete = new RetryablePredicate<Long>(new JobComplete(client), 600, 5, TimeUnit.SECONDS);
|
||||
virtualMachineRunning = new RetryablePredicate<VirtualMachine>(new VirtualMachineRunning(client), 600, 5,
|
||||
TimeUnit.SECONDS);
|
||||
virtualMachineDestroyed = new RetryablePredicate<VirtualMachine>(new VirtualMachineDestroyed(client), 600, 5,
|
||||
TimeUnit.SECONDS);
|
||||
}
|
||||
|
||||
static final Ordering<ServiceOffering> DEFAULT_SIZE_ORDERING = new Ordering<ServiceOffering>() {
|
||||
public int compare(ServiceOffering left, ServiceOffering right) {
|
||||
return ComparisonChain.start().compare(left.getCpuNumber(), right.getCpuNumber())
|
||||
.compare(left.getMemory(), right.getMemory()).result();
|
||||
return ComparisonChain.start().compare(left.getCpuNumber(), right.getCpuNumber()).compare(left.getMemory(),
|
||||
right.getMemory()).result();
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -78,7 +96,7 @@ public class VirtualMachineClientLiveTest extends BaseCloudStackClientLiveTest {
|
|||
}).getId();
|
||||
|
||||
DeployVirtualMachineOptions options = new DeployVirtualMachineOptions();
|
||||
if (zone.getNetworkType() == NetworkType.ADVANCED)
|
||||
if (zone.getNetworkType() == NetworkType.ADVANCED) {
|
||||
options.networkId(find(client.getNetworkClient().listNetworks(), new Predicate<Network>() {
|
||||
|
||||
@Override
|
||||
|
@ -87,36 +105,44 @@ public class VirtualMachineClientLiveTest extends BaseCloudStackClientLiveTest {
|
|||
}
|
||||
|
||||
}).getId());
|
||||
} else {
|
||||
options.securityGroupId(find(client.getSecurityGroupClient().listSecurityGroups(),
|
||||
new Predicate<SecurityGroup>() {
|
||||
|
||||
@Override
|
||||
public boolean apply(SecurityGroup arg0) {
|
||||
return arg0.getName().equals("default");
|
||||
}
|
||||
|
||||
}).getId());
|
||||
}
|
||||
System.out.printf("serviceOfferingId %d, templateId %d, zoneId %d, options %s%n", serviceOfferingId, templateId,
|
||||
zone.getId(), options);
|
||||
AsyncCreateResponse job = client.getVirtualMachineClient().deployVirtualMachine(serviceOfferingId, templateId,
|
||||
zone.getId(), options);
|
||||
assert jobComplete.apply(job.getJobId());
|
||||
vm = client.getVirtualMachineClient().getVirtualMachine(job.getId());
|
||||
assert virtualMachineRunning.apply(vm);
|
||||
assertEquals(vm.getServiceOfferingId(), serviceOfferingId);
|
||||
assertEquals(vm.getTemplateId(), templateId);
|
||||
assertEquals(vm.getZoneId(), zone.getId());
|
||||
assert or(equalTo("NetworkFilesystem"), equalTo("Not created")).apply(vm.getRootDeviceType()) : vm;
|
||||
assertEquals(vm.getRootDeviceType(), "NetworkFilesystem");
|
||||
checkVm(vm);
|
||||
|
||||
}
|
||||
|
||||
@AfterGroups(groups = "live")
|
||||
protected void tearDown() {
|
||||
if (vm != null) {
|
||||
try {
|
||||
Long job = client.getVirtualMachineClient().destroyVirtualMachine(vm.getId());
|
||||
assert job != null;
|
||||
assertEquals(client.getVirtualMachineClient().getVirtualMachine(vm.getId()), null);
|
||||
} catch (AssertionError e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
assert jobComplete.apply(job);
|
||||
assert virtualMachineDestroyed.apply(vm);
|
||||
}
|
||||
super.tearDown();
|
||||
}
|
||||
|
||||
public void testListVirtualMachines() throws Exception {
|
||||
Set<VirtualMachine> response = client.getVirtualMachineClient().listVirtualMachines();
|
||||
System.out.println(response);
|
||||
assert null != response;
|
||||
assertTrue(response.size() >= 0);
|
||||
for (VirtualMachine vm : response) {
|
||||
|
|
|
@ -59,20 +59,16 @@ public class ListSecurityGroupsResponseTest {
|
|||
public void test() {
|
||||
InputStream is = getClass().getResourceAsStream("/listsecuritygroupsresponse.json");
|
||||
|
||||
Set<SecurityGroup> expects = ImmutableSet.<SecurityGroup> of(
|
||||
SecurityGroup
|
||||
.builder()
|
||||
.id(3)
|
||||
.name("default")
|
||||
.description("Default Security Group")
|
||||
.account("adrian")
|
||||
.domainId(1)
|
||||
.domain("ROOT")
|
||||
.ingressRules(
|
||||
ImmutableSet.of(
|
||||
IngressRule.builder().id(8).protocol("tcp").startPort(22).endPort(22).CIDR("0.0.0.0/32")
|
||||
.build(), IngressRule.builder().id(9).protocol("icmp").ICMPType(-1).ICMPCode(-1)
|
||||
.securityGroupName("default").account("adrian").build())).build(),
|
||||
Set<SecurityGroup> expects = ImmutableSet.<SecurityGroup> of(SecurityGroup.builder().id(3).name("default")
|
||||
.description("Default Security Group").account("adrian").domainId(1).domain("ROOT").ingressRules(
|
||||
ImmutableSet.of(IngressRule.builder().id(8).protocol("tcp").startPort(22).endPort(22).CIDR(
|
||||
"0.0.0.0/32").build(),
|
||||
|
||||
IngressRule.builder().id(9).protocol("icmp").ICMPType(-1).ICMPCode(-1).securityGroupName(
|
||||
"default").account("adrian").build(),
|
||||
|
||||
IngressRule.builder().id(10).protocol("tcp").startPort(80).endPort(80).securityGroupName(
|
||||
"default").account("adrian").build())).build(),
|
||||
|
||||
SecurityGroup.builder().id(15).name("adriancole").account("adrian").domainId(1).domain("ROOT").build());
|
||||
|
||||
|
|
|
@ -1 +1 @@
|
|||
{ "listsecuritygroupsresponse" : { "securitygroup" : [ {"id":3,"name":"default","description":"Default Security Group","account":"adrian","domainid":1,"domain":"ROOT","ingressrule":[{"ruleid":8,"protocol":"tcp","startport":22,"endport":22,"cidr":"0.0.0.0/32"},{"ruleid":9,"protocol":"icmp","icmptype":-1,"icmpcode":-1,"securitygroupname":"default","account":"adrian"}]}, {"id":15,"name":"adriancole","account":"adrian","domainid":1,"domain":"ROOT"} ] } }
|
||||
{ "listsecuritygroupsresponse" : { "securitygroup" : [ {"id":3,"name":"default","description":"Default Security Group","account":"adrian","domainid":1,"domain":"ROOT","ingressrule":[{"ruleid":8,"protocol":"tcp","startport":22,"endport":22,"cidr":"0.0.0.0/32"},{"ruleid":9,"protocol":"icmp","icmptype":-1,"icmpcode":-1,"securitygroupname":"default","account":"adrian"},{"ruleid":10,"protocol":"tcp","startport":80,"endport":80,"securitygroupname":"default","account":"adrian"}]}, {"id":15,"name":"adriancole","account":"adrian","domainid":1,"domain":"ROOT"} ] } }
|
Loading…
Reference in New Issue