mirror of https://github.com/apache/cloudstack.git
constrained offerings should not have cpu speed of 0
This commit is contained in:
parent
b394b5ba74
commit
d681dfae78
|
|
@ -3198,14 +3198,8 @@ public class ConfigurationManagerImpl extends ManagerBase implements Configurati
|
|||
final String offeringName = cmd.getServiceOfferingName();
|
||||
|
||||
final String name = cmd.getServiceOfferingName();
|
||||
if (name == null || name.length() == 0) {
|
||||
throw new InvalidParameterValueException("Failed to create service offering: specify the name that has non-zero length");
|
||||
}
|
||||
|
||||
final String displayText = cmd.getDisplayText();
|
||||
if (displayText == null || displayText.length() == 0) {
|
||||
throw new InvalidParameterValueException("Failed to create service offering " + name + ": specify the display text that has non-zero length");
|
||||
}
|
||||
checkNameAndText(name, displayText);
|
||||
|
||||
final Integer cpuNumber = cmd.getCpuNumber();
|
||||
final Integer cpuSpeed = cmd.getCpuSpeed();
|
||||
|
|
@ -3217,6 +3211,8 @@ public class ConfigurationManagerImpl extends ManagerBase implements Configurati
|
|||
Integer maxMemory = cmd.getMaxMemory();
|
||||
Integer minMemory = cmd.getMinMemory();
|
||||
|
||||
checkSpeedOnConstrainedOffering(cmd.isCustomized(), cpuSpeed, offeringName, maxCPU, minCPU, maxMemory, minMemory);
|
||||
|
||||
// Check if service offering is Custom,
|
||||
// If Customized, the following conditions must hold
|
||||
// 1. cpuNumber, cpuSpeed and memory should be all null
|
||||
|
|
@ -3382,6 +3378,28 @@ public class ConfigurationManagerImpl extends ManagerBase implements Configurati
|
|||
cmd.getDiskOfferingStrictness(), cmd.isCustomized(), cmd.getEncryptRoot(), cmd.isPurgeResources());
|
||||
}
|
||||
|
||||
private static void checkNameAndText(String name, String displayText) {
|
||||
if (name == null || name.length() == 0) {
|
||||
throw new InvalidParameterValueException("Failed to create service offering: specify the name that has non-zero length");
|
||||
}
|
||||
|
||||
if (displayText == null || displayText.length() == 0) {
|
||||
throw new InvalidParameterValueException("Failed to create service offering " + name + ": specify the display text that has non-zero length");
|
||||
}
|
||||
}
|
||||
|
||||
private static void checkSpeedOnConstrainedOffering(boolean customised, Integer cpuSpeed, String offeringName, Integer maxCPU, Integer minCPU, Integer maxMemory, Integer minMemory) {
|
||||
// Check for the combination of zero speed and custom or constrained offering
|
||||
if (cpuSpeed != null && cpuSpeed.intValue() == 0) {
|
||||
if (customised) {
|
||||
throw new InvalidParameterValueException("Failed to create service offering " + offeringName + ": cpu speed cannot be zero for custom offerings");
|
||||
}
|
||||
if (maxCPU != null || minCPU != null || maxMemory != null || minMemory != null) {
|
||||
throw new InvalidParameterValueException("Failed to create service offering " + offeringName + ": cpu speed cannot be zero for constrained offerings");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
protected ServiceOfferingVO createServiceOffering(final long userId, final boolean isSystem, final VirtualMachine.Type vmType,
|
||||
final String name, final Integer cpu, final Integer ramSize, final Integer speed, final String displayText, final String provisioningType, final boolean localStorageRequired,
|
||||
final boolean offerHA, final boolean limitResourceUse, final boolean volatileVm, String tags, final List<Long> domainIds, List<Long> zoneIds, final String hostTag,
|
||||
|
|
|
|||
Loading…
Reference in New Issue