mirror of https://github.com/apache/jclouds.git
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:
commit
9939237c6b
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
|
}
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -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"));
|
||||||
|
|
|
@ -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 + '\'' + ']';
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -534,6 +534,40 @@ public class Volume implements Comparable<Volume> {
|
||||||
result = 31 * result + (zoneName != null ? zoneName.hashCode() : 0);
|
result = 31 * result + (zoneName != null ? zoneName.hashCode() : 0);
|
||||||
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),
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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.
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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;
|
||||||
|
|
||||||
|
@ -28,18 +29,20 @@ import org.testng.annotations.Test;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests behavior of {@code AsyncJobClientLiveTest}
|
* Tests behavior of {@code AsyncJobClientLiveTest}
|
||||||
*
|
*
|
||||||
* @author Adrian Cole
|
* @author Adrian Cole
|
||||||
*/
|
*/
|
||||||
@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 {
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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);
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1 @@
|
||||||
|
{ "queryasyncjobresultresponse" : {"jobid":118,"jobstatus":1,"jobprocstatus":0,"jobresultcode":0,"jobresulttype":"object","jobresult":{"success":true}} }
|
|
@ -1,5 +1,6 @@
|
||||||
{
|
{
|
||||||
"listasyncjobsresponse": {
|
"listasyncjobsresponse": {
|
||||||
|
"count": 77,
|
||||||
"asyncjobs": [{
|
"asyncjobs": [{
|
||||||
"jobid": 1084,
|
"jobid": 1084,
|
||||||
"accountid": 3,
|
"accountid": 3,
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -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();
|
||||||
|
|
||||||
|
}
|
|
@ -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();
|
||||||
|
|
|
@ -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();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -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"));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
Loading…
Reference in New Issue