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.APIGetCpuMemoryCapacityReply; import org.zstack.header.cluster.ClusterInventory; import org.zstack.header.host.HostInventory; 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.Api; import org.zstack.test.ApiSenderException; import org.zstack.test.DBUtil; import org.zstack.test.WebBeanConstructor; import org.zstack.test.deployer.Deployer; import org.zstack.utils.SizeUtils; import java.util.Arrays; import static org.zstack.utils.CollectionDSL.e; import static org.zstack.utils.CollectionDSL.map; /** * 1. set ZoneTag.HOST_RESERVED_MEMORY_CAPACITY, ClusterTag.HOST_RESERVED_MEMORY_CAPACITY, HostTag.RESERVED_MEMORY_CAPACITY, KvmGlobalConfig.RESERVED_MEMORY_CAPACITY * <p> * confirm getCpuMemoryCapacity returns right capacity */ public class TestGetCpuMemoryCapacity1 { 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 { ZoneInventory zone = deployer.zones.values().iterator().next(); ClusterInventory cluster = deployer.clusters.values().iterator().next(); HostInventory host = deployer.hosts.values().iterator().next(); KVMGlobalConfig.RESERVED_MEMORY_CAPACITY.updateValue("1k"); SystemTagCreator creator = ZoneSystemTags.HOST_RESERVED_MEMORY_CAPACITY.newSystemTagCreator(zone.getUuid()); creator.setTagByTokens(map(e("capacity", "1M"))); TagInventory ztag = creator.create(); creator = ClusterSystemTags.HOST_RESERVED_MEMORY_CAPACITY.newSystemTagCreator(cluster.getUuid()); creator.setTagByTokens(map(e("capacity", "1G"))); TagInventory ctag = creator.create(); creator = HostSystemTags.RESERVED_MEMORY_CAPACITY.newSystemTagCreator(host.getUuid()); creator.setTagByTokens(map(e("capacity", "1T"))); TagInventory htag = creator.create(); // host tag takes effect APIGetCpuMemoryCapacityReply reply = api.retrieveHostCapacity(Arrays.asList(zone.getUuid()), null, null); Assert.assertEquals(reply.getAvailableMemory(), 0); api.deleteTag(htag.getUuid()); // cluster tag takes effect reply = api.retrieveHostCapacity(Arrays.asList(zone.getUuid()), null, null); Assert.assertEquals(reply.getAvailableMemory(), reply.getTotalMemory() - SizeUtils.sizeStringToBytes("1G")); api.deleteTag(ctag.getUuid()); // zone tag takes effect reply = api.retrieveHostCapacity(null, Arrays.asList(cluster.getUuid()), null); Assert.assertEquals(reply.getAvailableMemory(), reply.getTotalMemory() - SizeUtils.sizeStringToBytes("1M")); api.deleteTag(ztag.getUuid()); // kvm global config takes effect reply = api.retrieveHostCapacity(null, null, Arrays.asList(host.getUuid())); Assert.assertEquals(reply.getAvailableMemory(), reply.getTotalMemory() - SizeUtils.sizeStringToBytes("1k")); } }