package org.zstack.test.kvm; import junit.framework.Assert; import org.junit.Before; import org.junit.Test; import org.zstack.core.cloudbus.CloudBus; import org.zstack.core.componentloader.ComponentLoader; import org.zstack.core.db.DatabaseFacade; import org.zstack.header.host.HostInventory; import org.zstack.header.host.HostState; import org.zstack.header.identity.SessionInventory; import org.zstack.header.vm.VmInstanceInventory; import org.zstack.header.vm.VmInstanceState; import org.zstack.simulator.kvm.KVMSimulatorConfig; 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.test.storage.backup.sftp.TestSftpBackupStorageDeleteImage2; import org.zstack.utils.Utils; import org.zstack.utils.logging.CLogger; import java.util.Arrays; import java.util.List; /* * 3 vms on host1 * host1 enters maintenance mode * create a new vm * result: 3 vms successfully migrate to host2 * host1 is in maintenance mode * new vm created successfully on host2 */ public class TestKvmMaintenanceMode4 { CLogger logger = Utils.getLogger(TestSftpBackupStorageDeleteImage2.class); Deployer deployer; Api api; ComponentLoader loader; CloudBus bus; DatabaseFacade dbf; SessionInventory session; KVMSimulatorConfig config; @Before public void setUp() throws Exception { DBUtil.reDeployDB(); WebBeanConstructor con = new WebBeanConstructor(); deployer = new Deployer("deployerXml/kvm/TestKvmMaintenance.xml", con); deployer.addSpringConfig("KVMRelated.xml"); deployer.build(); api = deployer.getApi(); loader = deployer.getComponentLoader(); bus = loader.getComponent(CloudBus.class); dbf = loader.getComponent(DatabaseFacade.class); config = loader.getComponent(KVMSimulatorConfig.class); session = api.loginAsAdmin(); } @Test public void test() throws ApiSenderException { HostInventory host1 = deployer.hosts.get("host1"); HostInventory host2 = deployer.hosts.get("host2"); api.maintainHost(host1.getUuid()); Assert.assertEquals(3, config.migrateVmCmds.size()); List<VmInstanceInventory> vms = api.listVmInstances(null); for (VmInstanceInventory vm : vms) { Assert.assertEquals(VmInstanceState.Running.toString(), vm.getState()); Assert.assertEquals(host2.getUuid(), vm.getHostUuid()); Assert.assertEquals(host1.getUuid(), vm.getLastHostUuid()); } host1 = api.listHosts(Arrays.asList(host1.getUuid())).get(0); Assert.assertEquals(HostState.Maintenance.toString(), host1.getState()); VmInstanceInventory vm = deployer.vms.get("TestVm"); vm = api.createVmFromClone(vm); Assert.assertEquals(VmInstanceState.Running.toString(), vm.getState()); Assert.assertEquals(host2.getUuid(), vm.getHostUuid()); } }