package org.zstack.test.configuration;
import junit.framework.Assert;
import org.junit.After;
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.configuration.DiskOfferingInventory;
import org.zstack.header.volume.VolumeInventory;
import org.zstack.header.volume.VolumeVO;
import org.zstack.test.*;
import org.zstack.utils.Utils;
import org.zstack.utils.data.SizeUnit;
import org.zstack.utils.logging.CLogger;
/**
* 1. create a disk offering
* 2. create a data volume from the disk offering
* 3. delete the disk offering
* <p>
* confirm the volume's disk offering column is set to null
*/
public class TestDeleteDiskOffering2 {
CLogger logger = Utils.getLogger(TestDeleteDiskOffering2.class);
Api api;
ComponentLoader loader;
DatabaseFacade dbf;
CloudBus bus;
@Before
public void setUp() throws Exception {
DBUtil.reDeployDB();
BeanConstructor con = new WebBeanConstructor();
/* This loads spring application context */
loader = con.addXml("PortalForUnitTest.xml").addXml("Simulator.xml").addXml("ZoneManager.xml")
.addXml("PrimaryStorageManager.xml").addXml("ConfigurationManager.xml").addXml("VolumeManager.xml").addXml("AccountManager.xml").build();
dbf = loader.getComponent(DatabaseFacade.class);
bus = loader.getComponent(CloudBus.class);
api = new Api();
api.startServer();
}
@After
public void tearDown() throws Exception {
api.stopServer();
}
@Test
public void test() throws ApiSenderException {
DiskOfferingInventory dinv = new DiskOfferingInventory();
dinv.setDiskSize(SizeUnit.GIGABYTE.toByte(10));
dinv.setName("Test");
dinv.setDescription("Test");
dinv = api.addDiskOffering(dinv);
VolumeInventory vinv = api.createDataVolume("TestData", dinv.getUuid());
Assert.assertNotNull(vinv.getDiskOfferingUuid());
api.deleteDiskOffering(dinv.getUuid());
VolumeVO vol = dbf.findByUuid(vinv.getUuid(), VolumeVO.class);
Assert.assertNull(vol.getDiskOfferingUuid());
}
}