.setImagetype(context.<String>deserialize(jsonObj.get(IMAGE_TYPE_KEY), String.class)) .setDNSSuffix(context.<String>deserialize(jsonObj.get(DNS_SUFFIX_KEY), String.class)) .setConfig(config) .build();
.setServices("zookeeper") .setProvider("joyent") .setConfig(defaultClusterConfig) .build()) .setCompatibilities(Compatibilities.builder().setServices("zookeeper").build())
.setServices(services) .setProvider("joyent") .setConfig(Entities.ClusterTemplateExample.clusterConf).build()) .setCompatibilities(Compatibilities.builder().setServices(services).build()) .setConstraints(new Constraints(
.setServices(services) .setProvider("joyent") .setConfig(Entities.ClusterTemplateExample.clusterConf).build()) .setCompatibilities(Compatibilities.builder().setServices("service1", "service2", "service3").build()) .build();
@Test(expected = IllegalArgumentException.class) public void testConflictingServicesThrowsException() throws Exception { Set<String> services = ImmutableSet.of("myapp-1"); ClusterTemplate template = ClusterTemplate.builder() .setName("name") .setClusterDefaults(ClusterDefaults.builder() .setServices(services) .setProvider("joyent") .setConfig(Entities.ClusterTemplateExample.clusterConf).build()) .setCompatibilities(Compatibilities.builder().setServices("myapp-1", "myapp-2").build()) .build(); Service myapp1 = Service.builder() .setName("myapp-1") .setDependencies(ServiceDependencies.builder().setProvides("myapp").setConflicts("myapp-2").build()) .build(); Service myapp2 = Service.builder() .setName("myapp-2") .setDependencies(ServiceDependencies.builder().setProvides("myapp").setConflicts("myapp-1").build()) .build(); entityStoreService.getView(account).writeService(myapp1); entityStoreService.getView(account).writeService(myapp2); Cluster cluster = getBaseBuilder() .setClusterTemplate(template) .setServices(ImmutableSet.of(myapp1.getName())) .build(); solver.validateServicesToAdd(cluster, ImmutableSet.of(myapp2.getName())); }
private void copyMainProps(AbstractTemplate from, AbstractTemplate to, Set<String> immutables, boolean isImmutable) throws TemplateImmutabilityException { //merge defaults if(!from.clusterDefaults.equals(ClusterDefaults.EMPTY_CLUSTER_DEFAULTS)){ to.clusterDefaults = ClusterDefaults.builder() .setServices(mergeSet(to.clusterDefaults.services, from.clusterDefaults.services)) .setConfig(mergeConfig(to.clusterDefaults.config, from.clusterDefaults.config, immutables, isImmutable)) .setDNSSuffix(mergeString(to.clusterDefaults.dnsSuffix, from.clusterDefaults.dnsSuffix)) .setHardwaretype(mergeString(to.clusterDefaults.hardwaretype, from.clusterDefaults.hardwaretype)) .setImagetype(mergeString(to.clusterDefaults.imagetype, from.clusterDefaults.imagetype)) .setProvider(mergeString(to.clusterDefaults.provider, from.clusterDefaults.provider)) .build(); } //merge compatibilities services if(!from.compatibilities.equals(Compatibilities.EMPTY_COMPATIBILITIES)) { to.compatibilities = Compatibilities.builder() .setServices(mergeSet(to.compatibilities.services, from.compatibilities.services)) .setHardwaretypes(mergeSet(to.compatibilities.hardwaretypes, from.compatibilities.hardwaretypes)) .setImagetypes(mergeSet(to.compatibilities.imagetypes, from.compatibilities.imagetypes)) .build(); } }
@BeforeClass public static void initData() throws Exception { JsonObject defaultClusterConfig = new JsonObject(); defaultClusterConfig.addProperty("defaultconfig", "value1"); smallTemplate = ClusterTemplate.builder() .setName("one-machine") .setClusterDefaults( ClusterDefaults.builder() .setServices("zookeeper") .setProvider("rackspace") .setConfig(defaultClusterConfig) .build()) .setCompatibilities(Compatibilities.builder().setServices("zookeeper").build()) .setAdministration(new Administration(LeaseDuration.of("10s", "30s", "5s"))) .build(); }