package org.zstack.test.compute.hostallocator; import org.junit.Assert; import org.junit.Before; import org.junit.Test; import org.zstack.compute.cluster.ClusterSystemTags; import org.zstack.compute.host.HostSystemTags; import org.zstack.compute.zone.ZoneSystemTags; import org.zstack.core.cloudbus.CloudBus; import org.zstack.core.componentloader.ComponentLoader; import org.zstack.core.db.DatabaseFacade; import org.zstack.header.allocator.HostAllocatorError; import org.zstack.header.cluster.ClusterInventory; import org.zstack.header.configuration.InstanceOfferingInventory; import org.zstack.header.host.HostInventory; import org.zstack.header.image.ImageInventory; import org.zstack.header.network.l3.L3NetworkInventory; import org.zstack.header.tag.TagInventory; import org.zstack.header.zone.ZoneInventory; import org.zstack.kvm.KVMGlobalConfig; import org.zstack.tag.SystemTagCreator; import org.zstack.test.*; import org.zstack.test.deployer.Deployer; import static org.zstack.utils.CollectionDSL.e; import static org.zstack.utils.CollectionDSL.map; /** * 1. set ZoneTag.HOST_RESERVED_CPU_CAPACITY, ClusterTag.HOST_RESERVED_CPU_CAPACITY, HostTag.RESERVED_CPU_CAPACITY, KvmGlobalConfig.RESERVED_CPU_CAPACITY * <p> * confirm the precedence is: * HostTag.RESERVED_CPU_CAPACITY > ClusterTag.HOST_RESERVED_CPU_CAPACITY > ZoneTag.HOST_RESERVED_CPU_CAPACITY > KvmGlobalConfig.RESERVED_CPU_CAPACITY */ @Deprecated public class TestReservedHostCapacity5 { Deployer deployer; Api api; ComponentLoader loader; CloudBus bus; DatabaseFacade dbf; @Before public void setUp() throws Exception { DBUtil.reDeployDB(); WebBeanConstructor con = new WebBeanConstructor(); deployer = new Deployer("deployerXml/hostAllocator/TestReservedHostCapacity.xml", con); deployer.addSpringConfig("KVMRelated.xml"); deployer.build(); api = deployer.getApi(); loader = deployer.getComponentLoader(); bus = loader.getComponent(CloudBus.class); dbf = loader.getComponent(DatabaseFacade.class); } @Test public void test() throws ApiSenderException { boolean success = false; ZoneInventory zone = deployer.zones.values().iterator().next(); ClusterInventory cluster = deployer.clusters.values().iterator().next(); HostInventory host = deployer.hosts.values().iterator().next(); // set kvm global reserved capacity to 0 that can create vm KVMGlobalConfig.RESERVED_CPU_CAPACITY.updateValue(0); // set zone reserved capacity to big value that cannot create vm SystemTagCreator sc = ZoneSystemTags.HOST_RESERVED_CPU_CAPACITY.newSystemTagCreator(zone.getUuid()); sc.setTagByTokens(map(e("capacity", 10*2600L))); TagInventory ztag = sc.create(); // set cluster reserved capacity to 0 that can create vm sc = ClusterSystemTags.HOST_RESERVED_CPU_CAPACITY.newSystemTagCreator(cluster.getUuid()); sc.setTagByTokens(map(e("capacity", 0L))); TagInventory ctag = sc.create(); // set host reserved capacity to big value that cannot create vm sc = HostSystemTags.RESERVED_CPU_CAPACITY.newSystemTagCreator(host.getUuid()); sc.setTagByTokens(map(e("capacity", 10*2600L))); TagInventory htag = sc.create(); L3NetworkInventory l3 = deployer.l3Networks.get("TestL3Network1"); InstanceOfferingInventory instanceOffering = deployer.instanceOfferings.get("TestInstanceOffering"); ImageInventory imageInventory = deployer.images.get("TestImage"); // host tag takes effect try { VmCreator creator = new VmCreator(api); creator.timeout = 600; creator.addL3Network(l3.getUuid()); creator.imageUuid = imageInventory.getUuid(); creator.instanceOfferingUuid = instanceOffering.getUuid(); creator.create(); } catch (ApiSenderException e) { if (e.getError().getCause() != null && HostAllocatorError.NO_AVAILABLE_HOST.toString().equals(e.getError().getCause().getCode())) { success = true; } } Assert.assertTrue(success); api.deleteTag(htag.getUuid()); // cluster tag takes effect VmCreator creator = new VmCreator(api); creator.timeout = 600; creator.addL3Network(l3.getUuid()); creator.imageUuid = imageInventory.getUuid(); creator.instanceOfferingUuid = instanceOffering.getUuid(); creator.create(); api.deleteTag(ctag.getUuid()); // zone tag takes effect success = false; try { creator = new VmCreator(api); creator.timeout = 600; creator.addL3Network(l3.getUuid()); creator.imageUuid = imageInventory.getUuid(); creator.instanceOfferingUuid = instanceOffering.getUuid(); creator.create(); } catch (ApiSenderException e) { if (e.getError().getCause() != null && HostAllocatorError.NO_AVAILABLE_HOST.toString().equals(e.getError().getCause().getCode())) { success = true; } } Assert.assertTrue(success); api.deleteTag(ztag.getUuid()); // kvm global config takes effect creator = new VmCreator(api); creator.timeout = 600; creator.addL3Network(l3.getUuid()); creator.imageUuid = imageInventory.getUuid(); creator.instanceOfferingUuid = instanceOffering.getUuid(); creator.create(); } }