package org.zstack.test.compute.vm; import org.junit.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.core.scheduler.SchedulerInventory; import org.zstack.header.vm.VmInstanceInventory; import org.zstack.header.vm.VmInstanceState; import org.zstack.header.vm.VmInstanceVO; import org.zstack.test.Api; import org.zstack.test.ApiSenderException; import org.zstack.test.DBUtil; import org.zstack.test.deployer.Deployer; import java.util.concurrent.TimeUnit; /** * Created by root on 8/16/16. */ public class TestRebootVmScheduler { Deployer deployer; Api api; ComponentLoader loader; CloudBus bus; DatabaseFacade dbf; @Before public void setUp() throws Exception { DBUtil.reDeployDB(); deployer = new Deployer("deployerXml/vm/TestCreateVm.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, InterruptedException { VmInstanceInventory inv = api.listVmInstances(null).get(0); String type = "simple"; Long startDate = 0L; Integer interval = 3; Integer repeatCount = 1; String vmUuid = inv.getUuid(); Assert.assertEquals(VmInstanceState.Running.toString(), inv.getState()); SchedulerInventory schedulerInv = api.rebootVmInstanceScheduler(vmUuid, type, startDate, interval, repeatCount, null); TimeUnit.SECONDS.sleep(10); VmInstanceVO vm = dbf.findByUuid(inv.getUuid(), VmInstanceVO.class); Assert.assertNotNull(vm); Assert.assertEquals(VmInstanceState.Running, vm.getState()); Assert.assertNotNull(vm.getHostUuid()); Assert.assertNotNull(schedulerInv.getStopTime()); SchedulerInventory schedulerInv2 = api.rebootVmInstanceScheduler(vmUuid, type, startDate, interval, null, null); TimeUnit.SECONDS.sleep(2); Assert.assertNull(schedulerInv2.getStopTime()); } }