Merge branch 'master' into cloudstack-template-live-test

Conflicts:
	apis/cloudstack/src/test/java/org/jclouds/cloudstack/features/TemplateClientLiveTest.java
This commit is contained in:
Richard Downer 2011-12-02 19:51:02 +02:00
commit 9939237c6b
84 changed files with 1468 additions and 1925 deletions

View File

@ -48,6 +48,18 @@ public class BindTemplateMetadataToQueryParams implements Binder {
request = ModifyRequest.addQueryParam(request, "name", metadata.getName(), uriBuilderProvider.get()); request = ModifyRequest.addQueryParam(request, "name", metadata.getName(), uriBuilderProvider.get());
request = ModifyRequest.addQueryParam(request, "ostypeid", metadata.getOsTypeId(), uriBuilderProvider.get()); request = ModifyRequest.addQueryParam(request, "ostypeid", metadata.getOsTypeId(), uriBuilderProvider.get());
request = ModifyRequest.addQueryParam(request, "displaytext", metadata.getDisplayText(), uriBuilderProvider.get()); request = ModifyRequest.addQueryParam(request, "displaytext", metadata.getDisplayText(), uriBuilderProvider.get());
if (metadata.getSnapshotId() != null) {
request = ModifyRequest.addQueryParam(request, "snapshotid", metadata.getSnapshotId(), uriBuilderProvider.get());
}
if (metadata.getVolumeId() != null) {
request = ModifyRequest.addQueryParam(request, "volumeid", metadata.getVolumeId(), uriBuilderProvider.get());
}
if (metadata.getVirtualMachineId() != null) {
request = ModifyRequest.addQueryParam(request, "virtualmachineid", metadata.getVirtualMachineId(), uriBuilderProvider.get());
}
if (metadata.getPasswordEnabled() != null) {
request = ModifyRequest.addQueryParam(request, "passwordenabled", metadata.getPasswordEnabled(), uriBuilderProvider.get());
}
return request; return request;
} }
} }

View File

@ -0,0 +1,73 @@
package org.jclouds.cloudstack.domain;
import com.google.gson.annotations.SerializedName;
/**
* The result of an operation.
*
* A handful of Cloudstack API calls return this structure when there is no domain model data to return - for example,
* when deleting an object.
*
* @author Richard Downer
*/
public class JobResult implements Comparable<JobResult> {
private boolean success;
@SerializedName("displaytext")
private String displayText;
/**
* present only for the serializer
*/
JobResult() {
}
public JobResult(boolean success, String displayText) {
this.success = success;
this.displayText = displayText;
}
public boolean getSuccess() {
return success;
}
public String getDisplayText() {
return displayText;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
JobResult that = (JobResult) o;
if (success != that.success) return false;
if (displayText != null ? !displayText.equals(that.displayText) : that.displayText != null) return false;
return true;
}
@Override
public int hashCode() {
int result = (success ? 1 : 0);
result = 31 * result + (displayText != null ? displayText.hashCode() : 0);
return result;
}
@Override
public String toString() {
return "[" +
"success=" + success +
", displayText=" + (displayText != null ? '\'' + displayText + '\'' : "null") +
']';
}
@Override
public int compareTo(JobResult other) {
int comparison = Boolean.valueOf(success).compareTo(other.success);
if (comparison == 0)
comparison = displayText.compareTo(other.displayText);
return comparison;
}
}

View File

@ -18,11 +18,13 @@
*/ */
package org.jclouds.cloudstack.domain; package org.jclouds.cloudstack.domain;
import com.google.gson.annotations.SerializedName; import static com.google.common.base.Preconditions.checkNotNull;
import java.util.Date; import java.util.Date;
import static com.google.common.base.Preconditions.checkNotNull; import com.google.common.base.CaseFormat;
import com.google.common.base.Objects;
import com.google.gson.annotations.SerializedName;
/** /**
* @author Richard Downer * @author Richard Downer
@ -48,7 +50,7 @@ public class Snapshot implements Comparable<Snapshot> {
private State state; private State state;
private long volumeId; private long volumeId;
private String volumeName; private String volumeName;
private String volumeType; private Volume.VolumeType volumeType;
/** /**
* @param id ID of the snapshot * @param id ID of the snapshot
@ -157,27 +159,37 @@ public class Snapshot implements Comparable<Snapshot> {
/** /**
* @param volumeType type of the disk volume * @param volumeType type of the disk volume
*/ */
public Builder volumeType(String volumeType) { public Builder volumeType(Volume.VolumeType volumeType) {
this.volumeType = volumeType; this.volumeType = volumeType;
return this; return this;
} }
public Snapshot build() {
return new Snapshot(id, account, created, domain, domainId, interval, jobId,
jobStatus, name, snapshotType, state, volumeId, volumeName, volumeType);
}
} }
public static enum State { public enum State {
BackedUp, Creating, BackingUp, UNRECOGNIZED; BACKED_UP, CREATING, BACKING_UP, UNRECOGNIZED;
public static State fromValue(String type) { @Override
public String toString() {
return CaseFormat.UPPER_UNDERSCORE.to(CaseFormat.UPPER_CAMEL, name());
}
public static State fromValue(String state) {
try { try {
return valueOf(checkNotNull(type, "type")); return valueOf(CaseFormat.UPPER_CAMEL.to(CaseFormat.UPPER_UNDERSCORE, checkNotNull(state, "state")));
} catch (IllegalArgumentException e) { } catch (IllegalArgumentException e) {
return UNRECOGNIZED; return UNRECOGNIZED;
} }
} }
} }
public static enum Type { public enum Type {
MANUAL, RECURRING, UNRECOGNIZED; MANUAL, RECURRING, UNRECOGNIZED;
@ -190,7 +202,7 @@ public class Snapshot implements Comparable<Snapshot> {
} }
} }
public static enum Interval { public enum Interval {
HOURLY, DAILY, WEEKLY, MONTHLY, template, none, UNRECOGNIZED; HOURLY, DAILY, WEEKLY, MONTHLY, template, none, UNRECOGNIZED;
@ -224,7 +236,25 @@ public class Snapshot implements Comparable<Snapshot> {
@SerializedName("volumename") @SerializedName("volumename")
private String volumeName; private String volumeName;
@SerializedName("volumetype") @SerializedName("volumetype")
private String volumeType; // FIXME: replace this with a proper enumerated type (blocked until volume API implemented) private Volume.VolumeType volumeType;
public Snapshot(long id, String account, Date created, String domain, long domainId, Interval interval, long jobId,
String jobStatus, String name, Type snapshotType, State state, long volumeId, String volumeName, Volume.VolumeType volumeType) {
this.id = id;
this.account = account;
this.created = created;
this.domain = domain;
this.domainId = domainId;
this.interval = interval;
this.jobId = jobId;
this.jobStatus = jobStatus;
this.name = name;
this.snapshotType = snapshotType;
this.state = state;
this.volumeId = volumeId;
this.volumeName = volumeName;
this.volumeType = volumeType;
}
/** /**
* present only for serializer * present only for serializer
@ -326,7 +356,7 @@ public class Snapshot implements Comparable<Snapshot> {
/** /**
* @return type of the disk volume * @return type of the disk volume
*/ */
public String getVolumeType() { public Volume.VolumeType getVolumeType() {
return volumeType; return volumeType;
} }
@ -335,22 +365,22 @@ public class Snapshot implements Comparable<Snapshot> {
if (this == o) return true; if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false; if (o == null || getClass() != o.getClass()) return false;
Snapshot snapshot = (Snapshot) o; Snapshot that = (Snapshot) o;
if (domainId != snapshot.domainId) return false; if (!Objects.equal(domainId, that.domainId)) return false;
if (id != snapshot.id) return false; if (!Objects.equal(id, that.id)) return false;
if (jobId != snapshot.jobId) return false; if (!Objects.equal(jobId, that.jobId)) return false;
if (volumeId != snapshot.volumeId) return false; if (!Objects.equal(volumeId, that.volumeId)) return false;
if (account != null ? !account.equals(snapshot.account) : snapshot.account != null) return false; if (!Objects.equal(account, that.account)) return false;
if (created != null ? !created.equals(snapshot.created) : snapshot.created != null) return false; if (!Objects.equal(created, that.created)) return false;
if (domain != null ? !domain.equals(snapshot.domain) : snapshot.domain != null) return false; if (!Objects.equal(domain, that.domain)) return false;
if (interval != snapshot.interval) return false; if (!Objects.equal(interval, that.interval)) return false;
if (jobStatus != null ? !jobStatus.equals(snapshot.jobStatus) : snapshot.jobStatus != null) return false; if (!Objects.equal(jobStatus, that.jobStatus)) return false;
if (name != null ? !name.equals(snapshot.name) : snapshot.name != null) return false; if (!Objects.equal(name, that.name)) return false;
if (snapshotType != snapshot.snapshotType) return false; if (!Objects.equal(snapshotType, that.snapshotType)) return false;
if (state != snapshot.state) return false; if (!Objects.equal(state, that.state)) return false;
if (volumeName != null ? !volumeName.equals(snapshot.volumeName) : snapshot.volumeName != null) return false; if (!Objects.equal(volumeName, that.volumeName)) return false;
if (volumeType != null ? !volumeType.equals(snapshot.volumeType) : snapshot.volumeType != null) return false; if (!Objects.equal(volumeType, that.volumeType)) return false;
return true; return true;
} }
@ -377,21 +407,21 @@ public class Snapshot implements Comparable<Snapshot> {
@Override @Override
public String toString() { public String toString() {
return "Snapshot[" + return "Snapshot[" +
"id=" + id + "id=" + id +
", account='" + account + '\'' + ", account='" + account + '\'' +
", created=" + created + ", created=" + created +
", domain='" + domain + '\'' + ", domain='" + domain + '\'' +
", domainId=" + domainId + ", domainId=" + domainId +
", interval=" + interval + ", interval=" + interval +
", jobId=" + jobId + ", jobId=" + jobId +
", jobStatus='" + jobStatus + '\'' + ", jobStatus='" + jobStatus + '\'' +
", name='" + name + '\'' + ", name='" + name + '\'' +
", snapshotType=" + snapshotType + ", snapshotType=" + snapshotType +
", state=" + state + ", state=" + state +
", volumeId=" + volumeId + ", volumeId=" + volumeId +
", volumeName='" + volumeName + '\'' + ", volumeName='" + volumeName + '\'' +
", volumeType='" + volumeType + '\'' + ", volumeType='" + volumeType + '\'' +
']'; ']';
} }
@Override @Override

View File

@ -86,6 +86,9 @@ public class SnapshotPolicy implements Comparable<SnapshotPolicy> {
return this; return this;
} }
public SnapshotPolicy build() {
return new SnapshotPolicy(id, interval, numberToRetain, schedule, timezone, volumeId);
}
} }
private long id; private long id;
@ -98,6 +101,15 @@ public class SnapshotPolicy implements Comparable<SnapshotPolicy> {
@SerializedName("volumeid") @SerializedName("volumeid")
private long volumeId; private long volumeId;
public SnapshotPolicy(long id, Snapshot.Interval interval, long numberToRetain, String schedule, String timezone, long volumeId) {
this.id = id;
this.interval = interval;
this.numberToRetain = numberToRetain;
this.schedule = schedule;
this.timezone = timezone;
this.volumeId = volumeId;
}
/** /**
* present only for serializer * present only for serializer
*/ */

View File

@ -211,6 +211,7 @@ public class Template implements Comparable<Template> {
USER, BUILTIN, UNRECOGNIZED; USER, BUILTIN, UNRECOGNIZED;
//TODO do we need camel case routines (e.g. see enums in VirtualMachine) ?
public static Type fromValue(String type) { public static Type fromValue(String type) {
try { try {
return valueOf(checkNotNull(type, "type")); return valueOf(checkNotNull(type, "type"));

View File

@ -18,116 +18,211 @@
*/ */
package org.jclouds.cloudstack.domain; package org.jclouds.cloudstack.domain;
import com.google.common.base.Objects;
/** /**
* @author Richard Downer * @author Richard Downer
*/ */
public class TemplateMetadata { public class TemplateMetadata {
public static Builder builder() { public static Builder builder() {
return new Builder(); return new Builder();
} }
public static class Builder { public static class Builder {
private String name;
private long osTypeId;
private String displayText;
private Long snapshotId;
private Long volumeId;
private Long virtualMachineId;
private Boolean passwordEnabled;
private String name; /**
private long osTypeId; * @param name
private String displayText; * the name of the template
*/
public Builder name(String name) {
this.name = name;
return this;
}
/** /**
* @param name the name of the template * @param osTypeId
*/ * the ID of the OS Type that best represents the OS of this template.
public Builder name(String name) { */
this.name = name; public Builder osTypeId(long osTypeId) {
return this; this.osTypeId = osTypeId;
} return this;
}
/** /**
* @param osTypeId the ID of the OS Type that best represents the OS of this template. * @param displayText
*/ * the display text of the template. This is usually used for display purposes.
public Builder osTypeId(long osTypeId) { */
this.osTypeId = osTypeId; public Builder displayText(String displayText) {
return this; this.displayText = displayText;
} return this;
}
/** /**
* @param displayText the display text of the template. This is usually used for display purposes. * @param snapshotId
*/ * the ID of the snapshot the template is being created from.
public Builder displayText(String displayText) { * Either this parameter, or volumeId has to be passed in
this.displayText = displayText; */
return this; public Builder snapshotId(Long snapshotId) {
} this.snapshotId = snapshotId;
return this;
}
public TemplateMetadata build() { /**
return new TemplateMetadata(name, osTypeId, displayText); * @param volumeId
} * the ID of the disk volume the template is being created from.
} * Either this parameter, or snapshotId has to be passed in
*/
public Builder volumeId(Long volumeId) {
this.volumeId = volumeId;
return this;
}
private String name; /**
private long osTypeId; * @param virtualMachineId
private String displayText; * the ID of the disk volume the template is being created from
*/
public Builder virtualMachineId(Long virtualMachineId) {
this.virtualMachineId = virtualMachineId;
return this;
}
public TemplateMetadata(String name, long osTypeId, String displayText) { /**
this.name = name; * the template supports the password reset feature.
this.osTypeId = osTypeId; */
this.displayText = displayText; public Builder passwordEnabled() {
} this.passwordEnabled = true;
return this;
}
/** public TemplateMetadata build() {
* present only for serializer TemplateMetadata template = new TemplateMetadata(name, osTypeId, displayText);
*/ template.setPasswordEnabled(passwordEnabled);
TemplateMetadata() { template.setSnapshotId(snapshotId);
} template.setVirtualMachineId(virtualMachineId);
template.setVolumeId(volumeId);
return template;
}
}
/** private String name;
* @return the name of the template private long osTypeId;
*/ private String displayText;
public String getName() {
return name;
}
/** private Long snapshotId;
* @return the ID of the OS Type that best represents the OS of this template. private Long volumeId;
*/ private Long virtualMachineId;;
public long getOsTypeId() { private Boolean passwordEnabled;
return osTypeId;
}
/** public TemplateMetadata(String name, long osTypeId, String displayText) {
* @return the display text of the template. This is usually used for display purposes. this.name = name;
*/ this.osTypeId = osTypeId;
public String getDisplayText() { this.displayText = displayText;
return displayText; }
}
@Override /**
public boolean equals(Object o) { * present only for serializer
if (this == o) return true; */
if (o == null || getClass() != o.getClass()) return false; TemplateMetadata() {
}
TemplateMetadata that = (TemplateMetadata) o; /**
* @return the ID of the snapshot the template is being created from
*/
public Long getSnapshotId() {
return snapshotId;
}
if (osTypeId != that.osTypeId) return false; public void setSnapshotId(Long snapshotId) {
if (displayText != null ? !displayText.equals(that.displayText) : that.displayText != null) return false; this.snapshotId = snapshotId;
if (name != null ? !name.equals(that.name) : that.name != null) return false; }
return true; /**
} * @return the ID of the disk volume the template is being created from
*/
public Long getVolumeId() {
return volumeId;
}
@Override public void setVolumeId(Long volumeId) {
public int hashCode() { this.volumeId = volumeId;
int result = name != null ? name.hashCode() : 0; }
result = 31 * result + (int) (osTypeId ^ (osTypeId >>> 32));
result = 31 * result + (displayText != null ? displayText.hashCode() : 0);
return result;
}
@Override /**
public String toString() { * @return Optional, VM ID
return "[" + */
"name='" + name + '\'' + public Long getVirtualMachineId() {
", osTypeId=" + osTypeId + return virtualMachineId;
", displayText='" + displayText + '\'' + }
']';
} public void setVirtualMachineId(Long virtualMachineId) {
this.virtualMachineId = virtualMachineId;
}
/**
* @return true if the template supports the password reset feature; default is false
*/
public Boolean getPasswordEnabled() {
return passwordEnabled;
}
public void setPasswordEnabled(Boolean passwordEnabled) {
this.passwordEnabled = passwordEnabled;
}
/**
* @return the name of the template
*/
public String getName() {
return name;
}
/**
* @return the ID of the OS Type that best represents the OS of this template.
*/
public long getOsTypeId() {
return osTypeId;
}
/**
* @return the display text of the template. This is usually used for display purposes.
*/
public String getDisplayText() {
return displayText;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
TemplateMetadata that = (TemplateMetadata) o;
if (!Objects.equal(osTypeId, that.osTypeId)) return false;
if (!Objects.equal(snapshotId, that.snapshotId)) return false;
if (!Objects.equal(volumeId, that.volumeId)) return false;
if (!Objects.equal(virtualMachineId, that.virtualMachineId)) return false;
if (!Objects.equal(passwordEnabled, that.passwordEnabled)) return false;
if (!Objects.equal(displayText, that.displayText)) return false;
if (!Objects.equal(name, that.name)) return false;
return true;
}
@Override
public int hashCode() {
return Objects.hashCode(name, displayText, osTypeId, snapshotId, volumeId, passwordEnabled, virtualMachineId);
}
@Override
public String toString() {
return "[" + "name='" + name + '\'' + ", osTypeId=" + osTypeId + ", displayText='" + displayText + '\'' + ']';
}
} }

View File

@ -955,18 +955,23 @@ public class VirtualMachine implements Comparable<VirtualMachine> {
@Override @Override
public String toString() { public String toString() {
return "[id=" + id + ", account=" + account + ", cpuCount=" + cpuCount + ", cpuSpeed=" + cpuSpeed + ", cpuUsed=" return "[id=" + id
+ cpuUsed + ", displayName=" + displayName + ", created=" + created + ", domain=" + domain + ", domainId=" // + ", account=" + account + ", cpuCount=" + cpuCount + ", cpuSpeed=" + cpuSpeed + ", cpuUsed=" + cpuUsed
+ domainId + ", usesVirtualNetwork=" + usesVirtualNetwork + ", group=" + group + ", groupId=" + groupId + ", displayName=" + displayName + ", created=" + created
+ ", guestOSId=" + guestOSId + ", HAEnabled=" + HAEnabled + ", hostId=" + hostId + ", hostname=" + hostname // + ", domain=" + domain + ", domainId="
+ ", IPAddress=" + IPAddress + ", ISODisplayText=" + ISODisplayText + ", ISOId=" + ISOId + ", ISOName=" // + domainId + ", usesVirtualNetwork=" + usesVirtualNetwork + ", group=" + group + ", groupId=" + groupId
+ ISOName + ", jobId=" + jobId + ", jobStatus=" + jobStatus + ", memory=" + memory + ", name=" + name // + ", guestOSId=" + guestOSId + ", HAEnabled=" + HAEnabled + ", hostId=" + hostId + ", hostname=" + hostname
+ ", networkKbsRead=" + networkKbsRead + ", networkKbsWrite=" + networkKbsWrite + ", password=" + password + ", IPAddress=" + IPAddress
+ ", passwordEnabled=" + passwordEnabled + ", rootDeviceId=" + rootDeviceId + ", rootDeviceType=" // + ", ISODisplayText=" + ISODisplayText + ", ISOId=" + ISOId + ", ISOName="
+ rootDeviceType + ", serviceOfferingId=" + serviceOfferingId + ", serviceOfferingName=" // + ISOName + ", jobId=" + jobId + ", jobStatus=" + jobStatus + ", memory=" + memory + ", name=" + name
+ serviceOfferingName + ", state=" + state + ", templateDisplayText=" + templateDisplayText // + ", networkKbsRead=" + networkKbsRead + ", networkKbsWrite=" + networkKbsWrite + ", password=" + password
+ ", templateId=" + templateId + ", templateName=" + templateName + ", zoneId=" + zoneId + ", zoneName=" // + ", passwordEnabled=" + passwordEnabled + ", rootDeviceId=" + rootDeviceId + ", rootDeviceType="
+ zoneName + ", nics=" + nics + ", hypervisor=" + hypervisor + ", securityGroups=" + securityGroups + "]"; // + rootDeviceType + ", serviceOfferingId=" + serviceOfferingId + ", serviceOfferingName=" + serviceOfferingName
+ ", state=" + state
// + ", templateDisplayText=" + templateDisplayText
// + ", templateId=" + templateId + ", templateName=" + templateName + ", zoneId=" + zoneId + ", zoneName="
// + zoneName + ", nics=" + nics + ", hypervisor=" + hypervisor + ", securityGroups=" + securityGroups
+ "]";
} }
@Override @Override

View File

@ -24,6 +24,9 @@ import static com.google.common.base.Preconditions.checkNotNull;
import java.util.Date; import java.util.Date;
import java.util.Map; import java.util.Map;
import org.jclouds.cloudstack.domain.VirtualMachine.State;
import com.google.common.base.CaseFormat;
import com.google.common.base.Function; import com.google.common.base.Function;
import com.google.common.collect.ImmutableSet; import com.google.common.collect.ImmutableSet;
import com.google.common.collect.Maps; import com.google.common.collect.Maps;
@ -61,9 +64,8 @@ public class Volume implements Comparable<Volume> {
private String serviceOfferingName; private String serviceOfferingName;
private long size; private long size;
private long snapshotId; private long snapshotId;
private String state; private State state;
private String storage; private String storage;
// TODO enum
private String storageType; private String storageType;
private VolumeType type; private VolumeType type;
private long virtualMachineId; private long virtualMachineId;
@ -173,7 +175,7 @@ public class Volume implements Comparable<Volume> {
return this; return this;
} }
public Builder state(String state) { public Builder state(State state) {
this.state = state; this.state = state;
return this; return this;
} }
@ -231,11 +233,6 @@ public class Volume implements Comparable<Volume> {
} }
} }
// for deserialization
Volume() {
}
private long id; private long id;
private Date attached; private Date attached;
private Date created; private Date created;
@ -257,7 +254,6 @@ public class Volume implements Comparable<Volume> {
@SerializedName("jobid") @SerializedName("jobid")
private long jobId; private long jobId;
@SerializedName("jobstatus") @SerializedName("jobstatus")
//TODO Change to enum
private String jobStatus; private String jobStatus;
private String name; private String name;
@SerializedName("serviceofferingdisplaytext") @SerializedName("serviceofferingdisplaytext")
@ -269,9 +265,10 @@ public class Volume implements Comparable<Volume> {
private long size; private long size;
@SerializedName("snapshotid") @SerializedName("snapshotid")
private long snapshotId; private long snapshotId;
private String state; private State state;
private String storage; private String storage;
@SerializedName("storagetype") @SerializedName("storagetype")
// MAYDO: this should perhaps be an enum; only value I have seen is "shared"
private String storageType; private String storageType;
private VolumeType type; private VolumeType type;
@SerializedName("virtualmachineid") @SerializedName("virtualmachineid")
@ -291,7 +288,7 @@ public class Volume implements Comparable<Volume> {
String diskOfferingDisplayText, long diskOfferingId, String diskOfferingName, String diskOfferingDisplayText, long diskOfferingId, String diskOfferingName,
String domain, long domainId, String hypervisor, boolean extractable, long jobId, String domain, long domainId, String hypervisor, boolean extractable, long jobId,
String jobStatus, String name, String serviceOfferingDisplayText, long serviceOfferingId, String jobStatus, String name, String serviceOfferingDisplayText, long serviceOfferingId,
String serviceOfferingName, long size, long snapshotId, String state, String storage, String serviceOfferingName, long size, long snapshotId, State state, String storage,
String storageType, VolumeType type, long virtualMachineId, String vmDisplayName, String vmName, String storageType, VolumeType type, long virtualMachineId, String vmDisplayName, String vmName,
VirtualMachine.State vmState, long zoneId, String zoneName) { VirtualMachine.State vmState, long zoneId, String zoneName) {
this.id = id; this.id = id;
@ -326,6 +323,10 @@ public class Volume implements Comparable<Volume> {
this.zoneName = zoneName; this.zoneName = zoneName;
} }
// for deserialization
Volume() {
}
public long getId() { public long getId() {
return id; return id;
} }
@ -334,7 +335,6 @@ public class Volume implements Comparable<Volume> {
return attached; return attached;
} }
public Date getCreated() { public Date getCreated() {
return created; return created;
} }
@ -407,7 +407,7 @@ public class Volume implements Comparable<Volume> {
return snapshotId; return snapshotId;
} }
public String getState() { public State getState() {
return state; return state;
} }
@ -535,6 +535,40 @@ public class Volume implements Comparable<Volume> {
return result; return result;
} }
@Override
public String toString() {
return getClass().getCanonicalName()+"["+id+"; "+name+"; "+vmState+"]";
}
public enum State {
/** indicates that the volume record is created in the DB, but not on the backend */
ALLOCATED,
/** the volume is being created on the backend */
CREATING,
/** the volume is ready to be used */
READY,
/** the volume is destroyed (either as a result of deleteVolume command for DataDisk or as a part of destroyVm) */
DESTROYED,
/** the volume has failed somehow, e.g. during creation (in cloudstack development) */
FAILED,
UNRECOGNIZED;
@Override
public String toString() {
return CaseFormat.UPPER_UNDERSCORE.to(CaseFormat.UPPER_CAMEL, name());
}
public static State fromValue(String state) {
try {
return valueOf(CaseFormat.UPPER_CAMEL.to(CaseFormat.UPPER_UNDERSCORE, checkNotNull(state, "state")));
} catch (IllegalArgumentException e) {
return UNRECOGNIZED;
}
}
}
public enum VolumeType { public enum VolumeType {
ROOT(0), ROOT(0),
DATADISK(1), DATADISK(1),

View File

@ -116,8 +116,9 @@ public interface TemplateAsyncClient {
*/ */
@GET @GET
@QueryParams(keys = "command", values = "deleteTemplate") @QueryParams(keys = "command", values = "deleteTemplate")
@ExceptionParser(ReturnVoidOnNotFoundOr404.class) @Unwrap
ListenableFuture<Void> deleteTemplate(@QueryParam("id") long id, DeleteTemplateOptions... options); @Consumes(MediaType.APPLICATION_JSON)
ListenableFuture<AsyncCreateResponse> deleteTemplate(@QueryParam("id") long id, DeleteTemplateOptions... options);
/** /**
* @see TemplateClient#listTemplates * @see TemplateClient#listTemplates

View File

@ -130,7 +130,7 @@ public interface TemplateClient {
* @param options * @param options
* optional arguments * optional arguments
*/ */
void deleteTemplate(long id, DeleteTemplateOptions... options); AsyncCreateResponse deleteTemplate(long id, DeleteTemplateOptions... options);
/** /**
* List all executable templates. * List all executable templates.

View File

@ -25,30 +25,34 @@ import java.util.Set;
import javax.inject.Singleton; import javax.inject.Singleton;
import com.google.inject.TypeLiteral;
import org.jclouds.cloudstack.domain.AsyncJob; import org.jclouds.cloudstack.domain.AsyncJob;
import org.jclouds.domain.JsonBall; import org.jclouds.domain.JsonBall;
import org.jclouds.http.HttpResponse; import org.jclouds.http.HttpResponse;
import org.jclouds.http.functions.ParseFirstJsonValueNamed;
import org.jclouds.http.functions.UnwrapOnlyNestedJsonValue; import org.jclouds.http.functions.UnwrapOnlyNestedJsonValue;
import com.google.common.base.Function; import com.google.common.base.Function;
import com.google.common.collect.ImmutableSet; import com.google.common.collect.ImmutableSet;
import com.google.common.collect.Iterables; import com.google.common.collect.Iterables;
import com.google.inject.Inject; import com.google.inject.Inject;
import org.jclouds.json.internal.GsonWrapper;
/** /**
*
* @author Adrian Cole * @author Adrian Cole
*/ */
@Singleton @Singleton
public class ParseAsyncJobsFromHttpResponse implements Function<HttpResponse, Set<AsyncJob<?>>> { public class ParseAsyncJobsFromHttpResponse implements Function<HttpResponse, Set<AsyncJob<?>>> {
private final UnwrapOnlyNestedJsonValue<Set<AsyncJob<Map<String, JsonBall>>>> parser; private final ParseFirstJsonValueNamed<Set<AsyncJob<Map<String, JsonBall>>>> parser;
private final ParseTypedAsyncJob parseTyped; private final ParseTypedAsyncJob parseTyped;
@Inject @Inject
public ParseAsyncJobsFromHttpResponse(ParseTypedAsyncJob parseTyped, public ParseAsyncJobsFromHttpResponse(ParseTypedAsyncJob parseTyped, GsonWrapper gsonWrapper) {
UnwrapOnlyNestedJsonValue<Set<AsyncJob<Map<String, JsonBall>>>> parser) {
this.parseTyped = checkNotNull(parseTyped, "parseTyped"); this.parseTyped = checkNotNull(parseTyped, "parseTyped");
this.parser = checkNotNull(parser, "parser"); this.parser = new ParseFirstJsonValueNamed<Set<AsyncJob<Map<String, JsonBall>>>>(
checkNotNull(gsonWrapper, "gsonWrapper"),
new TypeLiteral<Set<AsyncJob<Map<String, JsonBall>>>>() { },
"asyncjobs");
} }
public Set<AsyncJob<?>> apply(HttpResponse response) { public Set<AsyncJob<?>> apply(HttpResponse response) {

View File

@ -18,6 +18,7 @@
*/ */
package org.jclouds.cloudstack.features; package org.jclouds.cloudstack.features;
import static org.jclouds.cloudstack.domain.AsyncJob.ResultCode;
import static org.testng.Assert.assertEquals; import static org.testng.Assert.assertEquals;
import static org.testng.Assert.assertTrue; import static org.testng.Assert.assertTrue;
@ -33,13 +34,15 @@ import org.testng.annotations.Test;
*/ */
@Test(groups = "live", singleThreaded = true, testName = "AsyncJobClientLiveTest") @Test(groups = "live", singleThreaded = true, testName = "AsyncJobClientLiveTest")
public class AsyncJobClientLiveTest extends BaseCloudStackClientLiveTest { public class AsyncJobClientLiveTest extends BaseCloudStackClientLiveTest {
// disabled as it takes too long
@Test(enabled = false) @Test(enabled = true)
public void testListAsyncJobs() throws Exception { public void testListAsyncJobs() throws Exception {
Set<AsyncJob<?>> response = client.getAsyncJobClient().listAsyncJobs(); Set<AsyncJob<?>> response = client.getAsyncJobClient().listAsyncJobs();
assert null != response; assert null != response;
long asyncJobCount = response.size(); long asyncJobCount = response.size();
assertTrue(asyncJobCount >= 0); assertTrue(asyncJobCount >= 0);
for (AsyncJob<?> asyncJob : response) { for (AsyncJob<?> asyncJob : response) {
assert asyncJob.getCmd() != null : asyncJob; assert asyncJob.getCmd() != null : asyncJob;
assert asyncJob.getUserId() >= 0 : asyncJob; assert asyncJob.getUserId() >= 0 : asyncJob;
@ -57,12 +60,11 @@ public class AsyncJobClientLiveTest extends BaseCloudStackClientLiveTest {
assert query.getStatus().code() >= 0 : query; assert query.getStatus().code() >= 0 : query;
assert query.getResultCode().code() >= 0 : query; assert query.getResultCode().code() >= 0 : query;
assert query.getProgress() >= 0 : query; assert query.getProgress() >= 0 : query;
if (query.getResultCode().code() == 0) { if (query.getResultCode() == ResultCode.SUCCESS) {
if (query.getResult() != null)// null is ok for result of success = if (query.getResult() != null) {
// true assertEquals(query.getResult().getClass().getPackage(), AsyncJob.class.getPackage());
// ensure we parsed properly }
assert (query.getResult().getClass().getPackage().equals(AsyncJob.class.getPackage())) : query; } else if (query.getResultCode() == ResultCode.FAIL) {
} else if (query.getResultCode().code() > 400) {
assert query.getResult() == null : query; assert query.getResult() == null : query;
assert query.getError() != null : query; assert query.getError() != null : query;
} else { } else {

View File

@ -49,6 +49,7 @@ import org.jclouds.cloudstack.predicates.VirtualMachineDestroyed;
import org.jclouds.cloudstack.predicates.VirtualMachineRunning; import org.jclouds.cloudstack.predicates.VirtualMachineRunning;
import org.jclouds.cloudstack.strategy.BlockUntilJobCompletesAndReturnResult; import org.jclouds.cloudstack.strategy.BlockUntilJobCompletesAndReturnResult;
import org.jclouds.compute.BaseVersionedServiceLiveTest; import org.jclouds.compute.BaseVersionedServiceLiveTest;
import org.jclouds.compute.ComputeService;
import org.jclouds.compute.ComputeServiceContextFactory; import org.jclouds.compute.ComputeServiceContextFactory;
import org.jclouds.compute.domain.ExecResponse; import org.jclouds.compute.domain.ExecResponse;
import org.jclouds.domain.Credentials; import org.jclouds.domain.Credentials;
@ -130,6 +131,7 @@ public class BaseCloudStackClientLiveTest extends BaseVersionedServiceLiveTest {
protected String prefix = System.getProperty("user.name"); protected String prefix = System.getProperty("user.name");
protected CloudStackContext computeContext; protected CloudStackContext computeContext;
protected ComputeService computeClient;
protected RestContext<CloudStackClient, CloudStackAsyncClient> context; protected RestContext<CloudStackClient, CloudStackAsyncClient> context;
protected CloudStackClient client; protected CloudStackClient client;
protected CloudStackClient adminClient; protected CloudStackClient adminClient;
@ -173,8 +175,10 @@ public class BaseCloudStackClientLiveTest extends BaseVersionedServiceLiveTest {
public void setupClient() { public void setupClient() {
setupCredentials(); setupCredentials();
computeContext = CloudStackContext.class.cast(new ComputeServiceContextFactory().createContext(provider, computeContext = CloudStackContext.class.cast(new ComputeServiceContextFactory(setupRestProperties()).
ImmutableSet.<Module> of(new Log4JLoggingModule(), new SshjSshClientModule()), setupProperties())); createContext(provider, ImmutableSet.<Module> of(
new Log4JLoggingModule(), new SshjSshClientModule()), setupProperties()));
computeClient = computeContext.getComputeService();
context = computeContext.getProviderSpecificContext(); context = computeContext.getProviderSpecificContext();
client = context.getApi(); client = context.getApi();
user = verifyCurrentUserIsOfType(context, Account.Type.USER); user = verifyCurrentUserIsOfType(context, Account.Type.USER);
@ -182,9 +186,9 @@ public class BaseCloudStackClientLiveTest extends BaseVersionedServiceLiveTest {
domainAdminEnabled = setupAdminProperties() != null; domainAdminEnabled = setupAdminProperties() != null;
if (domainAdminEnabled) { if (domainAdminEnabled) {
domainAdminComputeContext = CloudStackContext.class.cast(new ComputeServiceContextFactory().createContext( domainAdminComputeContext = CloudStackContext.class.cast(new ComputeServiceContextFactory(setupRestProperties()).
provider, ImmutableSet.<Module> of(new Log4JLoggingModule(), new SshjSshClientModule()), createContext(provider, ImmutableSet.<Module> of(
setupAdminProperties())); new Log4JLoggingModule(), new SshjSshClientModule()), setupAdminProperties()));
domainAdminContext = domainAdminComputeContext.getDomainContext(); domainAdminContext = domainAdminComputeContext.getDomainContext();
domainAdminClient = domainAdminContext.getApi(); domainAdminClient = domainAdminContext.getApi();
domainAdminUser = verifyCurrentUserIsOfType(domainAdminContext, Account.Type.DOMAIN_ADMIN); domainAdminUser = verifyCurrentUserIsOfType(domainAdminContext, Account.Type.DOMAIN_ADMIN);

View File

@ -28,9 +28,15 @@ import static org.testng.AssertJUnit.assertTrue;
import java.util.Set; import java.util.Set;
import javax.annotation.Resource;
import org.jclouds.cloudstack.domain.AsyncCreateResponse; import org.jclouds.cloudstack.domain.AsyncCreateResponse;
import org.jclouds.cloudstack.domain.Snapshot; import org.jclouds.cloudstack.domain.Snapshot;
import org.jclouds.cloudstack.domain.Volume;
import org.jclouds.cloudstack.options.ListSnapshotsOptions; import org.jclouds.cloudstack.options.ListSnapshotsOptions;
import org.jclouds.logging.Logger;
import org.jclouds.predicates.PredicateCallable;
import org.jclouds.predicates.Retryables;
import org.testng.annotations.Test; import org.testng.annotations.Test;
import com.google.common.base.Function; import com.google.common.base.Function;
@ -40,11 +46,13 @@ import com.google.common.collect.Iterables;
/** /**
* Tests behavior of {@code SnapshotClient} * Tests behavior of {@code SnapshotClient}
* *
* @author grkvlt@apache.org * @author grkvlt@apache.org, Alex Heneveld
*/ */
@Test(groups = "live", singleThreaded = true, testName = "SnapshotClientLiveTest") @Test(groups = "live", singleThreaded = true, testName = "SnapshotClientLiveTest")
public class SnapshotClientLiveTest extends BaseCloudStackClientLiveTest { public class SnapshotClientLiveTest extends BaseCloudStackClientLiveTest {
@Resource Logger logger = Logger.NULL;
public void testListSnapshots() { public void testListSnapshots() {
Set<Snapshot> snapshots = client.getSnapshotClient().listSnapshots(); Set<Snapshot> snapshots = client.getSnapshotClient().listSnapshots();
assertNotNull(snapshots); assertNotNull(snapshots);
@ -102,24 +110,30 @@ public class SnapshotClientLiveTest extends BaseCloudStackClientLiveTest {
assertNull(found); assertNull(found);
} }
public void testCreateSnapshotFromVolume() { protected Volume getPreferredVolume() {
// Pick some volume for (Volume candidate : client.getVolumeClient().listVolumes()) {
long volumeId = Iterables.get(client.getVolumeClient().listVolumes(), 0).getId(); if (candidate.getState() == Volume.State.READY)
return candidate;
Snapshot snapshot = null;
while (snapshot == null) {
try {
AsyncCreateResponse job = client.getSnapshotClient().createSnapshot(volumeId);
assertTrue(jobComplete.apply(job.getJobId()));
snapshot = findSnapshotWithId(job.getId());
} catch (IllegalStateException e) {
// TODO snapshot creation failed - retry?
}
} }
throw new AssertionError("No suitable Volume found.");
}
public void testCreateSnapshotFromVolume() {
final Volume volume = getPreferredVolume(); //fail fast if none
Snapshot snapshot = Retryables.retryGettingResultOrFailing(new PredicateCallable<Snapshot>() {
public Snapshot call() {
logger.info("creating snapshot from volume %s", volume);
AsyncCreateResponse job = client.getSnapshotClient().createSnapshot(volume.getId());
assertTrue(jobComplete.apply(job.getJobId()));
return findSnapshotWithId(job.getId());
}
protected void onFailure() {
logger.info("failed creating snapshot (retrying): %s", getLastFailure());
}
}, null, 60*1000, "failed to create snapshot");
logger.info("created snapshot %s from volume %s", snapshot, volume);
checkSnapshot(snapshot); checkSnapshot(snapshot);
// Delete the snapshot
client.getSnapshotClient().deleteSnapshot(snapshot.getId()); client.getSnapshotClient().deleteSnapshot(snapshot.getId());
} }

View File

@ -170,12 +170,12 @@ public class TemplateAsyncClientTest extends BaseCloudStackAsyncClientTest<Templ
HttpRequest httpRequest = processor.createRequest(method, 17); HttpRequest httpRequest = processor.createRequest(method, 17);
assertRequestLineEquals(httpRequest, "GET http://localhost:8080/client/api?response=json&command=deleteTemplate&id=17 HTTP/1.1"); assertRequestLineEquals(httpRequest, "GET http://localhost:8080/client/api?response=json&command=deleteTemplate&id=17 HTTP/1.1");
assertNonPayloadHeadersEqual(httpRequest, ""); assertNonPayloadHeadersEqual(httpRequest, "Accept: application/json\n");
assertPayloadEquals(httpRequest, null, null, false); assertPayloadEquals(httpRequest, null, null, false);
assertResponseParserClassEquals(method, httpRequest, ReleasePayloadAndReturn.class); assertResponseParserClassEquals(method, httpRequest, UnwrapOnlyJsonValue.class);
assertSaxResponseParserClassEquals(method, null); assertSaxResponseParserClassEquals(method, null);
assertExceptionParserClassEquals(method, ReturnVoidOnNotFoundOr404.class); assertExceptionParserClassEquals(method, MapHttp4xxCodesToExceptions.class);
checkFilters(httpRequest); checkFilters(httpRequest);
} }
@ -185,12 +185,12 @@ public class TemplateAsyncClientTest extends BaseCloudStackAsyncClientTest<Templ
HttpRequest httpRequest = processor.createRequest(method, 17, DeleteTemplateOptions.Builder.zoneId(8)); HttpRequest httpRequest = processor.createRequest(method, 17, DeleteTemplateOptions.Builder.zoneId(8));
assertRequestLineEquals(httpRequest, "GET http://localhost:8080/client/api?response=json&command=deleteTemplate&id=17&zoneid=8 HTTP/1.1"); assertRequestLineEquals(httpRequest, "GET http://localhost:8080/client/api?response=json&command=deleteTemplate&id=17&zoneid=8 HTTP/1.1");
assertNonPayloadHeadersEqual(httpRequest, ""); assertNonPayloadHeadersEqual(httpRequest, "Accept: application/json\n");
assertPayloadEquals(httpRequest, null, null, false); assertPayloadEquals(httpRequest, null, null, false);
assertResponseParserClassEquals(method, httpRequest, ReleasePayloadAndReturn.class); assertResponseParserClassEquals(method, httpRequest, UnwrapOnlyJsonValue.class);
assertSaxResponseParserClassEquals(method, null); assertSaxResponseParserClassEquals(method, null);
assertExceptionParserClassEquals(method, ReturnVoidOnNotFoundOr404.class); assertExceptionParserClassEquals(method, MapHttp4xxCodesToExceptions.class);
checkFilters(httpRequest); checkFilters(httpRequest);
} }

View File

@ -37,7 +37,7 @@ import static org.jclouds.cloudstack.options.ListTemplatesOptions.Builder.zoneId
import static org.testng.Assert.*; import static org.testng.Assert.*;
/** /**
* Tests behavior of {@code TemplateClientLiveTest} * Tests behavior of {@code TemplateClient}
* *
* @author Adrian Cole * @author Adrian Cole
*/ */
@ -187,6 +187,8 @@ public class TemplateClientLiveTest extends BaseCloudStackClientLiveTest {
assert virtualMachineDestroyed.apply(vm); assert virtualMachineDestroyed.apply(vm);
} }
if (createdTemplate != null) { if (createdTemplate != null) {
AsyncCreateResponse deleteJob = client.getTemplateClient().deleteTemplate(template.getId());
assertTrue(jobComplete.apply(deleteJob.getJobId()));
client.getTemplateClient().deleteTemplate(createdTemplate.getId()); client.getTemplateClient().deleteTemplate(createdTemplate.getId());
} }
if (registeredTemplate != null) { if (registeredTemplate != null) {

View File

@ -18,31 +18,46 @@
*/ */
package org.jclouds.cloudstack.features; package org.jclouds.cloudstack.features;
import static com.google.common.collect.Iterables.*; import static org.testng.AssertJUnit.assertEquals;
import static org.testng.AssertJUnit.*; import static org.testng.AssertJUnit.assertFalse;
import static org.testng.AssertJUnit.assertNotNull;
import static org.testng.AssertJUnit.assertNotSame;
import static org.testng.AssertJUnit.assertNull;
import static org.testng.AssertJUnit.assertTrue;
import java.util.NoSuchElementException;
import java.util.Set; import java.util.Set;
import com.google.common.base.Function; import javax.annotation.Resource;
import org.jclouds.cloudstack.CloudStackClient;
import org.jclouds.cloudstack.domain.AsyncCreateResponse; import org.jclouds.cloudstack.domain.AsyncCreateResponse;
import org.jclouds.cloudstack.domain.DiskOffering;
import org.jclouds.cloudstack.domain.Snapshot; import org.jclouds.cloudstack.domain.Snapshot;
import org.jclouds.cloudstack.domain.VirtualMachine;
import org.jclouds.cloudstack.domain.Volume; import org.jclouds.cloudstack.domain.Volume;
import org.jclouds.cloudstack.domain.Zone; import org.jclouds.cloudstack.domain.Zone;
import org.jclouds.cloudstack.options.ListVolumesOptions; import org.jclouds.cloudstack.options.ListVolumesOptions;
import org.jclouds.logging.Logger;
import org.jclouds.predicates.PredicateCallable;
import org.jclouds.predicates.Retryables;
import org.testng.annotations.BeforeMethod; import org.testng.annotations.BeforeMethod;
import org.testng.annotations.Test; import org.testng.annotations.Test;
import com.google.common.base.Predicate; import com.google.common.base.Function;
import com.google.common.collect.Iterables; import com.google.common.collect.Iterables;
/** /**
* Tests behavior of {@code VolumeClient} * Tests behavior of {@code VolumeClient}
* *
* @author Vijay Kiran * @author Vijay Kiran, Alex Heneveld
*/ */
@Test(groups = "live", singleThreaded = true, testName = "VolumeClientLiveTest") @Test(groups = "live", singleThreaded = true, testName = "VolumeClientLiveTest")
public class VolumeClientLiveTest extends BaseCloudStackClientLiveTest { public class VolumeClientLiveTest extends BaseCloudStackClientLiveTest {
protected String prefix = System.getProperty("user.name");
@Resource Logger logger = Logger.NULL;
protected String prefix = System.getProperty("user.name")+"-"+getClass().getSimpleName();
private long zoneId; private long zoneId;
@ -66,10 +81,10 @@ public class VolumeClientLiveTest extends BaseCloudStackClientLiveTest {
public void testListVolumesById() { public void testListVolumesById() {
Iterable<Long> volumeIds = Iterables.transform(client.getVolumeClient().listVolumes(), new Function<Volume, Long>() { Iterable<Long> volumeIds = Iterables.transform(client.getVolumeClient().listVolumes(), new Function<Volume, Long>() {
public Long apply(Volume input) { public Long apply(Volume input) {
return input.getId(); return input.getId();
} }
}); });
assertNotNull(volumeIds); assertNotNull(volumeIds);
assertFalse(Iterables.isEmpty(volumeIds)); assertFalse(Iterables.isEmpty(volumeIds));
@ -91,10 +106,10 @@ public class VolumeClientLiveTest extends BaseCloudStackClientLiveTest {
public void testGetVolumeById() { public void testGetVolumeById() {
Iterable<Long> volumeIds = Iterables.transform(client.getVolumeClient().listVolumes(), new Function<Volume, Long>() { Iterable<Long> volumeIds = Iterables.transform(client.getVolumeClient().listVolumes(), new Function<Volume, Long>() {
public Long apply(Volume input) { public Long apply(Volume input) {
return input.getId(); return input.getId();
} }
}); });
assertNotNull(volumeIds); assertNotNull(volumeIds);
assertFalse(Iterables.isEmpty(volumeIds)); assertFalse(Iterables.isEmpty(volumeIds));
@ -111,114 +126,141 @@ public class VolumeClientLiveTest extends BaseCloudStackClientLiveTest {
assertNull(found); assertNull(found);
} }
public void testCreateVolumeFromDiskofferingInZoneAndDeleteVolume() { protected DiskOffering getPreferredDiskOffering() {
// Pick some disk offering for (DiskOffering candidate : client.getOfferingClient().listDiskOfferings()) {
long diskOfferingId = Iterables.get(client.getOfferingClient().listDiskOfferings(), 0).getId(); //any will do
return candidate;
Volume volume = null;
while (volume == null) {
try {
AsyncCreateResponse job = client.getVolumeClient().createVolumeFromDiskOfferingInZone(prefix + "-jclouds-volume",
diskOfferingId, zoneId);
assertTrue(jobComplete.apply(job.getJobId()));
volume = findVolumeWithId(job.getId());
} catch (IllegalStateException e) {
// TODO volume creation failed - retry?
}
} }
throw new AssertionError("No suitable DiskOffering found.");
}
protected Snapshot getPreferredSnapshot() {
for (Snapshot candidate : client.getSnapshotClient().listSnapshots()) {
if (candidate.getState()==Snapshot.State.BACKED_UP)
return candidate;
}
throw new AssertionError("No suitable Snapshot found.");
}
protected VirtualMachine getPreferredVirtualMachine() {
for (VirtualMachine candidate : client.getVirtualMachineClient().listVirtualMachines()) {
// this is a guess::
if (candidate.getState()==VirtualMachine.State.RUNNING || candidate.getState()==VirtualMachine.State.STOPPED)
return candidate;
}
throw new AssertionError("No suitable VirtualMachine found.");
}
protected Volume createPreferredVolumeFromDisk() {
return Retryables.retryGettingResultOrFailing(new PredicateCallable<Volume>() {
public Volume call() {
AsyncCreateResponse job = client.getVolumeClient().createVolumeFromDiskOfferingInZone(
prefix+"-jclouds-volume", getPreferredDiskOffering().getId(), zoneId);
assertTrue(jobComplete.apply(job.getJobId()));
logger.info("created volume "+job.getId());
return findVolumeWithId(job.getId());
}
}, null, 60*1000, "failed to create volume");
}
public void testCreateVolumeFromDiskofferingInZoneAndDeleteVolume() {
logger.info("testCreateVolumeFromDiskofferingInZoneAndDeleteVolume");
Volume volume = createPreferredVolumeFromDisk();
checkVolume(volume); checkVolume(volume);
// Delete the volume
client.getVolumeClient().deleteVolume(volume.getId()); client.getVolumeClient().deleteVolume(volume.getId());
} }
/** test requires that a VM exist */
public void testCreateVolumeFromDiskofferingInZoneAndAttachVolumeToVirtualMachineAndDetachAndDelete() { public void testCreateVolumeFromDiskofferingInZoneAndAttachVolumeToVirtualMachineAndDetachAndDelete() {
// Pick some disk offering logger.info("testCreateVolumeFromDiskofferingInZoneAndAttachVolumeToVirtualMachineAndDetachAndDelete");
long diskOfferingId = Iterables.get(client.getOfferingClient().listDiskOfferings(), 0).getId(); final Volume volume = createPreferredVolumeFromDisk();
try {
Volume volume = null; checkVolume(volume);
while (volume == null) {
try { final VirtualMachine virtualMachine = getPreferredVirtualMachine();
AsyncCreateResponse job = client.getVolumeClient().createVolumeFromDiskOfferingInZone(prefix + "-jclouds-volume",
diskOfferingId, zoneId); Volume attachedVolume = Retryables.retryGettingResultOrFailing(new PredicateCallable<Volume>() {
assertTrue(jobComplete.apply(job.getJobId())); public Volume call() {
volume = findVolumeWithId(job.getId()); logger.info("attaching volume %s to vm %s", volume, virtualMachine);
} catch (IllegalStateException e) { AsyncCreateResponse job = client.getVolumeClient().attachVolume(volume.getId(), virtualMachine.getId());
// TODO volume creation failed - retry? assertTrue(jobComplete.apply(job.getJobId()));
} return findVolumeWithId(volume.getId());
}
int failures=0;
protected void onFailure() {
logger.info("failed attaching volume (retrying): %s", getLastFailure());
if (failures++==0) logger.warn(getLastFailure(), "first failure attaching volume");
}
}, null, 60*1000, "failed to attach volume");
checkVolume(attachedVolume);
assertEquals(virtualMachine.getId(), attachedVolume.getVirtualMachineId());
assertNotNull(attachedVolume.getAttached());
Volume detachedVolume = Retryables.retryGettingResultOrFailing(new PredicateCallable<Volume>() {
public Volume call() {
logger.info("detaching volume %s from vm %s", volume, virtualMachine);
AsyncCreateResponse job = client.getVolumeClient().detachVolume(volume.getId());
assertTrue(jobComplete.apply(job.getJobId()));
return findVolumeWithId(volume.getId());
}
protected void onFailure() {
logger.debug("failed detaching volume (retrying): %s", getLastFailure());
}
}, null, 60*1000, "failed to detach volume");
checkVolume(detachedVolume);
assertNull(detachedVolume.getAttached());
} finally {
client.getVolumeClient().deleteVolume(volume.getId());
} }
checkVolume(volume);
long virtualMachineId = Iterables.get(client.getVirtualMachineClient().listVirtualMachines(), 0).getId();
// Attach Volume
Volume attachedVolume = null;
while (attachedVolume == null) {
try {
AsyncCreateResponse job = client.getVolumeClient().attachVolume(volume.getId(), virtualMachineId);
assertTrue(jobComplete.apply(job.getJobId()));
attachedVolume = findVolumeWithId(volume.getId());
assertEquals(virtualMachineId, attachedVolume.getVirtualMachineId());
assertNotNull(attachedVolume.getAttached());
} catch (IllegalStateException e) {
// TODO volume creation failed - retry?
}
}
// Detach Volume
Volume detachedVolume = null;
while (detachedVolume == null) {
try {
AsyncCreateResponse job = client.getVolumeClient().detachVolume(volume.getId());
assertTrue(jobComplete.apply(job.getJobId()));
detachedVolume = findVolumeWithId(volume.getId());
checkVolume(detachedVolume);
} catch (IllegalStateException e) {
//TODO volume creation failed - retry?
}
}
// Cleanup
client.getVolumeClient().deleteVolume(volume.getId());
} }
public void testCreateVolumeFromSnapshotInZoneAndDeleteVolume() { public void testCreateVolumeFromSnapshotInZoneAndDeleteVolume() {
Set<Snapshot> snapshots = client.getSnapshotClient().listSnapshots(); logger.info("testCreateVolumeFromSnapshotInZoneAndDeleteVolume (takes ~3m)");
assertNotNull(snapshots); assertNotNull(getPreferredSnapshot());
assertFalse(snapshots.isEmpty()); Volume volume = Retryables.retryGettingResultOrFailing(new PredicateCallable<Volume>() {
long snapshotId = Iterables.get(snapshots, 0).getId(); public Volume call() {
AsyncCreateResponse job = client.getVolumeClient().createVolumeFromSnapshotInZone(
Volume volume = null; prefix+"-jclouds-volume", getPreferredSnapshot().getId(), zoneId);
while (volume == null) {
try {
AsyncCreateResponse job = client.getVolumeClient().createVolumeFromSnapshotInZone(prefix + "-jclouds-volume",
snapshotId, zoneId);
assertTrue(jobComplete.apply(job.getJobId())); assertTrue(jobComplete.apply(job.getJobId()));
volume = findVolumeWithId(job.getId()); return findVolumeWithId(job.getId());
} catch (IllegalStateException e) {
// TODO volume creation failed - retry?
} }
} protected void onFailure() {
logger.debug("failed creating volume (retrying): %s", getLastFailure());
}
}, null, 60*1000, "failed to create volume");
checkVolume(volume); checkVolume(volume);
// Delete the volume
client.getVolumeClient().deleteVolume(volume.getId()); client.getVolumeClient().deleteVolume(volume.getId());
} }
private void checkVolume(final Volume volume) { static void checkVolume(final Volume volume) {
assertNotNull(volume.getId()); assertNotNull(volume.getId());
assertNotNull(volume.getName()); assertNotNull(volume.getName());
assertNotSame(Volume.VolumeType.UNRECOGNIZED, volume.getType()); assertNotSame(Volume.VolumeType.UNRECOGNIZED, volume.getType());
} }
private Volume findVolumeWithId(final long id) { Volume findVolumeWithId(final long id) {
return find(client.getVolumeClient().listVolumes(), new Predicate<Volume>() { return findVolumeWithId(client, id);
@Override
public boolean apply(Volume arg0) {
return arg0.getId() == id;
}
});
} }
static Volume findVolumeWithId(final CloudStackClient client, final long id) {
for (Volume v: client.getVolumeClient().listVolumes())
if (v.getId()==id) return v;
throw new NoSuchElementException("no volume with id "+id);
}
// //uncomment to force a cleanup of volumes (since test failures can leave messes)
// public void deleteAllWeUsed() {
// for (Volume v: client.getVolumeClient().listVolumes()) {
// if (v.getName().startsWith(prefix)) {
// logger.warn("found apparent detritus, deleting: %s", v);
// try {
// client.getVolumeClient().deleteVolume(v.getId());
// } catch (Exception e) {
// logger.warn(e, "failed to delete %s: %s", v, e);
// }
// }
// }
// }
} }

View File

@ -39,7 +39,7 @@ import com.google.inject.Injector;
@Test(groups = "unit") @Test(groups = "unit")
public class ParseAsyncJobsFromHttpResponseTest { public class ParseAsyncJobsFromHttpResponseTest {
Injector i = Guice.createInjector(new GsonModule() { Injector injector = Guice.createInjector(new GsonModule() {
@Override @Override
protected void configure() { protected void configure() {
@ -52,7 +52,7 @@ public class ParseAsyncJobsFromHttpResponseTest {
public void testCanParse() { public void testCanParse() {
InputStream is = getClass().getResourceAsStream("/listasyncjobsresponse.json"); InputStream is = getClass().getResourceAsStream("/listasyncjobsresponse.json");
ParseAsyncJobsFromHttpResponse parser = i.getInstance(ParseAsyncJobsFromHttpResponse.class); ParseAsyncJobsFromHttpResponse parser = injector.getInstance(ParseAsyncJobsFromHttpResponse.class);
Set<AsyncJob<?>> response = parser.apply(new HttpResponse(200, "ok", Payloads.newInputStreamPayload(is))); Set<AsyncJob<?>> response = parser.apply(new HttpResponse(200, "ok", Payloads.newInputStreamPayload(is)));
assertEquals(response.size(), 77); assertEquals(response.size(), 77);

View File

@ -0,0 +1,45 @@
/**
* Licensed to jclouds, Inc. (jclouds) under one or more
* contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. jclouds licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.jclouds.cloudstack.parse;
import org.jclouds.cloudstack.domain.AsyncJob;
import org.jclouds.cloudstack.domain.JobResult;
import org.jclouds.json.BaseItemParserTest;
import org.jclouds.rest.annotations.SelectJson;
import org.testng.annotations.Test;
/**
*
* @author Richard Downer
*/
@Test(groups = "unit", testName = "DeleteNetworkResponseTest")
public class JobResultResponseTest extends BaseItemParserTest<JobResult> {
@Override
public String resource() {
return "/deletetemplateresponse.json";
}
@Override
@SelectJson("jobresult")
public JobResult expected() {
return new JobResult(true, null);
}
}

View File

@ -0,0 +1 @@
{ "queryasyncjobresultresponse" : {"jobid":118,"jobstatus":1,"jobprocstatus":0,"jobresultcode":0,"jobresulttype":"object","jobresult":{"success":true}} }

View File

@ -1,5 +1,6 @@
{ {
"listasyncjobsresponse": { "listasyncjobsresponse": {
"count": 77,
"asyncjobs": [{ "asyncjobs": [{
"jobid": 1084, "jobid": 1084,
"accountid": 3, "accountid": 3,

View File

@ -103,24 +103,12 @@ $symbol_dollar = '$' )
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.${lcaseProviderName}.identity>\$\{test.${lcaseProviderName}.identity\}</test.${lcaseProviderName}.identity>
<name>test.${lcaseProviderName}.identity</name> <test.${lcaseProviderName}.credential>\$\{test.${lcaseProviderName}.credential\}</test.${lcaseProviderName}.credential>
<value>\$\{test.${lcaseProviderName}.identity\}</value> <test.${lcaseProviderName}.endpoint>\$\{test.${lcaseProviderName}.endpoint\}</test.${lcaseProviderName}.endpoint>
</property> <test.${lcaseProviderName}.apiversion>\$\{test.${lcaseProviderName}.apiversion\}</test.${lcaseProviderName}.apiversion>
<property> </systemPropertyVariables>
<name>test.${lcaseProviderName}.credential</name>
<value>\$\{test.${lcaseProviderName}.credential\}</value>
</property>
<property>
<name>test.${lcaseProviderName}.endpoint</name>
<value>\$\{test.${lcaseProviderName}.endpoint\}</value>
</property>
<property>
<name>test.${lcaseProviderName}.apiversion</name>
<value>\$\{test.${lcaseProviderName}.apiversion\}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -0,0 +1,66 @@
/**
* Licensed to jclouds, Inc. (jclouds) under one or more
* contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. jclouds licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.jclouds.predicates;
import java.util.concurrent.Callable;
import com.google.common.annotations.Beta;
/** Provides a facility to convert an arbitrary Callable to a Predicate, implementing PredicateWithResult,
* for use e.g. with Retryables.retryGetting... methods */
@Beta
public abstract class PredicateCallable<Result> implements PredicateWithResult<Void, Result>, Callable<Result> {
Result lastResult;
Exception lastFailure;
@Override
public boolean apply(Void input) {
try {
lastResult = call();
onCompletion();
return isAcceptable(lastResult);
} catch (Exception e) {
lastFailure = e;
onFailure();
return false;
}
}
protected void onFailure() {
}
protected void onCompletion() {
}
protected boolean isAcceptable(Result result) {
return result!=null;
}
@Override
public Result getResult() {
return lastResult;
}
@Override
public Throwable getLastFailure() {
return lastFailure;
}
}

View File

@ -0,0 +1,31 @@
/**
* Licensed to jclouds, Inc. (jclouds) under one or more
* contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. jclouds licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.jclouds.predicates;
import com.google.common.annotations.Beta;
import com.google.common.base.Predicate;
@Beta
public interface PredicateWithResult<Input,Result> extends Predicate<Input> {
Result getResult();
Throwable getLastFailure();
}

View File

@ -34,6 +34,11 @@ import com.google.common.base.Predicate;
/** /**
* *
* Retries a condition until it is met or a timeout occurs. * Retries a condition until it is met or a timeout occurs.
* maxWait parameter is required.
* Initial retry period and retry maxPeriod are optionally configurable,
* defaulting to 50ms and 1000ms respectively,
* with the retrier increasing the interval by a factor of 1.5 each time within these constraints.
* All values taken as millis unless TimeUnit specified.
* *
* @author Adrian Cole * @author Adrian Cole
*/ */
@ -92,6 +97,7 @@ public class RetryablePredicate<T> implements Predicate<T> {
} }
protected long nextMaxInterval(long attempt, Date end) { protected long nextMaxInterval(long attempt, Date end) {
// FIXME i think this should be pow(1.5, attempt) -- or alternatively newInterval = oldInterval*1.5
long interval = (period * (long) Math.pow(attempt, 1.5)); long interval = (period * (long) Math.pow(attempt, 1.5));
interval = interval > maxPeriod ? maxPeriod : interval; interval = interval > maxPeriod ? maxPeriod : interval;
long max = end.getTime() - System.currentTimeMillis(); long max = end.getTime() - System.currentTimeMillis();

View File

@ -0,0 +1,61 @@
/**
* Licensed to jclouds, Inc. (jclouds) under one or more
* contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. jclouds licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.jclouds.predicates;
import java.util.concurrent.TimeUnit;
import com.google.common.annotations.Beta;
import com.google.common.base.Predicate;
/** convenience methods to retry application of a predicate, and optionally (reducing quite a bit of boilerplate)
* get the final result or throw assertion error
*
* @author alex heneveld
*/
@Beta
public class Retryables {
public static <Input> boolean retry(Predicate<Input> predicate, Input input, long maxWaitMillis) {
return new RetryablePredicate<Input>(predicate, maxWaitMillis).apply(input);
}
public static <Input> boolean retry(Predicate<Input> predicate, Input input, long maxWait, long period, TimeUnit unit) {
return new RetryablePredicate<Input>(predicate, maxWait, period, unit).apply(input);
}
public static <Input> void assertEventually(Predicate<Input> predicate, Input input,
long maxWaitMillis, String failureMessage) {
if (!new RetryablePredicate<Input>(predicate, maxWaitMillis).apply(input))
throw new AssertionError(failureMessage);
}
public static <Input,Result> Result retryGettingResultOrFailing(PredicateWithResult<Input,Result> predicate,
Input input, long maxWaitMillis, String failureMessage) {
if (!new RetryablePredicate<Input>(predicate, maxWaitMillis).apply(input))
throw (AssertionError)new AssertionError(failureMessage).initCause(predicate.getLastFailure());
return predicate.getResult();
}
public static <Input,Result> Result retryGettingResultOrFailing(PredicateWithResult<Input,Result> predicate,
Input input, long maxWait, long period, TimeUnit unit, String failureMessage) {
if (!new RetryablePredicate<Input>(predicate, maxWait, period, unit).apply(input))
throw (AssertionError)new AssertionError(failureMessage).initCause(predicate.getLastFailure());
return predicate.getResult();
}
}

View File

@ -0,0 +1,128 @@
/**
* Licensed to jclouds, Inc. (jclouds) under one or more
* contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. jclouds licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.jclouds.predicates;
import static java.util.concurrent.TimeUnit.MILLISECONDS;
import static org.jclouds.predicates.Retryables.retry;
import static org.jclouds.predicates.Retryables.retryGettingResultOrFailing;
import static org.testng.Assert.*;
import org.testng.annotations.Test;
@Test
public class RetryablesTest {
public static class FindX implements PredicateWithResult<String,Character> {
Character result;
Throwable lastFailure;
int attempts=0;
@Override
public boolean apply(String input) {
try {
result = input.charAt(attempts++);
return (result=='x');
} catch (Exception e) {
lastFailure = e;
return false;
}
}
public Character getResult() {
return result;
}
public Throwable getLastFailure() {
return lastFailure;
}
}
public void testPredicateWithResult() {
FindX findX = new FindX();
assertFalse(findX.apply("hexy"));
assertEquals((char)findX.getResult(), 'h');
assertFalse(findX.apply("hexy"));
assertTrue(findX.apply("hexy"));
assertEquals((char)findX.getResult(), 'x');
assertFalse(findX.apply("hexy"));
assertNull(findX.getLastFailure());
//now we get error
assertFalse(findX.apply("hexy"));
assertNotNull(findX.getLastFailure());
assertEquals((char)findX.getResult(), 'y');
}
public void testRetry() {
FindX findX = new FindX();
assertTrue(retry(findX, "hexy", 1000, 1, MILLISECONDS));
assertEquals(findX.attempts, 3);
assertEquals((char)findX.getResult(), 'x');
assertNull(findX.getLastFailure());
//now we'll be getting errors
assertFalse(retry(findX, "hexy", 100, 1, MILLISECONDS));
assertEquals((char)findX.getResult(), 'y');
assertNotNull(findX.getLastFailure());
}
public void testRetryGetting() {
FindX findX = new FindX();
assertEquals((char)retryGettingResultOrFailing(findX, "hexy", 1000, "shouldn't happen"), 'x');
//now we'll be getting errors
boolean secondRetrySucceeds=false;
try {
retryGettingResultOrFailing(findX, "hexy", 100, "expected");
secondRetrySucceeds = true;
} catch (AssertionError e) {
assertTrue(e.toString().contains("expected"));
}
if (secondRetrySucceeds) fail("should have thrown");
assertNotNull(findX.getLastFailure());
assertFalse(findX.getLastFailure().toString().contains("expected"));
}
//using PredicateCallable we can repeat the above test, with the job expressed more simply
public static class FindXSimpler extends PredicateCallable<Character> {
String input = "hexy";
int attempts=0;
public Character call() {
return input.charAt(attempts++);
}
public boolean isAcceptable(Character result) {
return result=='x';
}
}
public void testSimplerPredicateCallableRetryGetting() {
FindXSimpler findX = new FindXSimpler();
assertEquals((char)retryGettingResultOrFailing(findX, null, 1000, "shouldn't happen"), 'x');
//now we'll be getting errors
boolean secondRetrySucceeds=false;
try {
retryGettingResultOrFailing(findX, null, 100, "expected");
secondRetrySucceeds = true;
} catch (AssertionError e) {
assertTrue(e.toString().contains("expected"));
}
if (secondRetrySucceeds) fail("should have thrown");
assertNotNull(findX.getLastFailure());
assertFalse(findX.getLastFailure().toString().contains("expected"));
}
}

View File

@ -96,40 +96,16 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.identity.azureblob>${jclouds.azure.storage.account}</test.identity.azureblob>
<name>test.identity.azureblob</name> <test.credential.azureblob>${jclouds.azure.storage.key}</test.credential.azureblob>
<value>${jclouds.azure.storage.account}</value> <test.identity.cloudfiles>${jclouds.rackspace.user}</test.identity.cloudfiles>
</property> <test.credential.cloudfiles>${jclouds.rackspace.key}</test.credential.cloudfiles>
<property> <test.identity.s3>${jclouds.aws.accesskeyid}</test.identity.s3>
<name>test.credential.azureblob</name> <test.credential.s3>${jclouds.aws.secretaccesskey}</test.credential.s3>
<value>${jclouds.azure.storage.key}</value> <jclouds.getpath.container>${jclouds.getpath.container}</jclouds.getpath.container>
</property> <jclouds.getpath.path>${jclouds.getpath.path}</jclouds.getpath.path>
<property> </systemPropertyVariables>
<name>test.identity.cloudfiles</name>
<value>${jclouds.rackspace.user}</value>
</property>
<property>
<name>test.credential.cloudfiles</name>
<value>${jclouds.rackspace.key}</value>
</property>
<property>
<name>test.identity.s3</name>
<value>${jclouds.aws.accesskeyid}</value>
</property>
<property>
<name>test.credential.s3</name>
<value>${jclouds.aws.secretaccesskey}</value>
</property>
<property>
<name>jclouds.getpath.container</name>
<value>${jclouds.getpath.container}</value>
</property>
<property>
<name>jclouds.getpath.path</name>
<value>${jclouds.getpath.path}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -151,34 +151,14 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.aws.identity>${test.aws-s3.identity}</test.aws.identity>
<name>test.aws.identity</name> <test.aws.credential>${test.aws-s3.credential}</test.aws.credential>
<!-- same for EC2 --> <appengine.sdk.root>${appengine.sdk.root}</appengine.sdk.root>
<value>${test.aws-s3.identity}</value> <devappserver.address>${devappserver.address}</devappserver.address>
</property> <devappserver.port>${devappserver.port}</devappserver.port>
<property> <warfile>${project.build.directory}/${project.artifactId}</warfile>
<name>test.aws.credential</name> </systemPropertyVariables>
<!-- same for EC2 -->
<value>${test.aws-s3.credential}</value>
</property>
<property>
<name>appengine.sdk.root</name>
<value>${appengine.sdk.root}</value>
</property>
<property>
<name>devappserver.address</name>
<value>${devappserver.address}</value>
</property>
<property>
<name>devappserver.port</name>
<value>${devappserver.port}</value>
</property>
<property>
<name>warfile</name>
<value>${project.build.directory}/${project.artifactId}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -132,24 +132,12 @@
</goals> </goals>
<configuration> <configuration>
<threadCount>1</threadCount> <threadCount>1</threadCount>
<systemProperties> <systemPropertyVariables>
<property> <test.aws-s3.identity>${test.aws-s3.identity}</test.aws-s3.identity>
<name>test.aws-s3.identity</name> <test.aws-s3.credential>${test.aws-s3.credential}</test.aws-s3.credential>
<value>${test.aws-s3.identity}</value> <test.initializer>${test.initializer}</test.initializer>
</property> <test.aws-s3.loopcount>${test.aws-s3.loopcount}</test.aws-s3.loopcount>
<property> </systemPropertyVariables>
<name>test.aws-s3.credential</name>
<value>${test.aws-s3.credential}</value>
</property>
<property>
<name>test.initializer</name>
<value>${test.initializer}</value>
</property>
<property>
<name>test.aws-s3.loopcount</name>
<value>${test.aws-s3.loopcount}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -95,88 +95,28 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.twitter.consumer.identity>${test.twitter.gae-tweetstore-spring.consumer.identity}</test.twitter.consumer.identity>
<name>test.twitter.consumer.identity</name> <test.twitter.consumer.credential>${test.twitter.gae-tweetstore-spring.consumer.credential}</test.twitter.consumer.credential>
<value>${test.twitter.gae-tweetstore-spring.consumer.identity}</value> <test.twitter.access.identity>${test.twitter.gae-tweetstore-spring.access.identity}</test.twitter.access.identity>
</property> <test.twitter.access.credential>${test.twitter.gae-tweetstore-spring.access.credential}</test.twitter.access.credential>
<property> <test.azureblob.identity>${test.azureblob.identity}</test.azureblob.identity>
<name>test.twitter.consumer.credential</name> <test.azureblob.credential>${test.azureblob.credential}</test.azureblob.credential>
<value>${test.twitter.gae-tweetstore-spring.consumer.credential}</value> <test.cloudfiles-us.identity>${test.cloudfiles-us.identity}</test.cloudfiles-us.identity>
</property> <test.cloudfiles-us.credential>${test.cloudfiles-us.credential}</test.cloudfiles-us.credential>
<property> <test.aws-s3.identity>${test.aws-s3.identity}</test.aws-s3.identity>
<name>test.twitter.access.identity</name> <test.aws-s3.credential>${test.aws-s3.credential}</test.aws-s3.credential>
<value>${test.twitter.gae-tweetstore-spring.access.identity}</value> <test.cloudonestorage.identity>${test.cloudonestorage.identity}</test.cloudonestorage.identity>
</property> <test.cloudonestorage.credential>${test.cloudonestorage.credential}</test.cloudonestorage.credential>
<property> <test.ninefold-storage.identity>${test.ninefold-storage.identity}</test.ninefold-storage.identity>
<name>test.twitter.access.credential</name> <test.ninefold-storage.credential>${test.ninefold-storage.credential}</test.ninefold-storage.credential>
<value>${test.twitter.gae-tweetstore-spring.access.credential}</value> <appengine.sdk.root>${appengine.sdk.root}</appengine.sdk.root>
</property> <devappserver.address>${devappserver.address}</devappserver.address>
<property> <devappserver.port>${devappserver.port}</devappserver.port>
<name>test.azureblob.identity</name> <jclouds.tweetstore.blobstores>${jclouds.tweetstore.blobstores}</jclouds.tweetstore.blobstores>
<value>${test.azureblob.identity}</value> <jclouds.tweetstore.container>test.${jclouds.tweetstore.container}</jclouds.tweetstore.container>
</property> <warfile>${project.build.directory}/${project.artifactId}</warfile>
<property> </systemPropertyVariables>
<name>test.azureblob.credential</name>
<value>${test.azureblob.credential}</value>
</property>
<property>
<name>test.cloudfiles-us.identity</name>
<value>${test.cloudfiles-us.identity}</value>
</property>
<property>
<name>test.cloudfiles-us.credential</name>
<value>${test.cloudfiles-us.credential}</value>
</property>
<property>
<name>test.aws-s3.identity</name>
<value>${test.aws-s3.identity}</value>
</property>
<property>
<name>test.aws-s3.credential</name>
<value>${test.aws-s3.credential}</value>
</property>
<property>
<name>test.cloudonestorage.identity</name>
<value>${test.cloudonestorage.identity}</value>
</property>
<property>
<name>test.cloudonestorage.credential</name>
<value>${test.cloudonestorage.credential}</value>
</property>
<property>
<name>test.ninefold-storage.identity</name>
<value>${test.ninefold-storage.identity}</value>
</property>
<property>
<name>test.ninefold-storage.credential</name>
<value>${test.ninefold-storage.credential}</value>
</property>
<property>
<name>appengine.sdk.root</name>
<value>${appengine.sdk.root}</value>
</property>
<property>
<name>devappserver.address</name>
<value>${devappserver.address}</value>
</property>
<property>
<name>devappserver.port</name>
<value>${devappserver.port}</value>
</property>
<property>
<name>jclouds.tweetstore.blobstores</name>
<value>${jclouds.tweetstore.blobstores}</value>
</property>
<property>
<name>jclouds.tweetstore.container</name>
<value>test.${jclouds.tweetstore.container}</value>
</property>
<property>
<name>warfile</name>
<value>${project.build.directory}/${project.artifactId}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -84,88 +84,28 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.twitter.consumer.identity>${test.twitter.gae-tweetstore.consumer.identity}</test.twitter.consumer.identity>
<name>test.twitter.consumer.identity</name> <test.twitter.consumer.credential>${test.twitter.gae-tweetstore.consumer.credential}</test.twitter.consumer.credential>
<value>${test.twitter.gae-tweetstore.consumer.identity}</value> <test.twitter.access.identity>${test.twitter.gae-tweetstore.access.identity}</test.twitter.access.identity>
</property> <test.twitter.access.credential>${test.twitter.gae-tweetstore.access.credential}</test.twitter.access.credential>
<property> <test.azureblob.identity>${test.azureblob.identity}</test.azureblob.identity>
<name>test.twitter.consumer.credential</name> <test.azureblob.credential>${test.azureblob.credential}</test.azureblob.credential>
<value>${test.twitter.gae-tweetstore.consumer.credential}</value> <test.cloudfiles-us.identity>${test.cloudfiles-us.identity}</test.cloudfiles-us.identity>
</property> <test.cloudfiles-us.credential>${test.cloudfiles-us.credential}</test.cloudfiles-us.credential>
<property> <test.aws-s3.identity>${test.aws-s3.identity}</test.aws-s3.identity>
<name>test.twitter.access.identity</name> <test.aws-s3.credential>${test.aws-s3.credential}</test.aws-s3.credential>
<value>${test.twitter.gae-tweetstore.access.identity}</value> <appengine.sdk.root>${appengine.sdk.root}</appengine.sdk.root>
</property> <test.cloudonestorage.identity>${test.cloudonestorage.identity}</test.cloudonestorage.identity>
<property> <test.cloudonestorage.credential>${test.cloudonestorage.credential}</test.cloudonestorage.credential>
<name>test.twitter.access.credential</name> <test.ninefold-storage.identity>${test.ninefold-storage.identity}</test.ninefold-storage.identity>
<value>${test.twitter.gae-tweetstore.access.credential}</value> <test.ninefold-storage.credential>${test.ninefold-storage.credential}</test.ninefold-storage.credential>
</property> <devappserver.address>${devappserver.address}</devappserver.address>
<property> <devappserver.port>${devappserver.port}</devappserver.port>
<name>test.azureblob.identity</name> <jclouds.tweetstore.blobstores>${jclouds.tweetstore.blobstores}</jclouds.tweetstore.blobstores>
<value>${test.azureblob.identity}</value> <jclouds.tweetstore.container>test.${jclouds.tweetstore.container}</jclouds.tweetstore.container>
</property> <warfile>${project.build.directory}/${project.artifactId}</warfile>
<property> </systemPropertyVariables>
<name>test.azureblob.credential</name>
<value>${test.azureblob.credential}</value>
</property>
<property>
<name>test.cloudfiles-us.identity</name>
<value>${test.cloudfiles-us.identity}</value>
</property>
<property>
<name>test.cloudfiles-us.credential</name>
<value>${test.cloudfiles-us.credential}</value>
</property>
<property>
<name>test.aws-s3.identity</name>
<value>${test.aws-s3.identity}</value>
</property>
<property>
<name>test.aws-s3.credential</name>
<value>${test.aws-s3.credential}</value>
</property>
<property>
<name>appengine.sdk.root</name>
<value>${appengine.sdk.root}</value>
</property>
<property>
<name>test.cloudonestorage.identity</name>
<value>${test.cloudonestorage.identity}</value>
</property>
<property>
<name>test.cloudonestorage.credential</name>
<value>${test.cloudonestorage.credential}</value>
</property>
<property>
<name>test.ninefold-storage.identity</name>
<value>${test.ninefold-storage.identity}</value>
</property>
<property>
<name>test.ninefold-storage.credential</name>
<value>${test.ninefold-storage.credential}</value>
</property>
<property>
<name>devappserver.address</name>
<value>${devappserver.address}</value>
</property>
<property>
<name>devappserver.port</name>
<value>${devappserver.port}</value>
</property>
<property>
<name>jclouds.tweetstore.blobstores</name>
<value>${jclouds.tweetstore.blobstores}</value>
</property>
<property>
<name>jclouds.tweetstore.container</name>
<value>test.${jclouds.tweetstore.container}</value>
</property>
<property>
<name>warfile</name>
<value>${project.build.directory}/${project.artifactId}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -85,88 +85,28 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.twitter.consumer.identity>${test.twitter.runatcloud-tweetstore.consumer.identity}</test.twitter.consumer.identity>
<name>test.twitter.consumer.identity</name> <test.twitter.consumer.credential>${test.twitter.runatcloud-tweetstore.consumer.credential}</test.twitter.consumer.credential>
<value>${test.twitter.runatcloud-tweetstore.consumer.identity}</value> <test.twitter.access.identity>${test.twitter.runatcloud-tweetstore.access.identity}</test.twitter.access.identity>
</property> <test.twitter.access.credential>${test.twitter.runatcloud-tweetstore.access.credential}</test.twitter.access.credential>
<property> <test.azureblob.identity>${test.azureblob.identity}</test.azureblob.identity>
<name>test.twitter.consumer.credential</name> <test.azureblob.credential>${test.azureblob.credential}</test.azureblob.credential>
<value>${test.twitter.runatcloud-tweetstore.consumer.credential}</value> <test.cloudfiles-us.identity>${test.cloudfiles-us.identity}</test.cloudfiles-us.identity>
</property> <test.cloudfiles-us.credential>${test.cloudfiles-us.credential}</test.cloudfiles-us.credential>
<property> <test.aws-s3.identity>${test.aws-s3.identity}</test.aws-s3.identity>
<name>test.twitter.access.identity</name> <test.aws-s3.credential>${test.aws-s3.credential}</test.aws-s3.credential>
<value>${test.twitter.runatcloud-tweetstore.access.identity}</value> <test.cloudonestorage.identity>${test.cloudonestorage.identity}</test.cloudonestorage.identity>
</property> <test.cloudonestorage.credential>${test.cloudonestorage.credential}</test.cloudonestorage.credential>
<property> <test.ninefold-storage.identity>${test.ninefold-storage.identity}</test.ninefold-storage.identity>
<name>test.twitter.access.credential</name> <test.ninefold-storage.credential>${test.ninefold-storage.credential}</test.ninefold-storage.credential>
<value>${test.twitter.runatcloud-tweetstore.access.credential}</value> <bees.address>${test.bees.address}</bees.address>
</property> <bees.port>${test.bees.port}</bees.port>
<property> <jclouds.tweetstore.blobstores>${jclouds.tweetstore.blobstores}</jclouds.tweetstore.blobstores>
<name>test.azureblob.identity</name> <jclouds.tweetstore.container>test.${jclouds.tweetstore.container}</jclouds.tweetstore.container>
<value>${test.azureblob.identity}</value> <bees.basedir>${project.build.directory}/bees</bees.basedir>
</property> <warfile>${project.build.directory}/${project.artifactId}</warfile>
<property> </systemPropertyVariables>
<name>test.azureblob.credential</name>
<value>${test.azureblob.credential}</value>
</property>
<property>
<name>test.cloudfiles-us.identity</name>
<value>${test.cloudfiles-us.identity}</value>
</property>
<property>
<name>test.cloudfiles-us.credential</name>
<value>${test.cloudfiles-us.credential}</value>
</property>
<property>
<name>test.aws-s3.identity</name>
<value>${test.aws-s3.identity}</value>
</property>
<property>
<name>test.aws-s3.credential</name>
<value>${test.aws-s3.credential}</value>
</property>
<property>
<name>test.cloudonestorage.identity</name>
<value>${test.cloudonestorage.identity}</value>
</property>
<property>
<name>test.cloudonestorage.credential</name>
<value>${test.cloudonestorage.credential}</value>
</property>
<property>
<name>test.ninefold-storage.identity</name>
<value>${test.ninefold-storage.identity}</value>
</property>
<property>
<name>test.ninefold-storage.credential</name>
<value>${test.ninefold-storage.credential}</value>
</property>
<property>
<name>bees.address</name>
<value>${test.bees.address}</value>
</property>
<property>
<name>bees.port</name>
<value>${test.bees.port}</value>
</property>
<property>
<name>jclouds.tweetstore.blobstores</name>
<value>${jclouds.tweetstore.blobstores}</value>
</property>
<property>
<name>jclouds.tweetstore.container</name>
<value>test.${jclouds.tweetstore.container}</value>
</property>
<property>
<name>bees.basedir</name>
<value>${project.build.directory}/bees</value>
</property>
<property>
<name>warfile</name>
<value>${project.build.directory}/${project.artifactId}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -136,32 +136,14 @@
<include>**/*IntegrationTest.java</include> <include>**/*IntegrationTest.java</include>
<include>**/*LiveTest.java</include> <include>**/*LiveTest.java</include>
</includes> </includes>
<systemProperties> <systemPropertyVariables>
<property> <file.encoding>UTF-8</file.encoding>
<name>file.encoding</name> <test.ssh.host>${test.ssh.host}</test.ssh.host>
<value>UTF-8</value> <test.ssh.port>${test.ssh.port}</test.ssh.port>
</property> <test.ssh.username>${test.ssh.username}</test.ssh.username>
<property> <test.ssh.keyfile>${test.ssh.keyfile}</test.ssh.keyfile>
<name>test.ssh.host</name> <test.ssh.password>${test.ssh.password}</test.ssh.password>
<value>${test.ssh.host}</value> </systemPropertyVariables>
</property>
<property>
<name>test.ssh.port</name>
<value>${test.ssh.port}</value>
</property>
<property>
<name>test.ssh.username</name>
<value>${test.ssh.username}</value>
</property>
<property>
<name>test.ssh.keyfile</name>
<value>${test.ssh.keyfile}</value>
</property>
<property>
<name>test.ssh.password</name>
<value>${test.ssh.password}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -140,32 +140,14 @@
<include>**/*IntegrationTest.java</include> <include>**/*IntegrationTest.java</include>
<include>**/*LiveTest.java</include> <include>**/*LiveTest.java</include>
</includes> </includes>
<systemProperties> <systemPropertyVariables>
<property> <file.encoding>UTF-8</file.encoding>
<name>file.encoding</name> <test.ssh.host>${test.ssh.host}</test.ssh.host>
<value>UTF-8</value> <test.ssh.port>${test.ssh.port}</test.ssh.port>
</property> <test.ssh.username>${test.ssh.username}</test.ssh.username>
<property> <test.ssh.keyfile>${test.ssh.keyfile}</test.ssh.keyfile>
<name>test.ssh.host</name> <test.ssh.password>${test.ssh.password}</test.ssh.password>
<value>${test.ssh.host}</value> </systemPropertyVariables>
</property>
<property>
<name>test.ssh.port</name>
<value>${test.ssh.port}</value>
</property>
<property>
<name>test.ssh.username</name>
<value>${test.ssh.username}</value>
</property>
<property>
<name>test.ssh.keyfile</name>
<value>${test.ssh.keyfile}</value>
</property>
<property>
<name>test.ssh.password</name>
<value>${test.ssh.password}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -349,16 +349,10 @@
<value>${jclouds.test.listener}</value> <value>${jclouds.test.listener}</value>
</property> </property>
</properties> </properties>
<systemProperties> <systemPropertyVariables>
<property> <jclouds.wire.httpstream.url>${jclouds.wire.httpstream.url}</jclouds.wire.httpstream.url>
<name>jclouds.wire.httpstream.url</name> <jclouds.wire.httpstream.md5>${jclouds.wire.httpstream.md5}</jclouds.wire.httpstream.md5>
<value>${jclouds.wire.httpstream.url}</value> </systemPropertyVariables>
</property>
<property>
<name>jclouds.wire.httpstream.md5</name>
<value>${jclouds.wire.httpstream.md5}</value>
</property>
</systemProperties>
</configuration> </configuration>
</plugin> </plugin>
<!-- make sure we generate src jars too --> <!-- make sure we generate src jars too -->
@ -572,29 +566,17 @@ pageTracker._trackPageview();
<include>**/*IntegrationTest.java</include> <include>**/*IntegrationTest.java</include>
<include>**/*LiveTest.java</include> <include>**/*LiveTest.java</include>
</includes> </includes>
<systemProperties> <systemPropertyVariables>
<!-- <!--
If you're behind a proxy, set this here If you're behind a proxy, set this here
http://java.sun.com/javase/6/docs/technotes/guides/net/proxies.html http://java.sun.com/javase/6/docs/technotes/guides/net/proxies.html
<property> <https.proxyHost>proxy</https.proxyHost>
<name>https.proxyHost</name> <https.proxyPort>port</https.proxyPort>
<value>proxy</value> <https.noProxyHosts>localhost|10.150.4.49</https.noProxyHosts>
</property> -->
<property> <file.encoding>${project.build.sourceEncoding}</file.encoding>
<name>https.proxyPort</name> </systemPropertyVariables>
<value>port</value>
</property>
<property>
<name>https.noProxyHosts</name>
<value>localhost|10.150.4.49</value>
</property>
-->
<property>
<name>file.encoding</name>
<value>${project.build.sourceEncoding}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -85,44 +85,17 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.aws-cloudwatch.endpoint>${test.aws-cloudwatch.endpoint}</test.aws-cloudwatch.endpoint>
<name>test.aws-cloudwatch.endpoint</name> <test.aws-cloudwatch.apiversion>${test.aws-cloudwatch.apiversion}</test.aws-cloudwatch.apiversion>
<value>${test.aws-cloudwatch.endpoint}</value> <test.aws-cloudwatch.identity>${test.aws-cloudwatch.identity}</test.aws-cloudwatch.identity>
</property> <test.aws-cloudwatch.credential>${test.aws-cloudwatch.credential}</test.aws-cloudwatch.credential>
<property> <test.aws-cloudwatch.compute.provider>${test.aws-cloudwatch.compute.provider}</test.aws-cloudwatch.compute.provider>
<name>test.aws-cloudwatch.apiversion</name> <test.aws-cloudwatch.compute.endpoint>${test.aws-cloudwatch.compute.endpoint}</test.aws-cloudwatch.compute.endpoint>
<value>${test.aws-cloudwatch.apiversion}</value> <test.aws-cloudwatch.compute.apiversion>${test.aws-cloudwatch.compute.apiversion}</test.aws-cloudwatch.compute.apiversion>
</property> <test.aws-cloudwatch.compute.identity>${test.aws-cloudwatch.compute.identity}</test.aws-cloudwatch.compute.identity>
<property> <test.aws-cloudwatch.compute.credential>${test.aws-cloudwatch.compute.credential}</test.aws-cloudwatch.compute.credential>
<name>test.aws-cloudwatch.identity</name> </systemPropertyVariables>
<value>${test.aws-cloudwatch.identity}</value>
</property>
<property>
<name>test.aws-cloudwatch.credential</name>
<value>${test.aws-cloudwatch.credential}</value>
</property>
<property>
<name>test.aws-cloudwatch.compute.provider</name>
<value>${test.aws-cloudwatch.compute.provider}</value>
</property>
<property>
<name>test.aws-cloudwatch.compute.endpoint</name>
<value>${test.aws-cloudwatch.compute.endpoint}</value>
</property>
<property>
<name>test.aws-cloudwatch.compute.apiversion</name>
<value>${test.aws-cloudwatch.compute.apiversion}</value>
</property>
<property>
<name>test.aws-cloudwatch.compute.identity</name>
<value>${test.aws-cloudwatch.compute.identity}</value>
</property>
<property>
<name>test.aws-cloudwatch.compute.credential</name>
<value>${test.aws-cloudwatch.compute.credential}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -121,40 +121,16 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.aws-s3.endpoint>${test.aws-s3.endpoint}</test.aws-s3.endpoint>
<name>test.aws-s3.endpoint</name> <test.aws-s3.apiversion>${test.aws-s3.apiversion}</test.aws-s3.apiversion>
<value>${test.aws-s3.endpoint}</value> <test.aws-s3.identity>${test.aws-s3.identity}</test.aws-s3.identity>
</property> <test.aws-s3.credential>${test.aws-s3.credential}</test.aws-s3.credential>
<property> <test.initializer>${test.initializer}</test.initializer>
<name>test.aws-s3.apiversion</name> <jclouds.blobstore.httpstream.url>${jclouds.blobstore.httpstream.url}</jclouds.blobstore.httpstream.url>
<value>${test.aws-s3.apiversion}</value> <jclouds.blobstore.httpstream.md5>${jclouds.blobstore.httpstream.md5}</jclouds.blobstore.httpstream.md5>
</property> <test.blobstore.container-count>${test.blobstore.container-count}</test.blobstore.container-count>
<property> </systemPropertyVariables>
<name>test.aws-s3.identity</name>
<value>${test.aws-s3.identity}</value>
</property>
<property>
<name>test.aws-s3.credential</name>
<value>${test.aws-s3.credential}</value>
</property>
<property>
<name>test.initializer</name>
<value>${test.initializer}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.url</name>
<value>${jclouds.blobstore.httpstream.url}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.md5</name>
<value>${jclouds.blobstore.httpstream.md5}</value>
</property>
<property>
<name>test.blobstore.container-count</name>
<value>${test.blobstore.container-count}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -98,36 +98,15 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.azureblob.endpoint>${test.azureblob.endpoint}</test.azureblob.endpoint>
<name>test.azureblob.endpoint</name> <test.azureblob.apiversion>${test.azureblob.apiversion}</test.azureblob.apiversion>
<value>${test.azureblob.endpoint}</value> <test.azureblob.identity>${test.azureblob.identity}</test.azureblob.identity>
</property> <test.azureblob.credential>${test.azureblob.credential}</test.azureblob.credential>
<property> <test.initializer>${test.initializer}</test.initializer>
<name>test.azureblob.apiversion</name> <jclouds.blobstore.httpstream.url>${jclouds.blobstore.httpstream.url}</jclouds.blobstore.httpstream.url>
<value>${test.azureblob.apiversion}</value> <jclouds.blobstore.httpstream.md5>${jclouds.blobstore.httpstream.md5}</jclouds.blobstore.httpstream.md5>
</property> </systemPropertyVariables>
<property>
<name>test.azureblob.identity</name>
<value>${test.azureblob.identity}</value>
</property>
<property>
<name>test.azureblob.credential</name>
<value>${test.azureblob.credential}</value>
</property>
<property>
<name>test.initializer</name>
<value>${test.initializer}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.url</name>
<value>${jclouds.blobstore.httpstream.url}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.md5</name>
<value>${jclouds.blobstore.httpstream.md5}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -107,36 +107,15 @@
</goals> </goals>
<configuration> <configuration>
<threadCount>1</threadCount> <threadCount>1</threadCount>
<systemProperties> <systemPropertyVariables>
<property> <test.cloudfiles-uk.endpoint>${test.cloudfiles-uk.endpoint}</test.cloudfiles-uk.endpoint>
<name>test.cloudfiles-uk.endpoint</name> <test.cloudfiles-uk.apiversion>${test.cloudfiles-uk.apiversion}</test.cloudfiles-uk.apiversion>
<value>${test.cloudfiles-uk.endpoint}</value> <test.cloudfiles-uk.identity>${test.cloudfiles-uk.identity}</test.cloudfiles-uk.identity>
</property> <test.cloudfiles-uk.credential>${test.cloudfiles-uk.credential}</test.cloudfiles-uk.credential>
<property> <test.initializer>${test.initializer}</test.initializer>
<name>test.cloudfiles-uk.apiversion</name> <jclouds.blobstore.httpstream.url>${jclouds.blobstore.httpstream.url}</jclouds.blobstore.httpstream.url>
<value>${test.cloudfiles-uk.apiversion}</value> <jclouds.blobstore.httpstream.md5>${jclouds.blobstore.httpstream.md5}</jclouds.blobstore.httpstream.md5>
</property> </systemPropertyVariables>
<property>
<name>test.cloudfiles-uk.identity</name>
<value>${test.cloudfiles-uk.identity}</value>
</property>
<property>
<name>test.cloudfiles-uk.credential</name>
<value>${test.cloudfiles-uk.credential}</value>
</property>
<property>
<name>test.initializer</name>
<value>${test.initializer}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.url</name>
<value>${jclouds.blobstore.httpstream.url}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.md5</name>
<value>${jclouds.blobstore.httpstream.md5}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -107,36 +107,15 @@
</goals> </goals>
<configuration> <configuration>
<threadCount>1</threadCount> <threadCount>1</threadCount>
<systemProperties> <systemPropertyVariables>
<property> <test.cloudfiles-us.endpoint>${test.cloudfiles-us.endpoint}</test.cloudfiles-us.endpoint>
<name>test.cloudfiles-us.endpoint</name> <test.cloudfiles-us.apiversion>${test.cloudfiles-us.apiversion}</test.cloudfiles-us.apiversion>
<value>${test.cloudfiles-us.endpoint}</value> <test.cloudfiles-us.identity>${test.cloudfiles-us.identity}</test.cloudfiles-us.identity>
</property> <test.cloudfiles-us.credential>${test.cloudfiles-us.credential}</test.cloudfiles-us.credential>
<property> <test.initializer>${test.initializer}</test.initializer>
<name>test.cloudfiles-us.apiversion</name> <jclouds.blobstore.httpstream.url>${jclouds.blobstore.httpstream.url}</jclouds.blobstore.httpstream.url>
<value>${test.cloudfiles-us.apiversion}</value> <jclouds.blobstore.httpstream.md5>${jclouds.blobstore.httpstream.md5}</jclouds.blobstore.httpstream.md5>
</property> </systemPropertyVariables>
<property>
<name>test.cloudfiles-us.identity</name>
<value>${test.cloudfiles-us.identity}</value>
</property>
<property>
<name>test.cloudfiles-us.credential</name>
<value>${test.cloudfiles-us.credential}</value>
</property>
<property>
<name>test.initializer</name>
<value>${test.initializer}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.url</name>
<value>${jclouds.blobstore.httpstream.url}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.md5</name>
<value>${jclouds.blobstore.httpstream.md5}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -107,24 +107,12 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.cloudloadbalancers-uk.endpoint>${test.cloudloadbalancers-uk.endpoint}</test.cloudloadbalancers-uk.endpoint>
<name>test.cloudloadbalancers-uk.endpoint</name> <test.cloudloadbalancers-uk.apiversion>${test.cloudloadbalancers-uk.apiversion}</test.cloudloadbalancers-uk.apiversion>
<value>${test.cloudloadbalancers-uk.endpoint}</value> <test.cloudloadbalancers-uk.identity>${test.cloudloadbalancers-uk.identity}</test.cloudloadbalancers-uk.identity>
</property> <test.cloudloadbalancers-uk.credential>${test.cloudloadbalancers-uk.credential}</test.cloudloadbalancers-uk.credential>
<property> </systemPropertyVariables>
<name>test.cloudloadbalancers-uk.apiversion</name>
<value>${test.cloudloadbalancers-uk.apiversion}</value>
</property>
<property>
<name>test.cloudloadbalancers-uk.identity</name>
<value>${test.cloudloadbalancers-uk.identity}</value>
</property>
<property>
<name>test.cloudloadbalancers-uk.credential</name>
<value>${test.cloudloadbalancers-uk.credential}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -107,24 +107,12 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.cloudloadbalancers-us.endpoint>${test.cloudloadbalancers-us.endpoint}</test.cloudloadbalancers-us.endpoint>
<name>test.cloudloadbalancers-us.endpoint</name> <test.cloudloadbalancers-us.apiversion>${test.cloudloadbalancers-us.apiversion}</test.cloudloadbalancers-us.apiversion>
<value>${test.cloudloadbalancers-us.endpoint}</value> <test.cloudloadbalancers-us.identity>${test.cloudloadbalancers-us.identity}</test.cloudloadbalancers-us.identity>
</property> <test.cloudloadbalancers-us.credential>${test.cloudloadbalancers-us.credential}</test.cloudloadbalancers-us.credential>
<property> </systemPropertyVariables>
<name>test.cloudloadbalancers-us.apiversion</name>
<value>${test.cloudloadbalancers-us.apiversion}</value>
</property>
<property>
<name>test.cloudloadbalancers-us.identity</name>
<value>${test.cloudloadbalancers-us.identity}</value>
</property>
<property>
<name>test.cloudloadbalancers-us.credential</name>
<value>${test.cloudloadbalancers-us.credential}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -100,36 +100,15 @@
</goals> </goals>
<configuration> <configuration>
<threadCount>1</threadCount> <threadCount>1</threadCount>
<systemProperties> <systemPropertyVariables>
<property> <test.cloudonestorage.endpoint>${test.cloudonestorage.endpoint}</test.cloudonestorage.endpoint>
<name>test.cloudonestorage.endpoint</name> <test.cloudonestorage.apiversion>${test.cloudonestorage.apiversion}</test.cloudonestorage.apiversion>
<value>${test.cloudonestorage.endpoint}</value> <test.cloudonestorage.identity>${test.cloudonestorage.identity}</test.cloudonestorage.identity>
</property> <test.cloudonestorage.credential>${test.cloudonestorage.credential}</test.cloudonestorage.credential>
<property> <test.initializer>${test.initializer}</test.initializer>
<name>test.cloudonestorage.apiversion</name> <jclouds.blobstore.httpstream.url>${jclouds.blobstore.httpstream.url}</jclouds.blobstore.httpstream.url>
<value>${test.cloudonestorage.apiversion}</value> <jclouds.blobstore.httpstream.md5>${jclouds.blobstore.httpstream.md5}</jclouds.blobstore.httpstream.md5>
</property> </systemPropertyVariables>
<property>
<name>test.cloudonestorage.identity</name>
<value>${test.cloudonestorage.identity}</value>
</property>
<property>
<name>test.cloudonestorage.credential</name>
<value>${test.cloudonestorage.credential}</value>
</property>
<property>
<name>test.initializer</name>
<value>${test.initializer}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.url</name>
<value>${jclouds.blobstore.httpstream.url}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.md5</name>
<value>${jclouds.blobstore.httpstream.md5}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -98,28 +98,13 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.elastichosts-lon-b.endpoint>${test.elastichosts-lon-b.endpoint}</test.elastichosts-lon-b.endpoint>
<name>test.elastichosts-lon-b.endpoint</name> <test.elastichosts-lon-b.apiversion>${test.elastichosts-lon-b.apiversion}</test.elastichosts-lon-b.apiversion>
<value>${test.elastichosts-lon-b.endpoint}</value> <test.elastichosts-lon-b.identity>${test.elastichosts-lon-b.identity}</test.elastichosts-lon-b.identity>
</property> <test.elastichosts-lon-b.credential>${test.elastichosts-lon-b.credential}</test.elastichosts-lon-b.credential>
<property> <test.elastichosts-lon-b.image-id>${test.elastichosts-lon-b.image-id}</test.elastichosts-lon-b.image-id>
<name>test.elastichosts-lon-b.apiversion</name> </systemPropertyVariables>
<value>${test.elastichosts-lon-b.apiversion}</value>
</property>
<property>
<name>test.elastichosts-lon-b.identity</name>
<value>${test.elastichosts-lon-b.identity}</value>
</property>
<property>
<name>test.elastichosts-lon-b.credential</name>
<value>${test.elastichosts-lon-b.credential}</value>
</property>
<property>
<name>test.elastichosts-lon-b.image-id</name>
<value>${test.elastichosts-lon-b.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -98,28 +98,13 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.elastichosts-lon-p.endpoint>${test.elastichosts-lon-p.endpoint}</test.elastichosts-lon-p.endpoint>
<name>test.elastichosts-lon-p.endpoint</name> <test.elastichosts-lon-p.apiversion>${test.elastichosts-lon-p.apiversion}</test.elastichosts-lon-p.apiversion>
<value>${test.elastichosts-lon-p.endpoint}</value> <test.elastichosts-lon-p.identity>${test.elastichosts-lon-p.identity}</test.elastichosts-lon-p.identity>
</property> <test.elastichosts-lon-p.credential>${test.elastichosts-lon-p.credential}</test.elastichosts-lon-p.credential>
<property> <test.elastichosts-lon-p.image-id>${test.elastichosts-lon-p.image-id}</test.elastichosts-lon-p.image-id>
<name>test.elastichosts-lon-p.apiversion</name> </systemPropertyVariables>
<value>${test.elastichosts-lon-p.apiversion}</value>
</property>
<property>
<name>test.elastichosts-lon-p.identity</name>
<value>${test.elastichosts-lon-p.identity}</value>
</property>
<property>
<name>test.elastichosts-lon-p.credential</name>
<value>${test.elastichosts-lon-p.credential}</value>
</property>
<property>
<name>test.elastichosts-lon-p.image-id</name>
<value>${test.elastichosts-lon-p.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -98,28 +98,13 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.elastichosts-sat-p.endpoint>${test.elastichosts-sat-p.endpoint}</test.elastichosts-sat-p.endpoint>
<name>test.elastichosts-sat-p.endpoint</name> <test.elastichosts-sat-p.apiversion>${test.elastichosts-sat-p.apiversion}</test.elastichosts-sat-p.apiversion>
<value>${test.elastichosts-sat-p.endpoint}</value> <test.elastichosts-sat-p.identity>${test.elastichosts-sat-p.identity}</test.elastichosts-sat-p.identity>
</property> <test.elastichosts-sat-p.credential>${test.elastichosts-sat-p.credential}</test.elastichosts-sat-p.credential>
<property> <test.elastichosts-sat-p.image-id>${test.elastichosts-sat-p.image-id}</test.elastichosts-sat-p.image-id>
<name>test.elastichosts-sat-p.apiversion</name> </systemPropertyVariables>
<value>${test.elastichosts-sat-p.apiversion}</value>
</property>
<property>
<name>test.elastichosts-sat-p.identity</name>
<value>${test.elastichosts-sat-p.identity}</value>
</property>
<property>
<name>test.elastichosts-sat-p.credential</name>
<value>${test.elastichosts-sat-p.credential}</value>
</property>
<property>
<name>test.elastichosts-sat-p.image-id</name>
<value>${test.elastichosts-sat-p.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -113,32 +113,14 @@
</goals> </goals>
<configuration> <configuration>
<threadCount>1</threadCount> <threadCount>1</threadCount>
<systemProperties> <systemPropertyVariables>
<property> <test.eucalyptus-partnercloud-ec2.endpoint>${test.eucalyptus-partnercloud-ec2.endpoint}</test.eucalyptus-partnercloud-ec2.endpoint>
<name>test.eucalyptus-partnercloud-ec2.endpoint</name> <test.eucalyptus-partnercloud-ec2.apiversion>${test.eucalyptus-partnercloud-ec2.apiversion}</test.eucalyptus-partnercloud-ec2.apiversion>
<value>${test.eucalyptus-partnercloud-ec2.endpoint}</value> <test.eucalyptus-partnercloud-ec2.identity>${test.eucalyptus-partnercloud-ec2.identity}</test.eucalyptus-partnercloud-ec2.identity>
</property> <test.eucalyptus-partnercloud-ec2.credential>${test.eucalyptus-partnercloud-ec2.credential}</test.eucalyptus-partnercloud-ec2.credential>
<property> <test.eucalyptus-partnercloud-ec2.image-id>${test.eucalyptus-partnercloud-ec2.image-id}</test.eucalyptus-partnercloud-ec2.image-id>
<name>test.eucalyptus-partnercloud-ec2.apiversion</name> <test.eucalyptus-partnercloud-ec2.virtualization-type>${test.eucalyptus-partnercloud-ec2.virtualization-type}</test.eucalyptus-partnercloud-ec2.virtualization-type>
<value>${test.eucalyptus-partnercloud-ec2.apiversion}</value> </systemPropertyVariables>
</property>
<property>
<name>test.eucalyptus-partnercloud-ec2.identity</name>
<value>${test.eucalyptus-partnercloud-ec2.identity}</value>
</property>
<property>
<name>test.eucalyptus-partnercloud-ec2.credential</name>
<value>${test.eucalyptus-partnercloud-ec2.credential}</value>
</property>
<property>
<name>test.eucalyptus-partnercloud-ec2.image-id</name>
<value>${test.eucalyptus-partnercloud-ec2.image-id}</value>
</property>
<property>
<name>test.eucalyptus-partnercloud-ec2.virtualization-type</name>
<value>${test.eucalyptus-partnercloud-ec2.virtualization-type}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -108,40 +108,16 @@
</goals> </goals>
<configuration> <configuration>
<threadCount>1</threadCount> <threadCount>1</threadCount>
<systemProperties> <systemPropertyVariables>
<property> <test.eucalyptus-partnercloud-s3.endpoint>${test.eucalyptus-partnercloud-s3.endpoint}</test.eucalyptus-partnercloud-s3.endpoint>
<name>test.eucalyptus-partnercloud-s3.endpoint</name> <test.eucalyptus-partnercloud-s3.apiversion>${test.eucalyptus-partnercloud-s3.apiversion}</test.eucalyptus-partnercloud-s3.apiversion>
<value>${test.eucalyptus-partnercloud-s3.endpoint}</value> <test.eucalyptus-partnercloud-s3.identity>${test.eucalyptus-partnercloud-s3.identity}</test.eucalyptus-partnercloud-s3.identity>
</property> <test.eucalyptus-partnercloud-s3.credential>${test.eucalyptus-partnercloud-s3.credential}</test.eucalyptus-partnercloud-s3.credential>
<property> <test.initializer>${test.initializer}</test.initializer>
<name>test.eucalyptus-partnercloud-s3.apiversion</name> <jclouds.blobstore.httpstream.url>${jclouds.blobstore.httpstream.url}</jclouds.blobstore.httpstream.url>
<value>${test.eucalyptus-partnercloud-s3.apiversion}</value> <jclouds.blobstore.httpstream.md5>${jclouds.blobstore.httpstream.md5}</jclouds.blobstore.httpstream.md5>
</property> <test.blobstore.container-count>${test.blobstore.container-count}</test.blobstore.container-count>
<property> </systemPropertyVariables>
<name>test.eucalyptus-partnercloud-s3.identity</name>
<value>${test.eucalyptus-partnercloud-s3.identity}</value>
</property>
<property>
<name>test.eucalyptus-partnercloud-s3.credential</name>
<value>${test.eucalyptus-partnercloud-s3.credential}</value>
</property>
<property>
<name>test.initializer</name>
<value>${test.initializer}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.url</name>
<value>${jclouds.blobstore.httpstream.url}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.md5</name>
<value>${jclouds.blobstore.httpstream.md5}</value>
</property>
<property>
<name>test.blobstore.container-count</name>
<value>${test.blobstore.container-count}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -98,28 +98,13 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.go2cloud-jhb1.endpoint>${test.go2cloud-jhb1.endpoint}</test.go2cloud-jhb1.endpoint>
<name>test.go2cloud-jhb1.endpoint</name> <test.go2cloud-jhb1.apiversion>${test.go2cloud-jhb1.apiversion}</test.go2cloud-jhb1.apiversion>
<value>${test.go2cloud-jhb1.endpoint}</value> <test.go2cloud-jhb1.identity>${test.go2cloud-jhb1.identity}</test.go2cloud-jhb1.identity>
</property> <test.go2cloud-jhb1.credential>${test.go2cloud-jhb1.credential}</test.go2cloud-jhb1.credential>
<property> <test.go2cloud-jhb1.image-id>${test.go2cloud-jhb1.image-id}</test.go2cloud-jhb1.image-id>
<name>test.go2cloud-jhb1.apiversion</name> </systemPropertyVariables>
<value>${test.go2cloud-jhb1.apiversion}</value>
</property>
<property>
<name>test.go2cloud-jhb1.identity</name>
<value>${test.go2cloud-jhb1.identity}</value>
</property>
<property>
<name>test.go2cloud-jhb1.credential</name>
<value>${test.go2cloud-jhb1.credential}</value>
</property>
<property>
<name>test.go2cloud-jhb1.image-id</name>
<value>${test.go2cloud-jhb1.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -91,28 +91,13 @@
</goals> </goals>
<configuration> <configuration>
<threadCount>1</threadCount> <threadCount>1</threadCount>
<systemProperties> <systemPropertyVariables>
<property> <test.gogrid.endpoint>${test.gogrid.endpoint}</test.gogrid.endpoint>
<name>test.gogrid.endpoint</name> <test.gogrid.apiversion>${test.gogrid.apiversion}</test.gogrid.apiversion>
<value>${test.gogrid.endpoint}</value> <test.gogrid.identity>${test.gogrid.identity}</test.gogrid.identity>
</property> <test.gogrid.credential>${test.gogrid.credential}</test.gogrid.credential>
<property> <test.gogrid.image-id>${test.gogrid.image-id}</test.gogrid.image-id>
<name>test.gogrid.apiversion</name> </systemPropertyVariables>
<value>${test.gogrid.apiversion}</value>
</property>
<property>
<name>test.gogrid.identity</name>
<value>${test.gogrid.identity}</value>
</property>
<property>
<name>test.gogrid.credential</name>
<value>${test.gogrid.credential}</value>
</property>
<property>
<name>test.gogrid.image-id</name>
<value>${test.gogrid.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -98,28 +98,13 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.greenhousedata-element-vcloud.endpoint>${test.greenhousedata-element-vcloud.endpoint}</test.greenhousedata-element-vcloud.endpoint>
<name>test.greenhousedata-element-vcloud.endpoint</name> <test.greenhousedata-element-vcloud.apiversion>${test.greenhousedata-element-vcloud.apiversion}</test.greenhousedata-element-vcloud.apiversion>
<value>${test.greenhousedata-element-vcloud.endpoint}</value> <test.greenhousedata-element-vcloud.identity>${test.greenhousedata-element-vcloud.identity}</test.greenhousedata-element-vcloud.identity>
</property> <test.greenhousedata-element-vcloud.credential>${test.greenhousedata-element-vcloud.credential}</test.greenhousedata-element-vcloud.credential>
<property> <test.greenhousedata-element-vcloud.image-id>${test.greenhousedata-element-vcloud.image-id}</test.greenhousedata-element-vcloud.image-id>
<name>test.greenhousedata-element-vcloud.apiversion</name> </systemPropertyVariables>
<value>${test.greenhousedata-element-vcloud.apiversion}</value>
</property>
<property>
<name>test.greenhousedata-element-vcloud.identity</name>
<value>${test.greenhousedata-element-vcloud.identity}</value>
</property>
<property>
<name>test.greenhousedata-element-vcloud.credential</name>
<value>${test.greenhousedata-element-vcloud.credential}</value>
</property>
<property>
<name>test.greenhousedata-element-vcloud.image-id</name>
<value>${test.greenhousedata-element-vcloud.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -99,36 +99,15 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.ninefold-storage.endpoint>${test.ninefold-storage.endpoint}</test.ninefold-storage.endpoint>
<name>test.ninefold-storage.endpoint</name> <test.ninefold-storage.apiversion>${test.ninefold-storage.apiversion}</test.ninefold-storage.apiversion>
<value>${test.ninefold-storage.endpoint}</value> <test.ninefold-storage.identity>${test.ninefold-storage.identity}</test.ninefold-storage.identity>
</property> <test.ninefold-storage.credential>${test.ninefold-storage.credential}</test.ninefold-storage.credential>
<property> <test.initializer>${test.initializer}</test.initializer>
<name>test.ninefold-storage.apiversion</name> <jclouds.blobstore.httpstream.url>${jclouds.blobstore.httpstream.url}</jclouds.blobstore.httpstream.url>
<value>${test.ninefold-storage.apiversion}</value> <jclouds.blobstore.httpstream.md5>${jclouds.blobstore.httpstream.md5}</jclouds.blobstore.httpstream.md5>
</property> </systemPropertyVariables>
<property>
<name>test.ninefold-storage.identity</name>
<value>${test.ninefold-storage.identity}</value>
</property>
<property>
<name>test.ninefold-storage.credential</name>
<value>${test.ninefold-storage.credential}</value>
</property>
<property>
<name>test.initializer</name>
<value>${test.initializer}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.url</name>
<value>${jclouds.blobstore.httpstream.url}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.md5</name>
<value>${jclouds.blobstore.httpstream.md5}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -98,28 +98,13 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.openhosting-east1.endpoint>${test.openhosting-east1.endpoint}</test.openhosting-east1.endpoint>
<name>test.openhosting-east1.endpoint</name> <test.openhosting-east1.apiversion>${test.openhosting-east1.apiversion}</test.openhosting-east1.apiversion>
<value>${test.openhosting-east1.endpoint}</value> <test.openhosting-east1.identity>${test.openhosting-east1.identity}</test.openhosting-east1.identity>
</property> <test.openhosting-east1.credential>${test.openhosting-east1.credential}</test.openhosting-east1.credential>
<property> <test.openhosting-east1.image-id>${test.openhosting-east1.image-id}</test.openhosting-east1.image-id>
<name>test.openhosting-east1.apiversion</name> </systemPropertyVariables>
<value>${test.openhosting-east1.apiversion}</value>
</property>
<property>
<name>test.openhosting-east1.identity</name>
<value>${test.openhosting-east1.identity}</value>
</property>
<property>
<name>test.openhosting-east1.credential</name>
<value>${test.openhosting-east1.credential}</value>
</property>
<property>
<name>test.openhosting-east1.image-id</name>
<value>${test.openhosting-east1.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -99,24 +99,12 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.rimuhosting.endpoint>${test.rimuhosting.endpoint}</test.rimuhosting.endpoint>
<name>test.rimuhosting.endpoint</name> <test.rimuhosting.apiversion>${test.rimuhosting.apiversion}</test.rimuhosting.apiversion>
<value>${test.rimuhosting.endpoint}</value> <test.rimuhosting.identity>${test.rimuhosting.identity}</test.rimuhosting.identity>
</property> <test.rimuhosting.image-id>${test.rimuhosting.image-id}</test.rimuhosting.image-id>
<property> </systemPropertyVariables>
<name>test.rimuhosting.apiversion</name>
<value>${test.rimuhosting.apiversion}</value>
</property>
<property>
<name>test.rimuhosting.identity</name>
<value>${test.rimuhosting.identity}</value>
</property>
<property>
<name>test.rimuhosting.image-id</name>
<value>${test.rimuhosting.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -112,40 +112,16 @@
</goals> </goals>
<configuration> <configuration>
<threadCount>1</threadCount> <threadCount>1</threadCount>
<systemProperties> <systemPropertyVariables>
<property> <test.savvis-symphonyvpdc.endpoint>${test.savvis-symphonyvpdc.endpoint}</test.savvis-symphonyvpdc.endpoint>
<name>test.savvis-symphonyvpdc.endpoint</name> <test.savvis-symphonyvpdc.apiversion>${test.savvis-symphonyvpdc.apiversion}</test.savvis-symphonyvpdc.apiversion>
<value>${test.savvis-symphonyvpdc.endpoint}</value> <test.savvis-symphonyvpdc.identity>${test.savvis-symphonyvpdc.identity}</test.savvis-symphonyvpdc.identity>
</property> <test.savvis-symphonyvpdc.credential>${test.savvis-symphonyvpdc.credential}</test.savvis-symphonyvpdc.credential>
<property> <test.savvis-symphonyvpdc.image-id>${test.savvis-symphonyvpdc.image-id}</test.savvis-symphonyvpdc.image-id>
<name>test.savvis-symphonyvpdc.apiversion</name> <test.savvis-symphonyvpdc.vdc-email>${test.savvis-symphonyvpdc.vdc-email}</test.savvis-symphonyvpdc.vdc-email>
<value>${test.savvis-symphonyvpdc.apiversion}</value> <test.savvis-symphonyvpdc.loginUser>${test.savvis-symphonyvpdc.loginUser}</test.savvis-symphonyvpdc.loginUser>
</property> <test.savvis-symphonyvpdc.loginPassword>${test.savvis-symphonyvpdc.loginPassword}</test.savvis-symphonyvpdc.loginPassword>
<property> </systemPropertyVariables>
<name>test.savvis-symphonyvpdc.identity</name>
<value>${test.savvis-symphonyvpdc.identity}</value>
</property>
<property>
<name>test.savvis-symphonyvpdc.credential</name>
<value>${test.savvis-symphonyvpdc.credential}</value>
</property>
<property>
<name>test.savvis-symphonyvpdc.image-id</name>
<value>${test.savvis-symphonyvpdc.image-id}</value>
</property>
<property>
<name>test.savvis-symphonyvpdc.vdc-email</name>
<value>${test.savvis-symphonyvpdc.vdc-email}</value>
</property>
<property>
<name>test.savvis-symphonyvpdc.loginUser</name>
<value>${test.savvis-symphonyvpdc.loginUser}</value>
</property>
<property>
<name>test.savvis-symphonyvpdc.loginPassword</name>
<value>${test.savvis-symphonyvpdc.loginPassword}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -98,28 +98,13 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.serverlove-z1-man.endpoint>${test.serverlove-z1-man.endpoint}</test.serverlove-z1-man.endpoint>
<name>test.serverlove-z1-man.endpoint</name> <test.serverlove-z1-man.apiversion>${test.serverlove-z1-man.apiversion}</test.serverlove-z1-man.apiversion>
<value>${test.serverlove-z1-man.endpoint}</value> <test.serverlove-z1-man.identity>${test.serverlove-z1-man.identity}</test.serverlove-z1-man.identity>
</property> <test.serverlove-z1-man.credential>${test.serverlove-z1-man.credential}</test.serverlove-z1-man.credential>
<property> <test.serverlove-z1-man.image-id>${test.serverlove-z1-man.image-id}</test.serverlove-z1-man.image-id>
<name>test.serverlove-z1-man.apiversion</name> </systemPropertyVariables>
<value>${test.serverlove-z1-man.apiversion}</value>
</property>
<property>
<name>test.serverlove-z1-man.identity</name>
<value>${test.serverlove-z1-man.identity}</value>
</property>
<property>
<name>test.serverlove-z1-man.credential</name>
<value>${test.serverlove-z1-man.credential}</value>
</property>
<property>
<name>test.serverlove-z1-man.image-id</name>
<value>${test.serverlove-z1-man.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -98,28 +98,13 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.skalicloud-sdg-my.endpoint>${test.skalicloud-sdg-my.endpoint}</test.skalicloud-sdg-my.endpoint>
<name>test.skalicloud-sdg-my.endpoint</name> <test.skalicloud-sdg-my.apiversion>${test.skalicloud-sdg-my.apiversion}</test.skalicloud-sdg-my.apiversion>
<value>${test.skalicloud-sdg-my.endpoint}</value> <test.skalicloud-sdg-my.identity>${test.skalicloud-sdg-my.identity}</test.skalicloud-sdg-my.identity>
</property> <test.skalicloud-sdg-my.credential>${test.skalicloud-sdg-my.credential}</test.skalicloud-sdg-my.credential>
<property> <test.skalicloud-sdg-my.image-id>${test.skalicloud-sdg-my.image-id}</test.skalicloud-sdg-my.image-id>
<name>test.skalicloud-sdg-my.apiversion</name> </systemPropertyVariables>
<value>${test.skalicloud-sdg-my.apiversion}</value>
</property>
<property>
<name>test.skalicloud-sdg-my.identity</name>
<value>${test.skalicloud-sdg-my.identity}</value>
</property>
<property>
<name>test.skalicloud-sdg-my.credential</name>
<value>${test.skalicloud-sdg-my.credential}</value>
</property>
<property>
<name>test.skalicloud-sdg-my.image-id</name>
<value>${test.skalicloud-sdg-my.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -91,24 +91,12 @@
<configuration> <configuration>
<!-- beat up the slicehost server less --> <!-- beat up the slicehost server less -->
<threadCount>1</threadCount> <threadCount>1</threadCount>
<systemProperties> <systemPropertyVariables>
<property> <test.slicehost.endpoint>${test.slicehost.endpoint}</test.slicehost.endpoint>
<name>test.slicehost.endpoint</name> <test.slicehost.apiversion>${test.slicehost.apiversion}</test.slicehost.apiversion>
<value>${test.slicehost.endpoint}</value> <test.slicehost.identity>${test.slicehost.identity}</test.slicehost.identity>
</property> <test.slicehost.image-id>${test.slicehost.image-id}</test.slicehost.image-id>
<property> </systemPropertyVariables>
<name>test.slicehost.apiversion</name>
<value>${test.slicehost.apiversion}</value>
</property>
<property>
<name>test.slicehost.identity</name>
<value>${test.slicehost.identity}</value>
</property>
<property>
<name>test.slicehost.image-id</name>
<value>${test.slicehost.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -98,28 +98,13 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.stratogen-vcloud-mycloud.endpoint>${test.stratogen-vcloud-mycloud.endpoint}</test.stratogen-vcloud-mycloud.endpoint>
<name>test.stratogen-vcloud-mycloud.endpoint</name> <test.stratogen-vcloud-mycloud.apiversion>${test.stratogen-vcloud-mycloud.apiversion}</test.stratogen-vcloud-mycloud.apiversion>
<value>${test.stratogen-vcloud-mycloud.endpoint}</value> <test.stratogen-vcloud-mycloud.identity>${test.stratogen-vcloud-mycloud.identity}</test.stratogen-vcloud-mycloud.identity>
</property> <test.stratogen-vcloud-mycloud.credential>${test.stratogen-vcloud-mycloud.credential}</test.stratogen-vcloud-mycloud.credential>
<property> <test.stratogen-vcloud-mycloud.image-id>${test.stratogen-vcloud-mycloud.image-id}</test.stratogen-vcloud-mycloud.image-id>
<name>test.stratogen-vcloud-mycloud.apiversion</name> </systemPropertyVariables>
<value>${test.stratogen-vcloud-mycloud.apiversion}</value>
</property>
<property>
<name>test.stratogen-vcloud-mycloud.identity</name>
<value>${test.stratogen-vcloud-mycloud.identity}</value>
</property>
<property>
<name>test.stratogen-vcloud-mycloud.credential</name>
<value>${test.stratogen-vcloud-mycloud.credential}</value>
</property>
<property>
<name>test.stratogen-vcloud-mycloud.image-id</name>
<value>${test.stratogen-vcloud-mycloud.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -99,36 +99,15 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.synaptic-storage.endpoint>${test.synaptic-storage.endpoint}</test.synaptic-storage.endpoint>
<name>test.synaptic-storage.endpoint</name> <test.synaptic-storage.apiversion>${test.synaptic-storage.apiversion}</test.synaptic-storage.apiversion>
<value>${test.synaptic-storage.endpoint}</value> <test.synaptic-storage.identity>${test.synaptic-storage.identity}</test.synaptic-storage.identity>
</property> <test.synaptic-storage.credential>${test.synaptic-storage.credential}</test.synaptic-storage.credential>
<property> <test.initializer>${test.initializer}</test.initializer>
<name>test.synaptic-storage.apiversion</name> <jclouds.blobstore.httpstream.url>${jclouds.blobstore.httpstream.url}</jclouds.blobstore.httpstream.url>
<value>${test.synaptic-storage.apiversion}</value> <jclouds.blobstore.httpstream.md5>${jclouds.blobstore.httpstream.md5}</jclouds.blobstore.httpstream.md5>
</property> </systemPropertyVariables>
<property>
<name>test.synaptic-storage.identity</name>
<value>${test.synaptic-storage.identity}</value>
</property>
<property>
<name>test.synaptic-storage.credential</name>
<value>${test.synaptic-storage.credential}</value>
</property>
<property>
<name>test.initializer</name>
<value>${test.initializer}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.url</name>
<value>${jclouds.blobstore.httpstream.url}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.md5</name>
<value>${jclouds.blobstore.httpstream.md5}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -100,32 +100,14 @@
</goals> </goals>
<configuration> <configuration>
<threadCount>1</threadCount> <threadCount>1</threadCount>
<systemProperties> <systemPropertyVariables>
<property> <test.trmk-ecloud.endpoint>${test.trmk-ecloud.endpoint}</test.trmk-ecloud.endpoint>
<name>test.trmk-ecloud.endpoint</name> <test.trmk-ecloud.apiversion>${test.trmk-ecloud.apiversion}</test.trmk-ecloud.apiversion>
<value>${test.trmk-ecloud.endpoint}</value> <test.trmk-ecloud.identity>${test.trmk-ecloud.identity}</test.trmk-ecloud.identity>
</property> <test.trmk-ecloud.credential>${test.trmk-ecloud.credential}</test.trmk-ecloud.credential>
<property> <test.trmk-ecloud.datacenter>${test.trmk-ecloud.datacenter}</test.trmk-ecloud.datacenter>
<name>test.trmk-ecloud.apiversion</name> <test.trmk-ecloud.image-id>${test.trmk-ecloud.image-id}</test.trmk-ecloud.image-id>
<value>${test.trmk-ecloud.apiversion}</value> </systemPropertyVariables>
</property>
<property>
<name>test.trmk-ecloud.identity</name>
<value>${test.trmk-ecloud.identity}</value>
</property>
<property>
<name>test.trmk-ecloud.credential</name>
<value>${test.trmk-ecloud.credential}</value>
</property>
<property>
<name>test.trmk-ecloud.datacenter</name>
<value>${test.trmk-ecloud.datacenter}</value>
</property>
<property>
<name>test.trmk-ecloud.image-id</name>
<value>${test.trmk-ecloud.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -99,28 +99,13 @@
</goals> </goals>
<configuration> <configuration>
<threadCount>1</threadCount> <threadCount>1</threadCount>
<systemProperties> <systemPropertyVariables>
<property> <test.trmk-vcloudexpress.endpoint>${test.trmk-vcloudexpress.endpoint}</test.trmk-vcloudexpress.endpoint>
<name>test.trmk-vcloudexpress.endpoint</name> <test.trmk-vcloudexpress.apiversion>${test.trmk-vcloudexpress.apiversion}</test.trmk-vcloudexpress.apiversion>
<value>${test.trmk-vcloudexpress.endpoint}</value> <test.trmk-vcloudexpress.identity>${test.trmk-vcloudexpress.identity}</test.trmk-vcloudexpress.identity>
</property> <test.trmk-vcloudexpress.credential>${test.trmk-vcloudexpress.credential}</test.trmk-vcloudexpress.credential>
<property> <test.trmk-vcloudexpress.image-id>${test.trmk-vcloudexpress.image-id}</test.trmk-vcloudexpress.image-id>
<name>test.trmk-vcloudexpress.apiversion</name> </systemPropertyVariables>
<value>${test.trmk-vcloudexpress.apiversion}</value>
</property>
<property>
<name>test.trmk-vcloudexpress.identity</name>
<value>${test.trmk-vcloudexpress.identity}</value>
</property>
<property>
<name>test.trmk-vcloudexpress.credential</name>
<value>${test.trmk-vcloudexpress.credential}</value>
</property>
<property>
<name>test.trmk-vcloudexpress.image-id</name>
<value>${test.trmk-vcloudexpress.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -114,52 +114,19 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.elb.zone>${test.elb.zone}</test.elb.zone>
<name>test.elb.zone</name> <test.elb.endpoint>${test.elb.endpoint}</test.elb.endpoint>
<value>${test.elb.zone}</value> <test.elb.apiversion>${test.elb.apiversion}</test.elb.apiversion>
</property> <test.elb.identity>${test.elb.identity}</test.elb.identity>
<property> <test.elb.credential>${test.elb.credential}</test.elb.credential>
<name>test.elb.endpoint</name> <test.elb.compute.provider>${test.elb.compute.provider}</test.elb.compute.provider>
<value>${test.elb.endpoint}</value> <test.elb.compute.endpoint>${test.elb.compute.endpoint}</test.elb.compute.endpoint>
</property> <test.elb.compute.apiversion>${test.elb.compute.apiversion}</test.elb.compute.apiversion>
<property> <test.elb.compute.identity>${test.elb.compute.identity}</test.elb.compute.identity>
<name>test.elb.apiversion</name> <test.elb.compute.credential>${test.elb.compute.credential}</test.elb.compute.credential>
<value>${test.elb.apiversion}</value> <test.elb.compute.image-id>${test.elb.compute.image-id}</test.elb.compute.image-id>
</property> </systemPropertyVariables>
<property>
<name>test.elb.identity</name>
<value>${test.elb.identity}</value>
</property>
<property>
<name>test.elb.credential</name>
<value>${test.elb.credential}</value>
</property>
<property>
<name>test.elb.compute.provider</name>
<value>${test.elb.compute.provider}</value>
</property>
<property>
<name>test.elb.compute.endpoint</name>
<value>${test.elb.compute.endpoint}</value>
</property>
<property>
<name>test.elb.compute.apiversion</name>
<value>${test.elb.compute.apiversion}</value>
</property>
<property>
<name>test.elb.compute.identity</name>
<value>${test.elb.compute.identity}</value>
</property>
<property>
<name>test.elb.compute.credential</name>
<value>${test.elb.compute.credential}</value>
</property>
<property>
<name>test.elb.compute.image-id</name>
<value>${test.elb.compute.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -124,28 +124,13 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.libvirt.endpoint>${test.libvirt.endpoint}</test.libvirt.endpoint>
<name>test.libvirt.endpoint</name> <test.libvirt.apiversion>${test.libvirt.apiversion}</test.libvirt.apiversion>
<value>${test.libvirt.endpoint}</value> <test.libvirt.identity>${test.libvirt.identity}</test.libvirt.identity>
</property> <test.libvirt.credential>${test.libvirt.credential}</test.libvirt.credential>
<property> <test.libvirt.image-id>${test.libvirt.image-id}</test.libvirt.image-id>
<name>test.libvirt.apiversion</name> </systemPropertyVariables>
<value>${test.libvirt.apiversion}</value>
</property>
<property>
<name>test.libvirt.identity</name>
<value>${test.libvirt.identity}</value>
</property>
<property>
<name>test.libvirt.credential</name>
<value>${test.libvirt.credential}</value>
</property>
<property>
<name>test.libvirt.image-id</name>
<value>${test.libvirt.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -104,24 +104,12 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.nirvanix.endpoint>${test.nirvanix.endpoint}</test.nirvanix.endpoint>
<name>test.nirvanix.endpoint</name> <test.nirvanix.apiversion>${test.nirvanix.apiversion}</test.nirvanix.apiversion>
<value>${test.nirvanix.endpoint}</value> <test.nirvanix.identity>${test.nirvanix.identity}</test.nirvanix.identity>
</property> <test.nirvanix.credential>${test.nirvanix.credential}</test.nirvanix.credential>
<property> </systemPropertyVariables>
<name>test.nirvanix.apiversion</name>
<value>${test.nirvanix.apiversion}</value>
</property>
<property>
<name>test.nirvanix.identity</name>
<value>${test.nirvanix.identity}</value>
</property>
<property>
<name>test.nirvanix.credential</name>
<value>${test.nirvanix.credential}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -104,24 +104,12 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.pcs.endpoint>${test.pcs.endpoint}</test.pcs.endpoint>
<name>test.pcs.endpoint</name> <test.pcs.apiversion>${test.pcs.apiversion}</test.pcs.apiversion>
<value>${test.pcs.endpoint}</value> <test.pcs.identity>${test.pcs.identity}</test.pcs.identity>
</property> <test.pcs.credential>${test.pcs.credential}</test.pcs.credential>
<property> </systemPropertyVariables>
<name>test.pcs.apiversion</name>
<value>${test.pcs.apiversion}</value>
</property>
<property>
<name>test.pcs.identity</name>
<value>${test.pcs.identity}</value>
</property>
<property>
<name>test.pcs.credential</name>
<value>${test.pcs.credential}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -99,36 +99,15 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.scality-rs2.endpoint>${test.scality-rs2.endpoint}</test.scality-rs2.endpoint>
<name>test.scality-rs2.endpoint</name> <test.scality-rs2.apiversion>${test.scality-rs2.apiversion}</test.scality-rs2.apiversion>
<value>${test.scality-rs2.endpoint}</value> <test.scality-rs2.identity>${test.scality-rs2.identity}</test.scality-rs2.identity>
</property> <test.scality-rs2.credential>${test.scality-rs2.credential}</test.scality-rs2.credential>
<property> <test.initializer>${test.initializer}</test.initializer>
<name>test.scality-rs2.apiversion</name> <jclouds.blobstore.httpstream.url>${jclouds.blobstore.httpstream.url}</jclouds.blobstore.httpstream.url>
<value>${test.scality-rs2.apiversion}</value> <jclouds.blobstore.httpstream.md5>${jclouds.blobstore.httpstream.md5}</jclouds.blobstore.httpstream.md5>
</property> </systemPropertyVariables>
<property>
<name>test.scality-rs2.identity</name>
<value>${test.scality-rs2.identity}</value>
</property>
<property>
<name>test.scality-rs2.credential</name>
<value>${test.scality-rs2.credential}</value>
</property>
<property>
<name>test.initializer</name>
<value>${test.initializer}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.url</name>
<value>${jclouds.blobstore.httpstream.url}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.md5</name>
<value>${jclouds.blobstore.httpstream.md5}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -77,24 +77,12 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.simpledb.endpoint>${test.simpledb.endpoint}</test.simpledb.endpoint>
<name>test.simpledb.endpoint</name> <test.simpledb.apiversion>${test.simpledb.apiversion}</test.simpledb.apiversion>
<value>${test.simpledb.endpoint}</value> <test.simpledb.identity>${test.simpledb.identity}</test.simpledb.identity>
</property> <test.simpledb.credential>${test.simpledb.credential}</test.simpledb.credential>
<property> </systemPropertyVariables>
<name>test.simpledb.apiversion</name>
<value>${test.simpledb.apiversion}</value>
</property>
<property>
<name>test.simpledb.identity</name>
<value>${test.simpledb.identity}</value>
</property>
<property>
<name>test.simpledb.credential</name>
<value>${test.simpledb.credential}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -77,24 +77,12 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.sqs.endpoint>${test.sqs.endpoint}</test.sqs.endpoint>
<name>test.sqs.endpoint</name> <test.sqs.apiversion>${test.sqs.apiversion}</test.sqs.apiversion>
<value>${test.sqs.endpoint}</value> <test.sqs.identity>${test.sqs.identity}</test.sqs.identity>
</property> <test.sqs.credential>${test.sqs.credential}</test.sqs.credential>
<property> </systemPropertyVariables>
<name>test.sqs.apiversion</name>
<value>${test.sqs.apiversion}</value>
</property>
<property>
<name>test.sqs.identity</name>
<value>${test.sqs.identity}</value>
</property>
<property>
<name>test.sqs.credential</name>
<value>${test.sqs.credential}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -121,48 +121,18 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.aws-elb.endpoint>${test.aws-elb.endpoint}</test.aws-elb.endpoint>
<name>test.aws-elb.endpoint</name> <test.aws-elb.apiversion>${test.aws-elb.apiversion}</test.aws-elb.apiversion>
<value>${test.aws-elb.endpoint}</value> <test.aws-elb.identity>${test.aws-elb.identity}</test.aws-elb.identity>
</property> <test.aws-elb.credential>${test.aws-elb.credential}</test.aws-elb.credential>
<property> <test.aws-elb.compute.provider>${test.aws-elb.compute.provider}</test.aws-elb.compute.provider>
<name>test.aws-elb.apiversion</name> <test.aws-elb.compute.endpoint>${test.aws-elb.compute.endpoint}</test.aws-elb.compute.endpoint>
<value>${test.aws-elb.apiversion}</value> <test.aws-elb.compute.apiversion>${test.aws-elb.compute.apiversion}</test.aws-elb.compute.apiversion>
</property> <test.aws-elb.compute.identity>${test.aws-elb.compute.identity}</test.aws-elb.compute.identity>
<property> <test.aws-elb.compute.credential>${test.aws-elb.compute.credential}</test.aws-elb.compute.credential>
<name>test.aws-elb.identity</name> <test.aws-elb.compute.image-id>${test.aws-elb.compute.image-id}</test.aws-elb.compute.image-id>
<value>${test.aws-elb.identity}</value> </systemPropertyVariables>
</property>
<property>
<name>test.aws-elb.credential</name>
<value>${test.aws-elb.credential}</value>
</property>
<property>
<name>test.aws-elb.compute.provider</name>
<value>${test.aws-elb.compute.provider}</value>
</property>
<property>
<name>test.aws-elb.compute.endpoint</name>
<value>${test.aws-elb.compute.endpoint}</value>
</property>
<property>
<name>test.aws-elb.compute.apiversion</name>
<value>${test.aws-elb.compute.apiversion}</value>
</property>
<property>
<name>test.aws-elb.compute.identity</name>
<value>${test.aws-elb.compute.identity}</value>
</property>
<property>
<name>test.aws-elb.compute.credential</name>
<value>${test.aws-elb.compute.credential}</value>
</property>
<property>
<name>test.aws-elb.compute.image-id</name>
<value>${test.aws-elb.compute.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -91,24 +91,12 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.aws-simpledb.endpoint>${test.aws-simpledb.endpoint}</test.aws-simpledb.endpoint>
<name>test.aws-simpledb.endpoint</name> <test.aws-simpledb.apiversion>${test.aws-simpledb.apiversion}</test.aws-simpledb.apiversion>
<value>${test.aws-simpledb.endpoint}</value> <test.aws-simpledb.identity>${test.aws-simpledb.identity}</test.aws-simpledb.identity>
</property> <test.aws-simpledb.credential>${test.aws-simpledb.credential}</test.aws-simpledb.credential>
<property> </systemPropertyVariables>
<name>test.aws-simpledb.apiversion</name>
<value>${test.aws-simpledb.apiversion}</value>
</property>
<property>
<name>test.aws-simpledb.identity</name>
<value>${test.aws-simpledb.identity}</value>
</property>
<property>
<name>test.aws-simpledb.credential</name>
<value>${test.aws-simpledb.credential}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -84,24 +84,12 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.azurequeue.endpoint>${test.azurequeue.endpoint}</test.azurequeue.endpoint>
<name>test.azurequeue.endpoint</name> <test.azurequeue.apiversion>${test.azurequeue.apiversion}</test.azurequeue.apiversion>
<value>${test.azurequeue.endpoint}</value> <test.azurequeue.identity>${test.azurequeue.identity}</test.azurequeue.identity>
</property> <test.azurequeue.credential>${test.azurequeue.credential}</test.azurequeue.credential>
<property> </systemPropertyVariables>
<name>test.azurequeue.apiversion</name>
<value>${test.azurequeue.apiversion}</value>
</property>
<property>
<name>test.azurequeue.identity</name>
<value>${test.azurequeue.identity}</value>
</property>
<property>
<name>test.azurequeue.credential</name>
<value>${test.azurequeue.credential}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -95,24 +95,12 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.boxdotnet.endpoint>${test.boxdotnet.endpoint}</test.boxdotnet.endpoint>
<name>test.boxdotnet.endpoint</name> <test.boxdotnet.apiversion>${test.boxdotnet.apiversion}</test.boxdotnet.apiversion>
<value>${test.boxdotnet.endpoint}</value> <test.boxdotnet.identity>${test.boxdotnet.identity}</test.boxdotnet.identity>
</property> <test.boxdotnet.credential>${test.boxdotnet.credential}</test.boxdotnet.credential>
<property> </systemPropertyVariables>
<name>test.boxdotnet.apiversion</name>
<value>${test.boxdotnet.apiversion}</value>
</property>
<property>
<name>test.boxdotnet.identity</name>
<value>${test.boxdotnet.identity}</value>
</property>
<property>
<name>test.boxdotnet.credential</name>
<value>${test.boxdotnet.credential}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -97,28 +97,13 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.dunkel-vcd.endpoint>${test.dunkel-vcd.endpoint}</test.dunkel-vcd.endpoint>
<name>test.dunkel-vcd.endpoint</name> <test.dunkel-vcd.apiversion>${test.dunkel-vcd.apiversion}</test.dunkel-vcd.apiversion>
<value>${test.dunkel-vcd.endpoint}</value> <test.dunkel-vcd.identity>${test.dunkel-vcd.identity}</test.dunkel-vcd.identity>
</property> <test.dunkel-vcd.credential>${test.dunkel-vcd.credential}</test.dunkel-vcd.credential>
<property> <test.dunkel-vcd.image-id>${test.dunkel-vcd.image-id}</test.dunkel-vcd.image-id>
<name>test.dunkel-vcd.apiversion</name> </systemPropertyVariables>
<value>${test.dunkel-vcd.apiversion}</value>
</property>
<property>
<name>test.dunkel-vcd.identity</name>
<value>${test.dunkel-vcd.identity}</value>
</property>
<property>
<name>test.dunkel-vcd.credential</name>
<value>${test.dunkel-vcd.credential}</value>
</property>
<property>
<name>test.dunkel-vcd.image-id</name>
<value>${test.dunkel-vcd.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -99,36 +99,15 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.googlestorage.endpoint>${test.googlestorage.endpoint}</test.googlestorage.endpoint>
<name>test.googlestorage.endpoint</name> <test.googlestorage.apiversion>${test.googlestorage.apiversion}</test.googlestorage.apiversion>
<value>${test.googlestorage.endpoint}</value> <test.googlestorage.identity>${test.googlestorage.identity}</test.googlestorage.identity>
</property> <test.googlestorage.credential>${test.googlestorage.credential}</test.googlestorage.credential>
<property> <test.initializer>${test.initializer}</test.initializer>
<name>test.googlestorage.apiversion</name> <jclouds.blobstore.httpstream.url>${jclouds.blobstore.httpstream.url}</jclouds.blobstore.httpstream.url>
<value>${test.googlestorage.apiversion}</value> <jclouds.blobstore.httpstream.md5>${jclouds.blobstore.httpstream.md5}</jclouds.blobstore.httpstream.md5>
</property> </systemPropertyVariables>
<property>
<name>test.googlestorage.identity</name>
<value>${test.googlestorage.identity}</value>
</property>
<property>
<name>test.googlestorage.credential</name>
<value>${test.googlestorage.credential}</value>
</property>
<property>
<name>test.initializer</name>
<value>${test.initializer}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.url</name>
<value>${jclouds.blobstore.httpstream.url}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.md5</name>
<value>${jclouds.blobstore.httpstream.md5}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -106,36 +106,15 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.hosteurope-storage.endpoint>${test.hosteurope-storage.endpoint}</test.hosteurope-storage.endpoint>
<name>test.hosteurope-storage.endpoint</name> <test.hosteurope-storage.apiversion>${test.hosteurope-storage.apiversion}</test.hosteurope-storage.apiversion>
<value>${test.hosteurope-storage.endpoint}</value> <test.hosteurope-storage.identity>${test.hosteurope-storage.identity}</test.hosteurope-storage.identity>
</property> <test.hosteurope-storage.credential>${test.hosteurope-storage.credential}</test.hosteurope-storage.credential>
<property> <test.initializer>${test.initializer}</test.initializer>
<name>test.hosteurope-storage.apiversion</name> <jclouds.blobstore.httpstream.url>${jclouds.blobstore.httpstream.url}</jclouds.blobstore.httpstream.url>
<value>${test.hosteurope-storage.apiversion}</value> <jclouds.blobstore.httpstream.md5>${jclouds.blobstore.httpstream.md5}</jclouds.blobstore.httpstream.md5>
</property> </systemPropertyVariables>
<property>
<name>test.hosteurope-storage.identity</name>
<value>${test.hosteurope-storage.identity}</value>
</property>
<property>
<name>test.hosteurope-storage.credential</name>
<value>${test.hosteurope-storage.credential}</value>
</property>
<property>
<name>test.initializer</name>
<value>${test.initializer}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.url</name>
<value>${jclouds.blobstore.httpstream.url}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.md5</name>
<value>${jclouds.blobstore.httpstream.md5}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -108,28 +108,13 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.ibm-smartcloud.endpoint>${test.ibm-smartcloud.endpoint}</test.ibm-smartcloud.endpoint>
<name>test.ibm-smartcloud.endpoint</name> <test.ibm-smartcloud.apiversion>${test.ibm-smartcloud.apiversion}</test.ibm-smartcloud.apiversion>
<value>${test.ibm-smartcloud.endpoint}</value> <test.ibm-smartcloud.identity>${test.ibm-smartcloud.identity}</test.ibm-smartcloud.identity>
</property> <test.ibm-smartcloud.credential>${test.ibm-smartcloud.credential}</test.ibm-smartcloud.credential>
<property> <test.ibm-smartcloud.image-id>${test.ibm-smartcloud.image-id}</test.ibm-smartcloud.image-id>
<name>test.ibm-smartcloud.apiversion</name> </systemPropertyVariables>
<value>${test.ibm-smartcloud.apiversion}</value>
</property>
<property>
<name>test.ibm-smartcloud.identity</name>
<value>${test.ibm-smartcloud.identity}</value>
</property>
<property>
<name>test.ibm-smartcloud.credential</name>
<value>${test.ibm-smartcloud.credential}</value>
</property>
<property>
<name>test.ibm-smartcloud.image-id</name>
<value>${test.ibm-smartcloud.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -106,36 +106,15 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.scaleup-storage.endpoint>${test.scaleup-storage.endpoint}</test.scaleup-storage.endpoint>
<name>test.scaleup-storage.endpoint</name> <test.scaleup-storage.apiversion>${test.scaleup-storage.apiversion}</test.scaleup-storage.apiversion>
<value>${test.scaleup-storage.endpoint}</value> <test.scaleup-storage.identity>${test.scaleup-storage.identity}</test.scaleup-storage.identity>
</property> <test.scaleup-storage.credential>${test.scaleup-storage.credential}</test.scaleup-storage.credential>
<property> <test.initializer>${test.initializer}</test.initializer>
<name>test.scaleup-storage.apiversion</name> <jclouds.blobstore.httpstream.url>${jclouds.blobstore.httpstream.url}</jclouds.blobstore.httpstream.url>
<value>${test.scaleup-storage.apiversion}</value> <jclouds.blobstore.httpstream.md5>${jclouds.blobstore.httpstream.md5}</jclouds.blobstore.httpstream.md5>
</property> </systemPropertyVariables>
<property>
<name>test.scaleup-storage.identity</name>
<value>${test.scaleup-storage.identity}</value>
</property>
<property>
<name>test.scaleup-storage.credential</name>
<value>${test.scaleup-storage.credential}</value>
</property>
<property>
<name>test.initializer</name>
<value>${test.initializer}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.url</name>
<value>${jclouds.blobstore.httpstream.url}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.md5</name>
<value>${jclouds.blobstore.httpstream.md5}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -107,36 +107,15 @@
</goals> </goals>
<configuration> <configuration>
<threadCount>1</threadCount> <threadCount>1</threadCount>
<systemProperties> <systemPropertyVariables>
<property> <test.tiscali-storage.endpoint>${test.tiscali-storage.endpoint}</test.tiscali-storage.endpoint>
<name>test.tiscali-storage.endpoint</name> <test.tiscali-storage.apiversion>${test.tiscali-storage.apiversion}</test.tiscali-storage.apiversion>
<value>${test.tiscali-storage.endpoint}</value> <test.tiscali-storage.identity>${test.tiscali-storage.identity}</test.tiscali-storage.identity>
</property> <test.tiscali-storage.credential>${test.tiscali-storage.credential}</test.tiscali-storage.credential>
<property> <test.initializer>${test.initializer}</test.initializer>
<name>test.tiscali-storage.apiversion</name> <jclouds.blobstore.httpstream.url>${jclouds.blobstore.httpstream.url}</jclouds.blobstore.httpstream.url>
<value>${test.tiscali-storage.apiversion}</value> <jclouds.blobstore.httpstream.md5>${jclouds.blobstore.httpstream.md5}</jclouds.blobstore.httpstream.md5>
</property> </systemPropertyVariables>
<property>
<name>test.tiscali-storage.identity</name>
<value>${test.tiscali-storage.identity}</value>
</property>
<property>
<name>test.tiscali-storage.credential</name>
<value>${test.tiscali-storage.credential}</value>
</property>
<property>
<name>test.initializer</name>
<value>${test.initializer}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.url</name>
<value>${jclouds.blobstore.httpstream.url}</value>
</property>
<property>
<name>jclouds.blobstore.httpstream.md5</name>
<value>${jclouds.blobstore.httpstream.md5}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -103,28 +103,13 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.tmrk-enterprisecloud.endpoint>${test.tmrk-enterprisecloud.endpoint}</test.tmrk-enterprisecloud.endpoint>
<name>test.tmrk-enterprisecloud.endpoint</name> <test.tmrk-enterprisecloud.apiversion>${test.tmrk-enterprisecloud.apiversion}</test.tmrk-enterprisecloud.apiversion>
<value>${test.tmrk-enterprisecloud.endpoint}</value> <test.tmrk-enterprisecloud.identity>${test.tmrk-enterprisecloud.identity}</test.tmrk-enterprisecloud.identity>
</property> <test.tmrk-enterprisecloud.credential>${test.tmrk-enterprisecloud.credential}</test.tmrk-enterprisecloud.credential>
<property> <test.tmrk-enterprisecloud.image-id>${test.tmrk-enterprisecloud.image-id}</test.tmrk-enterprisecloud.image-id>
<name>test.tmrk-enterprisecloud.apiversion</name> </systemPropertyVariables>
<value>${test.tmrk-enterprisecloud.apiversion}</value>
</property>
<property>
<name>test.tmrk-enterprisecloud.identity</name>
<value>${test.tmrk-enterprisecloud.identity}</value>
</property>
<property>
<name>test.tmrk-enterprisecloud.credential</name>
<value>${test.tmrk-enterprisecloud.credential}</value>
</property>
<property>
<name>test.tmrk-enterprisecloud.image-id</name>
<value>${test.tmrk-enterprisecloud.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -96,24 +96,12 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.twitter.endpoint>${test.twitter.endpoint}</test.twitter.endpoint>
<name>test.twitter.endpoint</name> <test.twitter.apiversion>${test.twitter.apiversion}</test.twitter.apiversion>
<value>${test.twitter.endpoint}</value> <test.twitter.identity>${test.twitter.identity}</test.twitter.identity>
</property> <test.twitter.credential>${test.twitter.credential}</test.twitter.credential>
<property> </systemPropertyVariables>
<name>test.twitter.apiversion</name>
<value>${test.twitter.apiversion}</value>
</property>
<property>
<name>test.twitter.identity</name>
<value>${test.twitter.identity}</value>
</property>
<property>
<name>test.twitter.credential</name>
<value>${test.twitter.credential}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -97,28 +97,13 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.virtacore-vcloudexpress.endpoint>${test.virtacore-vcloudexpress.endpoint}</test.virtacore-vcloudexpress.endpoint>
<name>test.virtacore-vcloudexpress.endpoint</name> <test.virtacore-vcloudexpress.apiversion>${test.virtacore-vcloudexpress.apiversion}</test.virtacore-vcloudexpress.apiversion>
<value>${test.virtacore-vcloudexpress.endpoint}</value> <test.virtacore-vcloudexpress.identity>${test.virtacore-vcloudexpress.identity}</test.virtacore-vcloudexpress.identity>
</property> <test.virtacore-vcloudexpress.credential>${test.virtacore-vcloudexpress.credential}</test.virtacore-vcloudexpress.credential>
<property> <test.virtacore-vcloudexpress.image-id>${test.virtacore-vcloudexpress.image-id}</test.virtacore-vcloudexpress.image-id>
<name>test.virtacore-vcloudexpress.apiversion</name> </systemPropertyVariables>
<value>${test.virtacore-vcloudexpress.apiversion}</value>
</property>
<property>
<name>test.virtacore-vcloudexpress.identity</name>
<value>${test.virtacore-vcloudexpress.identity}</value>
</property>
<property>
<name>test.virtacore-vcloudexpress.credential</name>
<value>${test.virtacore-vcloudexpress.credential}</value>
</property>
<property>
<name>test.virtacore-vcloudexpress.image-id</name>
<value>${test.virtacore-vcloudexpress.image-id}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>

View File

@ -96,24 +96,12 @@
<goal>test</goal> <goal>test</goal>
</goals> </goals>
<configuration> <configuration>
<systemProperties> <systemPropertyVariables>
<property> <test.servermanager.endpoint>${test.servermanager.endpoint}</test.servermanager.endpoint>
<name>test.servermanager.endpoint</name> <test.servermanager.apiversion>${test.servermanager.apiversion}</test.servermanager.apiversion>
<value>${test.servermanager.endpoint}</value> <test.servermanager.identity>${test.servermanager.identity}</test.servermanager.identity>
</property> <jclouds.compute.blacklist-nodes>${jclouds.compute.blacklist-nodes}</jclouds.compute.blacklist-nodes>
<property> </systemPropertyVariables>
<name>test.servermanager.apiversion</name>
<value>${test.servermanager.apiversion}</value>
</property>
<property>
<name>test.servermanager.identity</name>
<value>${test.servermanager.identity}</value>
</property>
<property>
<name>jclouds.compute.blacklist-nodes</name>
<value>${jclouds.compute.blacklist-nodes}</value>
</property>
</systemProperties>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>