/** * Abiquo community edition * cloud management application for hybrid clouds * Copyright (C) 2008-2010 - Abiquo Holdings S.L. * * This application is free software; you can redistribute it and/or * modify it under the terms of the GNU LESSER GENERAL PUBLIC * LICENSE as published by the Free Software Foundation under * version 3 of the License * * This software is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * LESSER GENERAL PUBLIC LICENSE v.3 for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the * Free Software Foundation, Inc., 59 Temple Place - Suite 330, * Boston, MA 02111-1307, USA. */ /** * */ package com.abiquo.api.resources.cloud; import static com.abiquo.api.common.Assert.assertLinkExist; import static com.abiquo.api.common.UriTestResolver.resolveVirtualApplianceActionGetIPsURI; import static com.abiquo.api.common.UriTestResolver.resolveVirtualApplianceURI; import static com.abiquo.api.common.UriTestResolver.resolveVirtualMachinesURI; import static org.testng.Assert.assertEquals; import static org.testng.Assert.assertNotNull; import java.util.ArrayList; import java.util.List; import java.util.Random; import javax.ws.rs.core.Response.Status; import org.apache.wink.client.ClientResponse; import org.testng.annotations.BeforeMethod; import org.testng.annotations.Test; import com.abiquo.api.resources.AbstractJpaGeneratorIT; import com.abiquo.model.util.ModelTransformer; import com.abiquo.server.core.cloud.VirtualAppliance; import com.abiquo.server.core.cloud.VirtualApplianceDto; import com.abiquo.server.core.cloud.VirtualDatacenter; import com.abiquo.server.core.enterprise.Enterprise; import com.abiquo.server.core.enterprise.Privilege; import com.abiquo.server.core.enterprise.Role; import com.abiquo.server.core.enterprise.User; import com.abiquo.server.core.infrastructure.Datacenter; import com.abiquo.server.core.infrastructure.network.IpsPoolManagementDto; /** * Test class to check the functionality of the resource {@link VirtualApplianceResource} * * @author jdevesa@abiquo.com */ public class VirtualApplianceResourceIT extends AbstractJpaGeneratorIT { protected Enterprise ent; protected Datacenter datacenter; protected VirtualDatacenter vdc; private static final String SYSADMIN = "sysadmin"; @BeforeMethod public void setUp() { ent = enterpriseGenerator.createUniqueInstance(); Role r = roleGenerator.createInstanceSysAdmin("sysRole"); User u = userGenerator.createInstance(ent, r, "sysadmin", "sysadmin"); datacenter = datacenterGenerator.createUniqueInstance(); vdc = vdcGenerator.createInstance(datacenter, ent); List<Object> entitiesToSetup = new ArrayList<Object>(); entitiesToSetup.add(ent); entitiesToSetup.add(datacenter); for (Privilege p : r.getPrivileges()) { entitiesToSetup.add(p); } entitiesToSetup.add(r); entitiesToSetup.add(u); entitiesToSetup.add(vdc); setup(entitiesToSetup.toArray()); } /** * Check a 'get virtual appliances' call after creating the instances in DB. Creating a virtual * datacenter with two virtual appliances. Check all of them are accessible. */ @Test public void getVirtualApplianceTest() { VirtualAppliance vapp1 = vappGenerator.createInstance(vdc); VirtualAppliance vapp2 = vappGenerator.createInstance(vdc); setup(vapp1, vapp2); // Check for vapp1 ClientResponse response = get(resolveVirtualApplianceURI(vdc.getId(), vapp1.getId()), SYSADMIN, SYSADMIN, VirtualApplianceDto.MEDIA_TYPE); assertEquals(response.getStatusCode(), Status.OK.getStatusCode()); VirtualApplianceDto vappdto = response.getEntity(VirtualApplianceDto.class); assertNotNull(vappdto); assertLinkExist(vappdto, resolveVirtualApplianceActionGetIPsURI(vdc.getId(), vapp1.getId()), IpAddressesResource.IP_ADDRESSES); assertLinkExist(vappdto, resolveVirtualMachinesURI(vdc.getId(), vapp1.getId()), VirtualMachinesResource.VIRTUAL_MACHINES_PATH); // Check for vapp2 response = get(resolveVirtualApplianceURI(vdc.getId(), vapp2.getId()), SYSADMIN, SYSADMIN, VirtualApplianceDto.MEDIA_TYPE); assertEquals(response.getStatusCode(), Status.OK.getStatusCode()); vappdto = response.getEntity(VirtualApplianceDto.class); assertNotNull(vappdto); assertLinkExist(vappdto, resolveVirtualApplianceActionGetIPsURI(vdc.getId(), vapp2.getId()), IpAddressesResource.IP_ADDRESSES); assertLinkExist(vappdto, resolveVirtualMachinesURI(vdc.getId(), vapp2.getId()), VirtualMachinesResource.VIRTUAL_MACHINES_PATH); } /** * Check a 'get virtual appliances' 404 NOT FOUND error code when the identifier of the virtual * appliance is a random number. */ @Test public void getVirtualApplianceRaises404ErrorWhenVappRandomIdentifier() { ClientResponse response = get(resolveVirtualApplianceURI(vdc.getId(), new Random().nextInt()), SYSADMIN, SYSADMIN, VirtualApplianceDto.MEDIA_TYPE); assertEquals(response.getStatusCode(), Status.NOT_FOUND.getStatusCode()); } /** * Create a virtual datacenter and a Virtual appliance. Check the 'get virtual appliances' 404 * NOT FOUND error code when the virtual appliance is OK, but the identifier of the virtual * datacenter is not. In other words, the virtual appliance exists but doesn't belong to the * virtual datacenter. */ @Test public void getVirtualApplianceRaises404WhenVappNotBelongsToVDC() { VirtualAppliance vapp1 = vappGenerator.createInstance(vdc); setup(vapp1); ClientResponse response = get(resolveVirtualApplianceURI(new Random().nextInt(), vapp1.getId()), SYSADMIN, SYSADMIN, VirtualApplianceDto.MEDIA_TYPE); assertEquals(response.getStatusCode(), Status.NOT_FOUND.getStatusCode()); } // TODO: Create a test to return a non-empty list of IPs. /** * Create a virtual appliance. Check the action resource returns an empty list */ @Test public void getVirtualApplianceActionIPsEmptyList() { VirtualAppliance vapp1 = vappGenerator.createInstance(vdc); setup(vapp1); ClientResponse response = get(resolveVirtualApplianceActionGetIPsURI(vdc.getId(), vapp1.getId()), SYSADMIN, SYSADMIN, IpsPoolManagementDto.MEDIA_TYPE); assertEquals(response.getStatusCode(), Status.OK.getStatusCode()); IpsPoolManagementDto entity = response.getEntity(IpsPoolManagementDto.class); assertNotNull(entity); assertNotNull(entity.getCollection()); assertEquals(entity.getCollection().size(), 0); } /** * Create a virtual appliance. Ask the IPs for an invalid virtual appliance identifier value. */ @Test public void getVirtualApplianceActionIPsRaises404WhenVappIsARandomValue() { ClientResponse response = get(resolveVirtualApplianceActionGetIPsURI(vdc.getId(), new Random().nextInt()), SYSADMIN, SYSADMIN, IpsPoolManagementDto.MEDIA_TYPE); assertEquals(response.getStatusCode(), Status.NOT_FOUND.getStatusCode()); } /** * Create a virtual appliance. Ask the IPs for a valid virtual appliance but invalid virtual * datacenter. */ @Test public void getVirtualApplianceActionIPsRaises404WhenVappNotBelongsToVDC() { VirtualAppliance vapp1 = vappGenerator.createInstance(vdc); setup(vapp1); ClientResponse response = get(resolveVirtualApplianceActionGetIPsURI(new Random().nextInt(), vapp1.getId()), SYSADMIN, SYSADMIN, IpsPoolManagementDto.MEDIA_TYPE); assertEquals(response.getStatusCode(), Status.NOT_FOUND.getStatusCode()); } @Test public void updateVirtualAppliance() throws Exception { VirtualAppliance vapp = vappGenerator.createInstance(vdc); setup(vapp); VirtualApplianceDto dto = ModelTransformer.transportFromPersistence(VirtualApplianceDto.class, vapp); String expectedName = "virtualApplianceName"; dto.setName(expectedName); String uri = resolveVirtualApplianceURI(vdc.getId(), vapp.getId()); ClientResponse response = put(uri, dto, SYSADMIN, SYSADMIN, VirtualApplianceDto.MEDIA_TYPE); assertEquals(response.getStatusCode(), 200); VirtualApplianceDto responseDto = response.getEntity(VirtualApplianceDto.class); assertEquals(responseDto.getName(), expectedName); } @Test public void updateVirtualApplianceWithNode() throws Exception { VirtualAppliance vapp = vappGenerator.createInstance(vdc); vapp.setNodeconnections("1,4"); setup(vapp); VirtualApplianceDto dto = ModelTransformer.transportFromPersistence(VirtualApplianceDto.class, vapp); String nodeconnections = "4,1"; dto.setNodeconnections(nodeconnections); String uri = resolveVirtualApplianceURI(vdc.getId(), vapp.getId()); ClientResponse response = put(uri, dto, SYSADMIN, SYSADMIN); assertEquals(response.getStatusCode(), 200); VirtualApplianceDto responseDto = response.getEntity(VirtualApplianceDto.class); assertEquals(responseDto.getNodeconnections(), nodeconnections); } }