mirror of https://github.com/apache/jclouds.git
Merge pull request #675 from vijaykiran/issue-305
Issue 305 - minDisk in TemplateBuilder Spec
This commit is contained in:
commit
f686737df3
|
@ -181,6 +181,11 @@ public interface TemplateBuilder {
|
||||||
*/
|
*/
|
||||||
TemplateBuilder minRam(int megabytes);
|
TemplateBuilder minRam(int megabytes);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Configure this template with required minimum disk space in gigabytes
|
||||||
|
*/
|
||||||
|
TemplateBuilder minDisk(double gigabytes);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Generate an immutable template from the current builder.
|
* Generate an immutable template from the current builder.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -140,6 +140,7 @@ public class TemplateBuilderSpec implements Serializable {
|
||||||
.put("hardwareId", new HardwareIdParser())
|
.put("hardwareId", new HardwareIdParser())
|
||||||
.put("minCores", new MinCoresParser())
|
.put("minCores", new MinCoresParser())
|
||||||
.put("minRam", new MinRamParser())
|
.put("minRam", new MinRamParser())
|
||||||
|
.put("minDisk", new MinDiskParser())
|
||||||
.put("hypervisorMatches", new HypervisorMatchesMatchesParser())
|
.put("hypervisorMatches", new HypervisorMatchesMatchesParser())
|
||||||
.put("imageId", new ImageIdParser())
|
.put("imageId", new ImageIdParser())
|
||||||
.put("imageNameMatches", new ImageNameMatchesParser())
|
.put("imageNameMatches", new ImageNameMatchesParser())
|
||||||
|
@ -160,6 +161,8 @@ public class TemplateBuilderSpec implements Serializable {
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
Integer minRam;
|
Integer minRam;
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
|
Double minDisk;
|
||||||
|
@VisibleForTesting
|
||||||
String hypervisorMatches;
|
String hypervisorMatches;
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
String imageId;
|
String imageId;
|
||||||
|
@ -238,6 +241,9 @@ public class TemplateBuilderSpec implements Serializable {
|
||||||
if (minRam != null) {
|
if (minRam != null) {
|
||||||
builder.minRam(minRam);
|
builder.minRam(minRam);
|
||||||
}
|
}
|
||||||
|
if (minDisk != null) {
|
||||||
|
builder.minDisk(minDisk);
|
||||||
|
}
|
||||||
if (hypervisorMatches != null) {
|
if (hypervisorMatches != null) {
|
||||||
builder.hypervisorMatches(hypervisorMatches);
|
builder.hypervisorMatches(hypervisorMatches);
|
||||||
}
|
}
|
||||||
|
@ -435,6 +441,16 @@ public class TemplateBuilderSpec implements Serializable {
|
||||||
spec.minRam = value;
|
spec.minRam = value;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Parse minDisk */
|
||||||
|
static class MinDiskParser extends DoubleParser {
|
||||||
|
@Override
|
||||||
|
protected void parseDouble(TemplateBuilderSpec spec, double value) {
|
||||||
|
checkArgument(spec.minDisk == null, "min disk was already set to ", spec.minDisk);
|
||||||
|
checkArgument(spec.hardwareId == null, "hardware id was already set to ", spec.hardwareId);
|
||||||
|
spec.minDisk = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/** Parse hypervisorMatches */
|
/** Parse hypervisorMatches */
|
||||||
static class HypervisorMatchesMatchesParser extends StringParser {
|
static class HypervisorMatchesMatchesParser extends StringParser {
|
||||||
|
|
|
@ -119,6 +119,8 @@ public class TemplateBuilderImpl implements TemplateBuilder {
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
protected int minRam;
|
protected int minRam;
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
|
protected double minDisk;
|
||||||
|
@VisibleForTesting
|
||||||
protected boolean biggest;
|
protected boolean biggest;
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
protected boolean fastest;
|
protected boolean fastest;
|
||||||
|
@ -392,6 +394,18 @@ public class TemplateBuilderImpl implements TemplateBuilder {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
private final Predicate<Hardware> hardwareDiskPredicate = new Predicate<Hardware>() {
|
||||||
|
@Override
|
||||||
|
public boolean apply(Hardware input) {
|
||||||
|
return getSpace(input) >= TemplateBuilderImpl.this.minDisk;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "minDisk(" + minDisk + ")";
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
private final Predicate<Hardware> hardwareRamPredicate = new Predicate<Hardware>() {
|
private final Predicate<Hardware> hardwareRamPredicate = new Predicate<Hardware>() {
|
||||||
@Override
|
@Override
|
||||||
public boolean apply(Hardware input) {
|
public boolean apply(Hardware input) {
|
||||||
|
@ -480,6 +494,7 @@ public class TemplateBuilderImpl implements TemplateBuilder {
|
||||||
this.location = hardware.getLocation();
|
this.location = hardware.getLocation();
|
||||||
this.minCores = getCores(hardware);
|
this.minCores = getCores(hardware);
|
||||||
this.minRam = hardware.getRam();
|
this.minRam = hardware.getRam();
|
||||||
|
this.minDisk = getSpace(hardware);
|
||||||
this.hypervisor = hardware.getHypervisor();
|
this.hypervisor = hardware.getHypervisor();
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
@ -932,6 +947,15 @@ public class TemplateBuilderImpl implements TemplateBuilder {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public TemplateBuilder minDisk(double gigabytes) {
|
||||||
|
this.minDisk = gigabytes;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
|
@ -984,7 +1008,7 @@ public class TemplateBuilderImpl implements TemplateBuilder {
|
||||||
return osFamily == null && location == null && imageId == null && hardwareId == null && hypervisor == null
|
return osFamily == null && location == null && imageId == null && hardwareId == null && hypervisor == null
|
||||||
&& osName == null && imagePredicate == null && osDescription == null && imageVersion == null
|
&& osName == null && imagePredicate == null && osDescription == null && imageVersion == null
|
||||||
&& osVersion == null && osArch == null && os64Bit == null && imageName == null && imageDescription == null
|
&& osVersion == null && osArch == null && os64Bit == null && imageName == null && imageDescription == null
|
||||||
&& minCores == 0 && minRam == 0 && !biggest && !fastest;
|
&& minCores == 0 && minRam == 0 && minDisk == 0 && !biggest && !fastest;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1022,6 +1046,8 @@ public class TemplateBuilderImpl implements TemplateBuilder {
|
||||||
toString.add("minRam", minRam);
|
toString.add("minRam", minRam);
|
||||||
if (minRam >0) //TODO: make non-primitive
|
if (minRam >0) //TODO: make non-primitive
|
||||||
toString.add("minRam", minRam);
|
toString.add("minRam", minRam);
|
||||||
|
if (minDisk >0) //TODO: make non-primitive
|
||||||
|
toString.add("minDisk", minDisk);
|
||||||
toString.add("osFamily", osFamily);
|
toString.add("osFamily", osFamily);
|
||||||
toString.add("osName", osName);
|
toString.add("osName", osName);
|
||||||
toString.add("osDescription", osDescription);
|
toString.add("osDescription", osDescription);
|
||||||
|
|
|
@ -23,6 +23,7 @@ import static org.jclouds.compute.domain.TemplateBuilderSpec.parse;
|
||||||
import static org.jclouds.compute.options.TemplateOptions.Builder.overrideLoginCredentials;
|
import static org.jclouds.compute.options.TemplateOptions.Builder.overrideLoginCredentials;
|
||||||
import static org.jclouds.compute.options.TemplateOptions.Builder.overrideLoginUser;
|
import static org.jclouds.compute.options.TemplateOptions.Builder.overrideLoginUser;
|
||||||
import static org.testng.Assert.assertEquals;
|
import static org.testng.Assert.assertEquals;
|
||||||
|
import static org.testng.Assert.assertNotEquals;
|
||||||
import static org.testng.Assert.assertNull;
|
import static org.testng.Assert.assertNull;
|
||||||
import static org.testng.Assert.fail;
|
import static org.testng.Assert.fail;
|
||||||
|
|
||||||
|
@ -53,6 +54,7 @@ public class TemplateBuilderSpecTest {
|
||||||
assertNull(spec.hardwareId);
|
assertNull(spec.hardwareId);
|
||||||
assertNull(spec.minCores);
|
assertNull(spec.minCores);
|
||||||
assertNull(spec.minRam);
|
assertNull(spec.minRam);
|
||||||
|
assertNull(spec.minDisk);
|
||||||
assertNull(spec.hypervisorMatches);
|
assertNull(spec.hypervisorMatches);
|
||||||
assertNull(spec.imageId);
|
assertNull(spec.imageId);
|
||||||
assertNull(spec.imageNameMatches);
|
assertNull(spec.imageNameMatches);
|
||||||
|
@ -72,6 +74,7 @@ public class TemplateBuilderSpecTest {
|
||||||
assertEquals(spec.hardwareId, "m1.small");
|
assertEquals(spec.hardwareId, "m1.small");
|
||||||
assertNull(spec.minCores);
|
assertNull(spec.minCores);
|
||||||
assertNull(spec.minRam);
|
assertNull(spec.minRam);
|
||||||
|
assertNull(spec.minDisk);
|
||||||
assertNull(spec.hypervisorMatches);
|
assertNull(spec.hypervisorMatches);
|
||||||
assertNull(spec.imageId);
|
assertNull(spec.imageId);
|
||||||
assertNull(spec.imageNameMatches);
|
assertNull(spec.imageNameMatches);
|
||||||
|
@ -122,6 +125,7 @@ public class TemplateBuilderSpecTest {
|
||||||
assertNull(spec.hardwareId);
|
assertNull(spec.hardwareId);
|
||||||
assertEquals(32, spec.minCores.intValue());
|
assertEquals(32, spec.minCores.intValue());
|
||||||
assertNull(spec.minRam);
|
assertNull(spec.minRam);
|
||||||
|
assertNull(spec.minDisk);
|
||||||
assertNull(spec.hypervisorMatches);
|
assertNull(spec.hypervisorMatches);
|
||||||
assertNull(spec.imageId);
|
assertNull(spec.imageId);
|
||||||
assertNull(spec.imageNameMatches);
|
assertNull(spec.imageNameMatches);
|
||||||
|
@ -164,6 +168,34 @@ public class TemplateBuilderSpecTest {
|
||||||
assertTemplateBuilderEquivalence(templateBuilders.get().minRam(10), templateBuilders.get().from(spec));
|
assertTemplateBuilderEquivalence(templateBuilders.get().minRam(10), templateBuilders.get().from(spec));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void testParse_minDisk() {
|
||||||
|
TemplateBuilderSpec spec = parse("minDisk=10");
|
||||||
|
assertNull(spec.hardwareId);
|
||||||
|
assertNull(spec.minCores);
|
||||||
|
assertNull(spec.minRam);
|
||||||
|
assertEquals(spec.minDisk.doubleValue(), 10.0);
|
||||||
|
assertNull(spec.hypervisorMatches);
|
||||||
|
assertNull(spec.imageId);
|
||||||
|
assertNull(spec.imageNameMatches);
|
||||||
|
assertNull(spec.osFamily);
|
||||||
|
assertNull(spec.osVersionMatches);
|
||||||
|
assertNull(spec.os64Bit);
|
||||||
|
assertNull(spec.osArchMatches);
|
||||||
|
assertNull(spec.osDescriptionMatches);
|
||||||
|
assertNull(spec.loginUser);
|
||||||
|
assertNull(spec.authenticateSudo);
|
||||||
|
assertNull(spec.locationId);
|
||||||
|
assertTemplateBuilderEquivalence(templateBuilders.get().minRam(10), templateBuilders.get().from(spec));
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testParse_minDiskIsNotEqual() {
|
||||||
|
TemplateBuilderSpec spec1 = parse("minDisk=10");
|
||||||
|
TemplateBuilderSpec spec2 = parse("minDisk=20");
|
||||||
|
assertTemplateBuilderEquivalence(templateBuilders.get().minDisk(10), templateBuilders.get().from(spec1));
|
||||||
|
assertTemplateBuilderEquivalence(templateBuilders.get().minDisk(20), templateBuilders.get().from(spec2));
|
||||||
|
assertNotEquals(spec1.minDisk, spec2.minDisk);
|
||||||
|
}
|
||||||
|
|
||||||
public void testParse_minRamRepeated() {
|
public void testParse_minRamRepeated() {
|
||||||
try {
|
try {
|
||||||
parse("minRam=10, minRam=20");
|
parse("minRam=10, minRam=20");
|
||||||
|
@ -178,6 +210,7 @@ public class TemplateBuilderSpecTest {
|
||||||
assertNull(spec.hardwareId);
|
assertNull(spec.hardwareId);
|
||||||
assertNull(spec.minCores);
|
assertNull(spec.minCores);
|
||||||
assertNull(spec.minRam);
|
assertNull(spec.minRam);
|
||||||
|
assertNull(spec.minDisk);
|
||||||
assertEquals(spec.hypervisorMatches, "OpenVZ");
|
assertEquals(spec.hypervisorMatches, "OpenVZ");
|
||||||
assertNull(spec.imageId);
|
assertNull(spec.imageId);
|
||||||
assertNull(spec.imageNameMatches);
|
assertNull(spec.imageNameMatches);
|
||||||
|
@ -206,6 +239,7 @@ public class TemplateBuilderSpecTest {
|
||||||
assertNull(spec.hardwareId);
|
assertNull(spec.hardwareId);
|
||||||
assertNull(spec.minCores);
|
assertNull(spec.minCores);
|
||||||
assertNull(spec.minRam);
|
assertNull(spec.minRam);
|
||||||
|
assertNull(spec.minDisk);
|
||||||
assertNull(spec.hypervisorMatches);
|
assertNull(spec.hypervisorMatches);
|
||||||
assertEquals(spec.imageId, "us-east-1/ami-fffffff");
|
assertEquals(spec.imageId, "us-east-1/ami-fffffff");
|
||||||
assertNull(spec.imageNameMatches);
|
assertNull(spec.imageNameMatches);
|
||||||
|
@ -275,6 +309,7 @@ public class TemplateBuilderSpecTest {
|
||||||
assertNull(spec.hardwareId);
|
assertNull(spec.hardwareId);
|
||||||
assertNull(spec.minCores);
|
assertNull(spec.minCores);
|
||||||
assertNull(spec.minRam);
|
assertNull(spec.minRam);
|
||||||
|
assertNull(spec.minDisk);
|
||||||
assertNull(spec.hypervisorMatches);
|
assertNull(spec.hypervisorMatches);
|
||||||
assertNull(spec.imageId);
|
assertNull(spec.imageId);
|
||||||
assertEquals(spec.imageNameMatches, ".*w/ None.*");
|
assertEquals(spec.imageNameMatches, ".*w/ None.*");
|
||||||
|
@ -303,6 +338,7 @@ public class TemplateBuilderSpecTest {
|
||||||
assertNull(spec.hardwareId);
|
assertNull(spec.hardwareId);
|
||||||
assertNull(spec.minCores);
|
assertNull(spec.minCores);
|
||||||
assertNull(spec.minRam);
|
assertNull(spec.minRam);
|
||||||
|
assertNull(spec.minDisk);
|
||||||
assertNull(spec.hypervisorMatches);
|
assertNull(spec.hypervisorMatches);
|
||||||
assertNull(spec.imageId);
|
assertNull(spec.imageId);
|
||||||
assertNull(spec.imageNameMatches);
|
assertNull(spec.imageNameMatches);
|
||||||
|
@ -332,6 +368,7 @@ public class TemplateBuilderSpecTest {
|
||||||
assertNull(spec.hardwareId);
|
assertNull(spec.hardwareId);
|
||||||
assertNull(spec.minCores);
|
assertNull(spec.minCores);
|
||||||
assertNull(spec.minRam);
|
assertNull(spec.minRam);
|
||||||
|
assertNull(spec.minDisk);
|
||||||
assertNull(spec.hypervisorMatches);
|
assertNull(spec.hypervisorMatches);
|
||||||
assertNull(spec.imageId);
|
assertNull(spec.imageId);
|
||||||
assertNull(spec.imageNameMatches);
|
assertNull(spec.imageNameMatches);
|
||||||
|
@ -360,6 +397,7 @@ public class TemplateBuilderSpecTest {
|
||||||
assertNull(spec.hardwareId);
|
assertNull(spec.hardwareId);
|
||||||
assertNull(spec.minCores);
|
assertNull(spec.minCores);
|
||||||
assertNull(spec.minRam);
|
assertNull(spec.minRam);
|
||||||
|
assertNull(spec.minDisk);
|
||||||
assertNull(spec.hypervisorMatches);
|
assertNull(spec.hypervisorMatches);
|
||||||
assertNull(spec.imageId);
|
assertNull(spec.imageId);
|
||||||
assertNull(spec.imageNameMatches);
|
assertNull(spec.imageNameMatches);
|
||||||
|
@ -388,6 +426,7 @@ public class TemplateBuilderSpecTest {
|
||||||
assertNull(spec.hardwareId);
|
assertNull(spec.hardwareId);
|
||||||
assertNull(spec.minCores);
|
assertNull(spec.minCores);
|
||||||
assertNull(spec.minRam);
|
assertNull(spec.minRam);
|
||||||
|
assertNull(spec.minDisk);
|
||||||
assertNull(spec.hypervisorMatches);
|
assertNull(spec.hypervisorMatches);
|
||||||
assertNull(spec.imageId);
|
assertNull(spec.imageId);
|
||||||
assertNull(spec.imageNameMatches);
|
assertNull(spec.imageNameMatches);
|
||||||
|
@ -416,6 +455,7 @@ public class TemplateBuilderSpecTest {
|
||||||
assertNull(spec.hardwareId);
|
assertNull(spec.hardwareId);
|
||||||
assertNull(spec.minCores);
|
assertNull(spec.minCores);
|
||||||
assertNull(spec.minRam);
|
assertNull(spec.minRam);
|
||||||
|
assertNull(spec.minDisk);
|
||||||
assertNull(spec.hypervisorMatches);
|
assertNull(spec.hypervisorMatches);
|
||||||
assertNull(spec.imageId);
|
assertNull(spec.imageId);
|
||||||
assertNull(spec.imageNameMatches);
|
assertNull(spec.imageNameMatches);
|
||||||
|
@ -444,6 +484,7 @@ public class TemplateBuilderSpecTest {
|
||||||
assertNull(spec.hardwareId);
|
assertNull(spec.hardwareId);
|
||||||
assertNull(spec.minCores);
|
assertNull(spec.minCores);
|
||||||
assertNull(spec.minRam);
|
assertNull(spec.minRam);
|
||||||
|
assertNull(spec.minDisk);
|
||||||
assertNull(spec.hypervisorMatches);
|
assertNull(spec.hypervisorMatches);
|
||||||
assertNull(spec.imageId);
|
assertNull(spec.imageId);
|
||||||
assertNull(spec.imageNameMatches);
|
assertNull(spec.imageNameMatches);
|
||||||
|
@ -474,6 +515,7 @@ public class TemplateBuilderSpecTest {
|
||||||
assertNull(spec.hardwareId);
|
assertNull(spec.hardwareId);
|
||||||
assertNull(spec.minCores);
|
assertNull(spec.minCores);
|
||||||
assertNull(spec.minRam);
|
assertNull(spec.minRam);
|
||||||
|
assertNull(spec.minDisk);
|
||||||
assertNull(spec.hypervisorMatches);
|
assertNull(spec.hypervisorMatches);
|
||||||
assertNull(spec.imageId);
|
assertNull(spec.imageId);
|
||||||
assertNull(spec.imageNameMatches);
|
assertNull(spec.imageNameMatches);
|
||||||
|
@ -505,6 +547,7 @@ public class TemplateBuilderSpecTest {
|
||||||
assertNull(spec.hardwareId);
|
assertNull(spec.hardwareId);
|
||||||
assertNull(spec.minCores);
|
assertNull(spec.minCores);
|
||||||
assertNull(spec.minRam);
|
assertNull(spec.minRam);
|
||||||
|
assertNull(spec.minDisk);
|
||||||
assertNull(spec.imageId);
|
assertNull(spec.imageId);
|
||||||
assertNull(spec.imageNameMatches);
|
assertNull(spec.imageNameMatches);
|
||||||
assertNull(spec.hypervisorMatches);
|
assertNull(spec.hypervisorMatches);
|
||||||
|
@ -536,6 +579,7 @@ public class TemplateBuilderSpecTest {
|
||||||
assertNull(spec.hardwareId);
|
assertNull(spec.hardwareId);
|
||||||
assertNull(spec.minCores);
|
assertNull(spec.minCores);
|
||||||
assertNull(spec.minRam);
|
assertNull(spec.minRam);
|
||||||
|
assertNull(spec.minDisk);
|
||||||
assertNull(spec.hypervisorMatches);
|
assertNull(spec.hypervisorMatches);
|
||||||
assertNull(spec.imageId);
|
assertNull(spec.imageId);
|
||||||
assertNull(spec.imageNameMatches);
|
assertNull(spec.imageNameMatches);
|
||||||
|
@ -565,6 +609,7 @@ public class TemplateBuilderSpecTest {
|
||||||
assertNull(spec.hardwareId);
|
assertNull(spec.hardwareId);
|
||||||
assertNull(spec.minCores);
|
assertNull(spec.minCores);
|
||||||
assertNull(spec.minRam);
|
assertNull(spec.minRam);
|
||||||
|
assertNull(spec.minDisk);
|
||||||
assertNull(spec.hypervisorMatches);
|
assertNull(spec.hypervisorMatches);
|
||||||
assertNull(spec.imageId);
|
assertNull(spec.imageId);
|
||||||
assertEquals(spec.imageNameMatches, ".*w/ None.*");
|
assertEquals(spec.imageNameMatches, ".*w/ None.*");
|
||||||
|
@ -585,6 +630,7 @@ public class TemplateBuilderSpecTest {
|
||||||
assertNull(spec.hardwareId);
|
assertNull(spec.hardwareId);
|
||||||
assertNull(spec.minCores);
|
assertNull(spec.minCores);
|
||||||
assertEquals(spec.minRam.intValue(), 10);
|
assertEquals(spec.minRam.intValue(), 10);
|
||||||
|
assertNull(spec.minDisk);
|
||||||
assertNull(spec.hypervisorMatches);
|
assertNull(spec.hypervisorMatches);
|
||||||
assertNull(spec.imageId);
|
assertNull(spec.imageId);
|
||||||
assertNull(spec.imageNameMatches);
|
assertNull(spec.imageNameMatches);
|
||||||
|
|
Loading…
Reference in New Issue