mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			1754 lines
		
	
	
		
			63 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			1754 lines
		
	
	
		
			63 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # Licensed to the Apache Software Foundation (ASF) under one
 | |
| # or more contributor license agreements.  See the NOTICE file
 | |
| # distributed with this work for additional information
 | |
| # regarding copyright ownership.  The ASF licenses this file
 | |
| # to you under the Apache License, Version 2.0 (the
 | |
| # "License"); you may not use this file except in compliance
 | |
| # with the License.  You may obtain a copy of the License at
 | |
| #
 | |
| #   http://www.apache.org/licenses/LICENSE-2.0
 | |
| #
 | |
| # Unless required by applicable law or agreed to in writing,
 | |
| # software distributed under the License is distributed on an
 | |
| # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 | |
| # KIND, either express or implied.  See the License for the
 | |
| # specific language governing permissions and limitations
 | |
| # under the License.
 | |
| 
 | |
| """ Tests for Dynamic Compute Offering Feature
 | |
| 
 | |
|     Test Plan: https://cwiki.apache.org/confluence/display/CLOUDSTACK
 | |
|     /Dynamic+ComputeOffering
 | |
| 
 | |
|     Issue Link: https://issues.apache.org/jira/browse/CLOUDSTACK-6147
 | |
| 
 | |
|     Feature Specifications: https://cwiki.apache.org/confluence/display/
 | |
|     CLOUDSTACK/Dynamic+Compute+Offering+FS
 | |
| """
 | |
| from marvin.cloudstackTestCase import cloudstackTestCase
 | |
| import unittest
 | |
| from marvin.lib.utils import (cleanup_resources,
 | |
|                               validateList,
 | |
|                               random_gen,
 | |
|                               get_hypervisor_type)
 | |
| from marvin.lib.base import (Account,
 | |
|                              VirtualMachine,
 | |
|                              ServiceOffering,
 | |
|                              Resources,
 | |
|                              AffinityGroup,
 | |
|                              Host)
 | |
| from marvin.lib.common import (get_zone,
 | |
|                                get_domain,
 | |
|                                get_template,
 | |
|                                verifyComputeOfferingCreation)
 | |
| 
 | |
| from nose.plugins.attrib import attr
 | |
| from marvin.codes import PASS, ADMIN_ACCOUNT, USER_ACCOUNT, FAILED
 | |
| from ddt import ddt, data
 | |
| 
 | |
| 
 | |
| @ddt
 | |
| class TestDynamicServiceOffering(cloudstackTestCase):
 | |
| 
 | |
|     """Test Dynamic Service Offerings
 | |
|     """
 | |
| 
 | |
|     @classmethod
 | |
|     def setUpClass(cls):
 | |
|         testClient = super(TestDynamicServiceOffering, cls).getClsTestClient()
 | |
|         cls.api_client = cls.apiclient = testClient.getApiClient()
 | |
|         cls.services = testClient.getParsedTestDataConfig()
 | |
| 
 | |
|         # Get Zone, Domain and templates
 | |
|         cls.domain = get_domain(cls.apiclient)
 | |
|         cls.zone = get_zone(cls.apiclient, testClient.getZoneForTests())
 | |
|         cls.services['mode'] = cls.zone.networktype
 | |
|         cls.hypervisor = testClient.getHypervisorInfo()
 | |
|         if cls.hypervisor.lower() in ['lxc']:
 | |
|             raise unittest.SkipTest("dynamic scaling feature is not supported on %s" % cls.hypervisor.lower())
 | |
| 
 | |
|         cls.template = get_template(
 | |
|             cls.apiclient,
 | |
|             cls.zone.id,
 | |
|             cls.services["ostype"]
 | |
|         )
 | |
|         if cls.template == FAILED:
 | |
|             assert False, "get_template() failed to return template\
 | |
|                     with description %s" % cls.services["ostype"]
 | |
|         cls.services["virtual_machine"]["zoneid"] = cls.zone.id
 | |
|         cls.services["virtual_machine"]["template"] = cls.template.id
 | |
|         cls._cleanup = []
 | |
|         return
 | |
| 
 | |
|     @classmethod
 | |
|     def tearDownClass(cls):
 | |
|         try:
 | |
|             # Cleanup resources used
 | |
|             cleanup_resources(cls.api_client, cls._cleanup)
 | |
|         except Exception as e:
 | |
|             raise Exception("Warning: Exception during cleanup : %s" % e)
 | |
|         return
 | |
| 
 | |
|     def setUp(self):
 | |
|         self.apiclient = self.testClient.getApiClient()
 | |
|         self.dbclient = self.testClient.getDbConnection()
 | |
|         self.cleanup_co = []
 | |
|         self.cleanup = []
 | |
|         return
 | |
| 
 | |
|     def tearDown(self):
 | |
|         try:
 | |
|             # Clean up compute offerings
 | |
|             cleanup_resources(self.apiclient, self.cleanup)
 | |
| 
 | |
|             # Clean up compute offerings
 | |
|             cleanup_resources(self.apiclient, self.cleanup_co)
 | |
| 
 | |
|             self.cleanup_co[:] = []
 | |
|             self.cleanup[:] = []
 | |
|         except Exception as e:
 | |
|             raise Exception("Warning: Exception during cleanup : %s" % e)
 | |
|         return
 | |
| 
 | |
|     @attr(tags=["basic", "advanced"])
 | |
|     def test_create_normal_compute_offering(self):
 | |
|         """ Create normal compute offering with non zero values for cpu,
 | |
|             cpu number and memory"""
 | |
| 
 | |
|         # Steps:
 | |
|         # 1. Create normal compute offering with non zero values
 | |
|         # for cpu number, cpu speed, memory
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. Compute offering should be created
 | |
| 
 | |
|         self.services["service_offering"]["cpunumber"] = 2
 | |
|         self.services["service_offering"]["cpuspeed"] = 256
 | |
|         self.services["service_offering"]["memory"] = 128
 | |
| 
 | |
|         serviceOffering = ServiceOffering.create(
 | |
|             self.api_client,
 | |
|             self.services["service_offering"])
 | |
|         self.assertEqual(
 | |
|             verifyComputeOfferingCreation(
 | |
|                 self.apiclient,
 | |
|                 serviceOffering.id),
 | |
|             PASS,
 | |
|             "Compute Offering verification failed")
 | |
| 
 | |
|         self.cleanup_co.append(serviceOffering)
 | |
|         return
 | |
| 
 | |
|     @attr(tags=["basic", "advanced"])
 | |
|     def test_create_dynamic_compute_offering(self):
 | |
|         """ Create dynamic compute offering with cpunumber, cpuspeed and memory
 | |
|             not specified"""
 | |
| 
 | |
|         # Steps:
 | |
|         # 1. Create dynamic compute offering with values for cpu number,
 | |
|         #    cpu speed, memory not specified
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. Compute offering should be created
 | |
| 
 | |
|         self.services["service_offering"]["cpunumber"] = ""
 | |
|         self.services["service_offering"]["cpuspeed"] = ""
 | |
|         self.services["service_offering"]["memory"] = ""
 | |
| 
 | |
|         serviceOffering = ServiceOffering.create(
 | |
|             self.api_client,
 | |
|             self.services["service_offering"])
 | |
|         self.assertEqual(
 | |
|             verifyComputeOfferingCreation(
 | |
|                 self.apiclient,
 | |
|                 serviceOffering.id),
 | |
|             PASS,
 | |
|             "Compute Offering verification failed")
 | |
| 
 | |
|         self.cleanup_co.append(serviceOffering)
 | |
|         return
 | |
| 
 | |
|     @attr(tags=["basic", "advanced"])
 | |
|     def test_create_dynamic_compute_offering_no_cpunumber(self):
 | |
|         """ Create dynamic compute offering with only cpunumber unspecified"""
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. Compute Offering creation should fail
 | |
| 
 | |
|         self.services["service_offering"]["cpunumber"] = ""
 | |
|         self.services["service_offering"]["cpuspeed"] = 256
 | |
|         self.services["service_offering"]["memory"] = 128
 | |
| 
 | |
|         try:
 | |
|             serviceOffering = ServiceOffering.create(
 | |
|                 self.api_client,
 | |
|                 self.services["service_offering"])
 | |
|             self.cleanup_co.append(serviceOffering)
 | |
|             self.fail(
 | |
|                 "Compute Offering creation succeeded, it should have failed")
 | |
|         except Exception:
 | |
|             self.debug("Compute Offering Creation failed as expected")
 | |
|         return
 | |
| 
 | |
|     @attr(tags=["basic", "advanced"])
 | |
|     def test_create_dynamic_compute_offering_no_cpuspeed(self):
 | |
|         """ Create dynamic compute offering with only cpuspeed unspecified"""
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. Compute offering creation should fail
 | |
| 
 | |
|         self.services["service_offering"]["cpunumber"] = 2
 | |
|         self.services["service_offering"]["cpuspeed"] = ""
 | |
|         self.services["service_offering"]["memory"] = 128
 | |
| 
 | |
|         try:
 | |
|             serviceOffering = ServiceOffering.create(
 | |
|                 self.api_client,
 | |
|                 self.services["service_offering"])
 | |
|             self.cleanup_co.append(serviceOffering)
 | |
|             self.fail(
 | |
|                 "Compute Offering creation succeeded, it should have failed")
 | |
|         except Exception:
 | |
|             self.debug("Compute Offering Creation failed as expected")
 | |
|         return
 | |
| 
 | |
|     @attr(tags=["basic", "advanced"])
 | |
|     def test_create_dynamic_compute_offering_no_memory(self):
 | |
|         """ Create dynamic compute offering with only memory unspecified"""
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. Compute offering creation should fail
 | |
| 
 | |
|         self.services["service_offering"]["cpunumber"] = 2
 | |
|         self.services["service_offering"]["cpuspeed"] = 256
 | |
|         self.services["service_offering"]["memory"] = ""
 | |
| 
 | |
|         try:
 | |
|             serviceOffering = ServiceOffering.create(
 | |
|                 self.api_client,
 | |
|                 self.services["service_offering"])
 | |
|             self.cleanup_co.append(serviceOffering)
 | |
|             self.fail(
 | |
|                 "Compute Offering creation succeeded, it should have failed")
 | |
|         except Exception:
 | |
|             self.debug("Compute Offering Creation failed as expected")
 | |
|         return
 | |
| 
 | |
|     @data(ADMIN_ACCOUNT, USER_ACCOUNT)
 | |
|     @attr(tags=["basic", "advanced"])
 | |
|     def test_deploy_virtual_machines_static_offering(self, value):
 | |
|         """Test deploy VM with static offering"""
 | |
| 
 | |
|         # Steps:
 | |
|         # 1. Create admin/user account and create its user api client
 | |
|         # 2. Create a static compute offering
 | |
|         # 3. Deploy a VM with account api client and static service offering
 | |
|         # 4. Repeat step 3 but also pass custom values for cpu number,
 | |
|         #    cpu speed and memory while deploying VM
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. Step 3 should succeed
 | |
|         # 2. Step 4 should fail
 | |
| 
 | |
|         isadmin = True
 | |
|         if value == USER_ACCOUNT:
 | |
|             isadmin = False
 | |
| 
 | |
|         # Create Account
 | |
|         self.account = Account.create(
 | |
|             self.apiclient,
 | |
|             self.services["account"],
 | |
|             domainid=self.domain.id,
 | |
|             admin=isadmin)
 | |
|         apiclient = self.testClient.getUserApiClient(
 | |
|             UserName=self.account.name,
 | |
|             DomainName=self.account.domain)
 | |
|         self.cleanup.append(self.account)
 | |
| 
 | |
|         # Create service offering
 | |
|         self.services["service_offering"]["cpunumber"] = 2
 | |
|         self.services["service_offering"]["cpuspeed"] = 256
 | |
|         self.services["service_offering"]["memory"] = 128
 | |
| 
 | |
|         serviceOffering = ServiceOffering.create(
 | |
|             self.apiclient,
 | |
|             self.services["service_offering"])
 | |
| 
 | |
|         self.cleanup_co.append(serviceOffering)
 | |
| 
 | |
|         # Deploy VM with static service offering
 | |
|         try:
 | |
|             VirtualMachine.create(
 | |
|                 apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering.id,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid)
 | |
|         except Exception as e:
 | |
|             self.fail("vm creation failed: %s" % e)
 | |
| 
 | |
|         # Deploy VM with static service offering, also with custom values
 | |
|         try:
 | |
|             VirtualMachine.create(
 | |
|                 apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering.id,
 | |
|                 customcpunumber=4,
 | |
|                 customcpuspeed=512,
 | |
|                 custommemory=256,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid)
 | |
|             self.fail("VM creation should have failed, it succeeded")
 | |
|         except Exception as e:
 | |
|             self.debug("vm creation failed as expected: %s" % e)
 | |
|         return
 | |
| 
 | |
|     @data(ADMIN_ACCOUNT, USER_ACCOUNT)
 | |
|     @attr(tags=["basic", "advanced"])
 | |
|     def test_deploy_virtual_machines_dynamic_offering(self, value):
 | |
|         """Test deploy VM with dynamic compute offering"""
 | |
| 
 | |
|         # Steps:
 | |
|         # 1. Create admin/user account and create its user api client
 | |
|         # 2. Create a dynamic service offering
 | |
|         # 3. Deploy a VM with account api client and dynamic service offering
 | |
|         #    without providing custom values for cpu number, cpu speed and
 | |
|         #    memory
 | |
|         # 4. Deploy a VM with account api client and dynamic service offering
 | |
|         #    providing custom values for cpu number, cpu speed and memory
 | |
|         # 5. Deploy a VM with account api client and dynamic service offering
 | |
|         #    providing custom values only for cpu number
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. Step 3 should fail
 | |
|         # 2. Step 4 should succeed
 | |
|         # 3. Step 5 should fail
 | |
| 
 | |
|         isadmin = True
 | |
|         if value == USER_ACCOUNT:
 | |
|             isadmin = False
 | |
| 
 | |
|         # Create Account and its api client
 | |
|         self.account = Account.create(
 | |
|             self.apiclient,
 | |
|             self.services["account"],
 | |
|             domainid=self.domain.id,
 | |
|             admin=isadmin)
 | |
|         apiclient = self.testClient.getUserApiClient(
 | |
|             UserName=self.account.name,
 | |
|             DomainName=self.account.domain)
 | |
|         self.cleanup.append(self.account)
 | |
| 
 | |
|         # Create dynamic service offering
 | |
|         self.services["service_offering"]["cpunumber"] = ""
 | |
|         self.services["service_offering"]["cpuspeed"] = ""
 | |
|         self.services["service_offering"]["memory"] = ""
 | |
| 
 | |
|         serviceOffering = ServiceOffering.create(
 | |
|             self.apiclient,
 | |
|             self.services["service_offering"])
 | |
| 
 | |
|         self.cleanup_co.append(serviceOffering)
 | |
| 
 | |
|         # Deploy VM with dynamic compute offering without providing
 | |
|         # custom values for
 | |
|         # cpu number, cpu speed and memory
 | |
|         try:
 | |
|             VirtualMachine.create(
 | |
|                 apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering.id,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid)
 | |
|             self.fail("VM creation succeeded, it should have failed")
 | |
|         except Exception as e:
 | |
|             self.debug("vm creation failed as expected with error: %s" % e)
 | |
| 
 | |
|         # Deploy VM with dynamic compute offering providing custom values for
 | |
|         # cpu number, cpu speed and memory
 | |
|         try:
 | |
|             VirtualMachine.create(
 | |
|                 apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering.id,
 | |
|                 customcpunumber=2,
 | |
|                 customcpuspeed=256,
 | |
|                 custommemory=128,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid)
 | |
|         except Exception as e:
 | |
|             self.fail("vm creation failed: %s" % e)
 | |
| 
 | |
|         # Deploy VM with dynamic compute offering providing custom values
 | |
|         # for only cpu number
 | |
|         try:
 | |
|             VirtualMachine.create(
 | |
|                 apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering.id,
 | |
|                 customcpunumber=2,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid)
 | |
|             self.fail("VM deployment should have failed, it succeeded")
 | |
|         except Exception as e:
 | |
|             self.debug("vm creation failed as expected: %s" % e)
 | |
|         return
 | |
| 
 | |
|     @data(ADMIN_ACCOUNT, USER_ACCOUNT)
 | |
|     @attr(tags=["basic", "advanced"])
 | |
|     def test_check_vm_stats(self, value):
 | |
|         """Deploy VM with dynamic service offering and check VM stats"""
 | |
| 
 | |
|         # Steps:
 | |
|         # 1. Create admin/user account and create its user api client
 | |
|         # 2. Create a dynamic service offering
 | |
|         # 3. Deploy a VM with account api client and dynamic service offering
 | |
|         #    providing custom values for cpu number, cpu speed and memory
 | |
|         # 4. List the VM and verify the dynamic parameters are same as passed
 | |
| 
 | |
|         isadmin = True
 | |
|         if value == USER_ACCOUNT:
 | |
|             isadmin = False
 | |
| 
 | |
|         # Create Account and api client
 | |
|         self.account = Account.create(
 | |
|             self.apiclient,
 | |
|             self.services["account"],
 | |
|             domainid=self.domain.id,
 | |
|             admin=isadmin)
 | |
|         apiclient = self.testClient.getUserApiClient(
 | |
|             UserName=self.account.name,
 | |
|             DomainName=self.account.domain)
 | |
|         self.cleanup.append(self.account)
 | |
| 
 | |
|         # Create dynamic compute offering
 | |
|         self.services["service_offering"]["cpunumber"] = ""
 | |
|         self.services["service_offering"]["cpuspeed"] = ""
 | |
|         self.services["service_offering"]["memory"] = ""
 | |
| 
 | |
|         serviceOffering = ServiceOffering.create(
 | |
|             self.apiclient,
 | |
|             self.services["service_offering"])
 | |
| 
 | |
|         self.cleanup_co.append(serviceOffering)
 | |
| 
 | |
|         # Custom values
 | |
|         customcpunumber = 2
 | |
|         customcpuspeed = 256
 | |
|         custommemory = 128
 | |
| 
 | |
|         # Deploy VM with dynamic service offering and the custom values
 | |
|         try:
 | |
|             virtualMachine = VirtualMachine.create(
 | |
|                 apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering.id,
 | |
|                 customcpunumber=customcpunumber,
 | |
|                 customcpuspeed=customcpuspeed,
 | |
|                 custommemory=custommemory,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid)
 | |
|         except Exception as e:
 | |
|             self.fail("vm creation failed: %s" % e)
 | |
| 
 | |
|         vmlist = VirtualMachine.list(self.apiclient, id=virtualMachine.id)
 | |
|         self.assertEqual(
 | |
|             validateList(vmlist)[0],
 | |
|             PASS,
 | |
|             "vm list validation failed")
 | |
|         vm = vmlist[0]
 | |
| 
 | |
|         # Verify the custom values
 | |
|         self.assertEqual(str(vm.cpunumber), str(customcpunumber), "vm cpu number %s\
 | |
|                  not matching with provided custom cpu number %s" %
 | |
|                          (vm.cpunumber, customcpunumber))
 | |
| 
 | |
|         self.assertEqual(str(vm.cpuspeed), str(customcpuspeed), "vm cpu speed %s\
 | |
|                  not matching with provided custom cpu speed %s" %
 | |
|                          (vm.cpuspeed, customcpuspeed))
 | |
| 
 | |
|         self.assertEqual(str(vm.memory), str(custommemory), "vm memory %s\
 | |
|                  not matching with provided custom memory %s" %
 | |
|                          (vm.memory, custommemory))
 | |
|         return
 | |
| 
 | |
| 
 | |
| @ddt
 | |
| class TestScaleVmDynamicServiceOffering(cloudstackTestCase):
 | |
| 
 | |
|     """Test scaling VMs with dynamic Service Offerings
 | |
|     """
 | |
| 
 | |
|     @classmethod
 | |
|     def setUpClass(cls):
 | |
|         cloudstackTestClient = super(
 | |
|             TestScaleVmDynamicServiceOffering,
 | |
|             cls).getClsTestClient()
 | |
|         cls.api_client = cloudstackTestClient.getApiClient()
 | |
|         cls.hypervisor = cls.testClient.getHypervisorInfo()
 | |
|         # Fill services from the external config file
 | |
|         cls.services = cloudstackTestClient.getParsedTestDataConfig()
 | |
| 
 | |
|         # Get Zone, Domain and templates
 | |
|         cls.domain = get_domain(cls.api_client)
 | |
|         cls.zone = get_zone(
 | |
|             cls.api_client,
 | |
|             cloudstackTestClient.getZoneForTests())
 | |
|         cls.mode = str(cls.zone.networktype).lower()
 | |
|         cls.template = get_template(
 | |
|             cls.api_client,
 | |
|             cls.zone.id,
 | |
|             cls.services["ostype"]
 | |
|         )
 | |
|         cls.services["virtual_machine"]["zoneid"] = cls.zone.id
 | |
|         cls.services["virtual_machine"]["template"] = cls.template.id
 | |
| 
 | |
|         cls._cleanup = []
 | |
|         cls.serviceOffering_static_1 = ServiceOffering.create(
 | |
|             cls.api_client,
 | |
|             cls.services["service_offering"])
 | |
|         cls._cleanup.append(cls.serviceOffering_static_1)
 | |
| 
 | |
|         if cls.hypervisor.lower() == "vmware":
 | |
|             virtual_machine = VirtualMachine.create(
 | |
|                 cls.api_client,
 | |
|                 cls.services["virtual_machine"],
 | |
|                 serviceofferingid=cls.serviceOffering_static_1.id,
 | |
|                 mode=cls.zone.networktype)
 | |
|             cls._cleanup.append(virtual_machine)
 | |
|             sshClient = virtual_machine.get_ssh_client()
 | |
|             result = str(
 | |
|                 sshClient.execute("service vmware-tools status")).lower()
 | |
|             if "running" not in result:
 | |
|                 cls.tearDownClass()
 | |
|                 raise unittest.SkipTest("Skipping scale VM operation because\
 | |
|                     VMware tools are not installed on the VM")
 | |
|         return
 | |
| 
 | |
|     @classmethod
 | |
|     def tearDownClass(cls):
 | |
|         try:
 | |
|             # Cleanup resources used
 | |
|             cleanup_resources(cls.api_client, cls._cleanup)
 | |
|         except Exception as e:
 | |
|             raise Exception("Warning: Exception during cleanup : %s" % e)
 | |
|         return
 | |
| 
 | |
|     def setUp(self):
 | |
|         self.apiclient = self.testClient.getApiClient()
 | |
|         self.dbclient = self.testClient.getDbConnection()
 | |
|         self.cleanup_co = []
 | |
|         self.cleanup = []
 | |
|         return
 | |
| 
 | |
|     def tearDown(self):
 | |
|         try:
 | |
|             # Clean up compute offerings
 | |
|             cleanup_resources(self.apiclient, self.cleanup)
 | |
| 
 | |
|             # Clean up compute offerings
 | |
|             cleanup_resources(self.apiclient, self.cleanup_co)
 | |
| 
 | |
|             self.cleanup_co[:] = []
 | |
|             self.cleanup[:] = []
 | |
|         except Exception as e:
 | |
|             raise Exception("Warning: Exception during cleanup : %s" % e)
 | |
|         return
 | |
| 
 | |
|     @data(ADMIN_ACCOUNT, USER_ACCOUNT)
 | |
|     @attr(tags=["basic", "advanced"])
 | |
|     def test_change_so_stopped_vm_static_to_static(self, value):
 | |
|         """Test scale stopped VM from static offering to static offering"""
 | |
| 
 | |
|         # Steps:
 | |
|         # 1. Create Account (admin/user) and its api client
 | |
|         # 2. Make two static service offerings
 | |
|         # 3. Deploy VM with one static offering
 | |
|         # 4. Stop the VM
 | |
|         # 5. Scale VM with 2nd static service offering
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. Scaling operation should be successful
 | |
| 
 | |
|         isadmin = True
 | |
|         if value == USER_ACCOUNT:
 | |
|             isadmin = False
 | |
| 
 | |
|         try:
 | |
|             # Create Account
 | |
|             self.account = Account.create(
 | |
|                 self.apiclient,
 | |
|                 self.services["account"],
 | |
|                 domainid=self.domain.id,
 | |
|                 admin=isadmin)
 | |
|             self.cleanup.append(self.account)
 | |
|             apiclient = self.testClient.getUserApiClient(
 | |
|                 UserName=self.account.name,
 | |
|                 DomainName=self.account.domain)
 | |
| 
 | |
|             # Create static service offerings (Second offering should have
 | |
|             # one of the custom values greater than 1st one, scaling down is
 | |
|             # not allowed
 | |
|             self.services["service_offering"]["cpunumber"] = "2"
 | |
|             self.services["service_offering"]["cpuspeed"] = "256"
 | |
|             self.services["service_offering"]["memory"] = "128"
 | |
| 
 | |
|             serviceOffering_static_1 = ServiceOffering.create(
 | |
|                 self.apiclient,
 | |
|                 self.services["service_offering"])
 | |
| 
 | |
|             self.services["service_offering"]["cpunumber"] = "4"
 | |
| 
 | |
|             serviceOffering_static_2 = ServiceOffering.create(
 | |
|                 self.apiclient,
 | |
|                 self.services["service_offering"])
 | |
| 
 | |
|             self.cleanup_co.append(serviceOffering_static_1)
 | |
|             self.cleanup_co.append(serviceOffering_static_2)
 | |
| 
 | |
|             # Deploy VM
 | |
|             virtualMachine = VirtualMachine.create(
 | |
|                 apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering_static_1.id,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid)
 | |
| 
 | |
|             # Stop VM
 | |
|             virtualMachine.stop(apiclient)
 | |
| 
 | |
|             # Scale VM to new static service offering
 | |
|             virtualMachine.scale(
 | |
|                 apiclient,
 | |
|                 serviceOfferingId=serviceOffering_static_2.id)
 | |
|         except Exception as e:
 | |
|             self.fail("Exception occurred: %s" % e)
 | |
|         return
 | |
| 
 | |
|     @data(ADMIN_ACCOUNT, USER_ACCOUNT)
 | |
|     @attr(tags=["basic", "advanced"])
 | |
|     def test_change_so_stopped_vm_static_to_dynamic(self, value):
 | |
|         """Test scale stopped VM from static offering to dynamic offering"""
 | |
| 
 | |
|         # Steps:
 | |
|         # 1. Create Account (admin/user) and its api client
 | |
|         # 2. Make static and dynamic service offerings
 | |
|         # 3. Deploy VM with static offering
 | |
|         # 4. Stop the VM
 | |
|         # 5. Scale VM with dynamic service offering providing all required
 | |
|         #    custom values
 | |
|         # 6. Deploy another VM with static offring and stop the VM
 | |
|         # 7. Scale VM with dynamic service offering providing only custom cpu
 | |
|         # number
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. Scale operation in step 5 should be successful
 | |
|         # 2. Scale operation in step 7 should fail
 | |
| 
 | |
|         isadmin = True
 | |
|         if value == USER_ACCOUNT:
 | |
|             isadmin = False
 | |
| 
 | |
|         try:
 | |
|             # Create Account and api client
 | |
|             self.account = Account.create(
 | |
|                 self.apiclient,
 | |
|                 self.services["account"],
 | |
|                 domainid=self.domain.id,
 | |
|                 admin=isadmin)
 | |
|             apiclient = self.testClient.getUserApiClient(
 | |
|                 UserName=self.account.name,
 | |
|                 DomainName=self.account.domain)
 | |
|             self.cleanup.append(self.account)
 | |
| 
 | |
|             # Create static and dynamic service offerings
 | |
|             self.services["service_offering"]["cpunumber"] = "2"
 | |
|             self.services["service_offering"]["cpuspeed"] = "256"
 | |
|             self.services["service_offering"]["memory"] = "128"
 | |
| 
 | |
|             serviceOffering_static = ServiceOffering.create(
 | |
|                 self.apiclient,
 | |
|                 self.services["service_offering"])
 | |
| 
 | |
|             self.services["service_offering"]["cpunumber"] = ""
 | |
|             self.services["service_offering"]["cpuspeed"] = ""
 | |
|             self.services["service_offering"]["memory"] = ""
 | |
| 
 | |
|             serviceOffering_dynamic = ServiceOffering.create(
 | |
|                 self.apiclient,
 | |
|                 self.services["service_offering"])
 | |
| 
 | |
|             self.cleanup_co.append(serviceOffering_static)
 | |
|             self.cleanup_co.append(serviceOffering_dynamic)
 | |
| 
 | |
|             # Deploy VM with static service offering
 | |
|             virtualMachine_1 = VirtualMachine.create(
 | |
|                 apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering_static.id,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid)
 | |
| 
 | |
|             # Stop VM
 | |
|             virtualMachine_1.stop(apiclient)
 | |
| 
 | |
|             # Scale VM to dynamic service offering proving all custom values
 | |
|             virtualMachine_1.scale(
 | |
|                 apiclient,
 | |
|                 serviceOfferingId=serviceOffering_dynamic.id,
 | |
|                 customcpunumber=4,
 | |
|                 customcpuspeed=256,
 | |
|                 custommemory=128)
 | |
| 
 | |
|             # Deploy VM with static service offering
 | |
|             virtualMachine_2 = VirtualMachine.create(
 | |
|                 apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering_static.id,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid)
 | |
| 
 | |
|             # Stop VM
 | |
|             virtualMachine_2.stop(apiclient)
 | |
|         except Exception as e:
 | |
|             self.fail("Exception occuered: %s" % e)
 | |
| 
 | |
|             # Scale VM to dynamic service offering proving only custom cpu
 | |
|             # number
 | |
|         with self.assertRaises(Exception):
 | |
|             virtualMachine_2.scale(
 | |
|                 apiclient,
 | |
|                 serviceOfferingId=serviceOffering_dynamic.id,
 | |
|                 customcpunumber=4)
 | |
|         return
 | |
| 
 | |
|     @data(ADMIN_ACCOUNT, USER_ACCOUNT)
 | |
|     @attr(tags=["basic", "advanced"])
 | |
|     def test_change_so_stopped_vm_dynamic_to_static(self, value):
 | |
|         """Test scale stopped VM from dynamic offering to static offering"""
 | |
| 
 | |
|         # Steps:
 | |
|         # 1. Create Account (admin/user) and its api client
 | |
|         # 2. Make static and dynamic service offerings
 | |
|         # 3. Deploy VM with dynamic service offering
 | |
|         # 4. Stop the VM
 | |
|         # 5. Scale VM with static service offering
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. Scale operation in step 5 should be successful
 | |
| 
 | |
|         isadmin = True
 | |
|         if value == USER_ACCOUNT:
 | |
|             isadmin = False
 | |
| 
 | |
|         try:
 | |
|             # Create account and api client
 | |
|             self.account = Account.create(
 | |
|                 self.apiclient,
 | |
|                 self.services["account"],
 | |
|                 domainid=self.domain.id,
 | |
|                 admin=isadmin)
 | |
|             apiclient = self.testClient.getUserApiClient(
 | |
|                 UserName=self.account.name,
 | |
|                 DomainName=self.account.domain)
 | |
|             self.cleanup.append(self.account)
 | |
| 
 | |
|             # Create dynamic and static service offering
 | |
|             self.services["service_offering"]["cpunumber"] = ""
 | |
|             self.services["service_offering"]["cpuspeed"] = ""
 | |
|             self.services["service_offering"]["memory"] = ""
 | |
| 
 | |
|             serviceOffering_dynamic = ServiceOffering.create(
 | |
|                 self.apiclient,
 | |
|                 self.services["service_offering"])
 | |
| 
 | |
|             self.services["service_offering"]["cpunumber"] = "4"
 | |
|             self.services["service_offering"]["cpuspeed"] = "256"
 | |
|             self.services["service_offering"]["memory"] = "128"
 | |
| 
 | |
|             serviceOffering_static = ServiceOffering.create(
 | |
|                 self.apiclient,
 | |
|                 self.services["service_offering"])
 | |
| 
 | |
|             self.cleanup_co.append(serviceOffering_static)
 | |
|             self.cleanup_co.append(serviceOffering_dynamic)
 | |
| 
 | |
|             # Deploy VM with dynamic service offering
 | |
|             virtualMachine = VirtualMachine.create(
 | |
|                 apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering_dynamic.id,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid,
 | |
|                 customcpunumber=2,
 | |
|                 customcpuspeed=256,
 | |
|                 custommemory=128)
 | |
| 
 | |
|             # Stop VM and verify that it is in stopped state
 | |
|             virtualMachine.stop(apiclient)
 | |
| 
 | |
|             # Scale VM to static service offering
 | |
|             virtualMachine.scale(
 | |
|                 apiclient,
 | |
|                 serviceOfferingId=serviceOffering_static.id)
 | |
|         except Exception as e:
 | |
|             self.fail("Exception occurred: %s" % e)
 | |
|         return
 | |
| 
 | |
|     @data(ADMIN_ACCOUNT, USER_ACCOUNT)
 | |
|     @attr(tags=["basic", "advanced"])
 | |
|     def test_change_so_stopped_vm_dynamic_to_dynamic(self, value):
 | |
|         """Test scale stopped VM from dynamic offering to dynamic offering"""
 | |
| 
 | |
|         # Steps:
 | |
|         # 1. Create Account (admin/user) and its api client
 | |
|         # 2. Make 2 dynamic service offerings
 | |
|         # 3. Deploy VM with dynamic service offering
 | |
|         # 4. Stop the VM
 | |
|         # 5. Scale VM with same dynamic service offering
 | |
|         # 6. Scale VM with other dynamic service offering
 | |
|         # 7. Scale VM with same/other dynamic offering but providing custom
 | |
|         #    value for only cpu number
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. Scale operation in step 5 should be successful
 | |
|         # 2. Scale operation in step 6 should be successful
 | |
|         # 3. Scale operation in step 7 should fail
 | |
| 
 | |
|         isadmin = True
 | |
|         if value == USER_ACCOUNT:
 | |
|             isadmin = False
 | |
| 
 | |
|         try:
 | |
|             # Create Account
 | |
|             self.account = Account.create(
 | |
|                 self.apiclient,
 | |
|                 self.services["account"],
 | |
|                 domainid=self.domain.id,
 | |
|                 admin=isadmin)
 | |
|             apiclient = self.testClient.getUserApiClient(
 | |
|                 UserName=self.account.name,
 | |
|                 DomainName=self.account.domain)
 | |
|             self.cleanup.append(self.account)
 | |
| 
 | |
|             # Create dynamic service offerings
 | |
|             self.services["service_offering"]["cpunumber"] = ""
 | |
|             self.services["service_offering"]["cpuspeed"] = ""
 | |
|             self.services["service_offering"]["memory"] = ""
 | |
| 
 | |
|             serviceOffering_dynamic_1 = ServiceOffering.create(
 | |
|                 self.apiclient,
 | |
|                 self.services["service_offering"])
 | |
| 
 | |
|             serviceOffering_dynamic_2 = ServiceOffering.create(
 | |
|                 self.apiclient,
 | |
|                 self.services["service_offering"])
 | |
| 
 | |
|             self.cleanup_co.append(serviceOffering_dynamic_1)
 | |
|             self.cleanup_co.append(serviceOffering_dynamic_2)
 | |
| 
 | |
|             # Deploy VM with dynamic service offering
 | |
|             virtualMachine = VirtualMachine.create(
 | |
|                 apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering_dynamic_1.id,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid,
 | |
|                 customcpunumber=2,
 | |
|                 customcpuspeed=256,
 | |
|                 custommemory=128)
 | |
| 
 | |
|             # Stop VM
 | |
|             virtualMachine.stop(apiclient)
 | |
| 
 | |
|             # Scale VM with same dynamic service offering
 | |
|             virtualMachine.scale(
 | |
|                 apiclient,
 | |
|                 serviceOfferingId=serviceOffering_dynamic_1.id,
 | |
|                 customcpunumber=4,
 | |
|                 customcpuspeed=512,
 | |
|                 custommemory=256)
 | |
| 
 | |
|             # Scale VM with other dynamic service offering
 | |
|             virtualMachine.scale(
 | |
|                 apiclient,
 | |
|                 serviceOfferingId=serviceOffering_dynamic_2.id,
 | |
|                 customcpunumber=4,
 | |
|                 customcpuspeed=512,
 | |
|                 custommemory=256)
 | |
|         except Exception as e:
 | |
|             self.fail("Exception occurred: %s" % e)
 | |
| 
 | |
|         # Scale VM with dynamic service offering proving custom value
 | |
|         # only for cpu number
 | |
|         with self.assertRaises(Exception):
 | |
|             virtualMachine.scale(
 | |
|                 apiclient,
 | |
|                 serviceOfferingId=serviceOffering_dynamic_1.id,
 | |
|                 customcpunumber=4)
 | |
|         return
 | |
| 
 | |
|     @data(ADMIN_ACCOUNT, USER_ACCOUNT)
 | |
|     @attr(tags=["basic", "advanced"],required_hardware="true")
 | |
|     def test_change_so_running_vm_static_to_static(self, value):
 | |
|         """Test scale running VM from static offering to static offering"""
 | |
| 
 | |
|         # Steps:
 | |
|         # 1. Create Account (admin/user) and its api client
 | |
|         # 2. Make two static service offerings
 | |
|         # 3. Deploy VM with one static offering
 | |
|         # 4. Scale VM with 2nd static service offering
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. Scaling operation should be successful
 | |
| 
 | |
|         hypervisor = get_hypervisor_type(self.apiclient)
 | |
|         if hypervisor.lower() in ["kvm", "hyperv", 'lxc']:
 | |
|             self.skipTest(
 | |
|                 "Scaling VM in running state is not supported on %s" % hypervisor)
 | |
| 
 | |
|         isadmin = True
 | |
|         if value == USER_ACCOUNT:
 | |
|             isadmin = False
 | |
| 
 | |
|         # Create Account and api client
 | |
|         self.account = Account.create(
 | |
|             self.apiclient,
 | |
|             self.services["account"],
 | |
|             domainid=self.domain.id,
 | |
|             admin=isadmin)
 | |
|         apiclient = self.testClient.getUserApiClient(
 | |
|             UserName=self.account.name,
 | |
|             DomainName=self.account.domain)
 | |
|         self.cleanup.append(self.account)
 | |
| 
 | |
|         # Create static service offerings
 | |
|         self.services["service_offering"]["cpunumber"] = "2"
 | |
|         self.services["service_offering"]["cpuspeed"] = "256"
 | |
|         self.services["service_offering"]["memory"] = "128"
 | |
| 
 | |
|         serviceOffering_static_1 = ServiceOffering.create(
 | |
|             self.apiclient,
 | |
|             self.services["service_offering"])
 | |
| 
 | |
|         self.services["service_offering"]["cpunumber"] = "4"
 | |
| 
 | |
|         serviceOffering_static_2 = ServiceOffering.create(
 | |
|             self.apiclient,
 | |
|             self.services["service_offering"])
 | |
| 
 | |
|         self.cleanup_co.append(serviceOffering_static_1)
 | |
|         self.cleanup_co.append(serviceOffering_static_2)
 | |
| 
 | |
|         # Deploy VM with static service offering
 | |
|         try:
 | |
|             virtualMachine = VirtualMachine.create(
 | |
|                 apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering_static_1.id,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid)
 | |
|         except Exception as e:
 | |
|             self.fail("vm creation failed: %s" % e)
 | |
| 
 | |
|         # Scale VM to other static service offering
 | |
|         try:
 | |
|             virtualMachine.scale(
 | |
|                 apiclient,
 | |
|                 serviceOfferingId=serviceOffering_static_2.id)
 | |
|         except Exception as e:
 | |
|             self.fail("Failure while changing service offering: %s" % e)
 | |
|         return
 | |
| 
 | |
|     @data(ADMIN_ACCOUNT, USER_ACCOUNT)
 | |
|     @attr(tags=["basic", "advanced"],required_hardware="true")
 | |
|     def test_change_so_running_vm_static_to_dynamic(self, value):
 | |
|         """Test scale running VM from static offering to dynamic offering"""
 | |
| 
 | |
|         # Steps:
 | |
|         # 1. Create Account (admin/user) and its api client
 | |
|         # 2. Make static and dynamic service offerings
 | |
|         # 3. Deploy VM with static offering
 | |
|         # 4. Scale VM with dynamic service offering providing all required
 | |
|         #    custom values
 | |
|         # 5. Deploy another VM with static offring
 | |
|         # 6. Scale VM with dynamic service offering providing only custom cpu
 | |
|         # number
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. Scale operation in step 4 should be successful
 | |
|         # 2. Scale operation in step 6 should fail
 | |
| 
 | |
|         hypervisor = get_hypervisor_type(self.apiclient)
 | |
|         if hypervisor.lower() in ["kvm", "hyperv", 'lxc']:
 | |
|             self.skipTest(
 | |
|                 "Scaling VM in running state is not supported on %s" % hypervisor)
 | |
| 
 | |
|         isadmin = True
 | |
|         if value == USER_ACCOUNT:
 | |
|             isadmin = False
 | |
| 
 | |
|         # Crate account and api client
 | |
|         self.account = Account.create(
 | |
|             self.apiclient,
 | |
|             self.services["account"],
 | |
|             domainid=self.domain.id,
 | |
|             admin=isadmin)
 | |
|         apiclient = self.testClient.getUserApiClient(
 | |
|             UserName=self.account.name,
 | |
|             DomainName=self.account.domain)
 | |
|         self.cleanup.append(self.account)
 | |
| 
 | |
|         # Create static and dynamic service offerings
 | |
|         self.services["service_offering"]["cpunumber"] = "2"
 | |
|         self.services["service_offering"]["cpuspeed"] = "256"
 | |
|         self.services["service_offering"]["memory"] = "128"
 | |
| 
 | |
|         serviceOffering_static = ServiceOffering.create(
 | |
|             self.apiclient,
 | |
|             self.services["service_offering"])
 | |
| 
 | |
|         self.services["service_offering"]["cpunumber"] = ""
 | |
|         self.services["service_offering"]["cpuspeed"] = ""
 | |
|         self.services["service_offering"]["memory"] = ""
 | |
| 
 | |
|         serviceOffering_dynamic = ServiceOffering.create(
 | |
|             self.apiclient,
 | |
|             self.services["service_offering"])
 | |
| 
 | |
|         self.cleanup_co.append(serviceOffering_static)
 | |
|         self.cleanup_co.append(serviceOffering_dynamic)
 | |
| 
 | |
|         # Deploy VM with static service offering
 | |
|         try:
 | |
|             virtualMachine_1 = VirtualMachine.create(
 | |
|                 apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering_static.id,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid)
 | |
|         except Exception as e:
 | |
|             self.fail("vm creation failed: %s" % e)
 | |
| 
 | |
|         # Scale VM to dynamic service offering
 | |
|         try:
 | |
|             virtualMachine_1.scale(
 | |
|                 apiclient,
 | |
|                 serviceOfferingId=serviceOffering_dynamic.id,
 | |
|                 customcpunumber=4,
 | |
|                 customcpuspeed=256,
 | |
|                 custommemory=128)
 | |
|         except Exception as e:
 | |
|             self.fail("Failure while changing service offering: %s" % e)
 | |
| 
 | |
|         try:
 | |
|             virtualMachine_2 = VirtualMachine.create(
 | |
|                 apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering_static.id,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid)
 | |
|         except Exception as e:
 | |
|             self.fail("vm creation failed: %s" % e)
 | |
| 
 | |
|         try:
 | |
|             virtualMachine_2.scale(
 | |
|                 apiclient,
 | |
|                 serviceOfferingId=serviceOffering_dynamic.id,
 | |
|                 customcpunumber=4)
 | |
|             self.fail(
 | |
|                 "Changing service offering with incomplete data should\
 | |
|                  have failed, it succeeded")
 | |
|         except Exception as e:
 | |
|             self.debug(
 | |
|                 "Failure while changing service offering as expected: %s" %
 | |
|                 e)
 | |
| 
 | |
|         return
 | |
| 
 | |
|     @data(ADMIN_ACCOUNT, USER_ACCOUNT)
 | |
|     @attr(tags=["basic", "advanced"],required_hardware="true")
 | |
|     def test_change_so_running_vm_dynamic_to_static(self, value):
 | |
|         """Test scale running VM from dynamic offering to static offering"""
 | |
| 
 | |
|         # Steps:
 | |
|         # 1. Create Account (admin/user) and its api client
 | |
|         # 2. Make static and dynamic service offerings
 | |
|         # 3. Deploy VM with dynamic service offering
 | |
|         # 4. Scale VM with static service offering
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. Scale operation in step 4 should be successful
 | |
|         hypervisor = get_hypervisor_type(self.apiclient)
 | |
|         if hypervisor.lower() in ["kvm", "hyperv", 'lxc']:
 | |
|             self.skipTest(
 | |
|                 "Scaling VM in running state is not supported on %s" % hypervisor)
 | |
| 
 | |
|         isadmin = True
 | |
|         if value == USER_ACCOUNT:
 | |
|             isadmin = False
 | |
| 
 | |
|         # Create account and api client
 | |
|         self.account = Account.create(
 | |
|             self.apiclient,
 | |
|             self.services["account"],
 | |
|             domainid=self.domain.id,
 | |
|             admin=isadmin)
 | |
|         apiclient = self.testClient.getUserApiClient(
 | |
|             UserName=self.account.name,
 | |
|             DomainName=self.account.domain)
 | |
|         self.cleanup.append(self.account)
 | |
| 
 | |
|         # Create dynamic and static service offerings
 | |
|         self.services["service_offering"]["cpunumber"] = ""
 | |
|         self.services["service_offering"]["cpuspeed"] = ""
 | |
|         self.services["service_offering"]["memory"] = ""
 | |
| 
 | |
|         serviceOffering_dynamic = ServiceOffering.create(
 | |
|             self.apiclient,
 | |
|             self.services["service_offering"])
 | |
| 
 | |
|         self.services["service_offering"]["cpunumber"] = "4"
 | |
|         self.services["service_offering"]["cpuspeed"] = "256"
 | |
|         self.services["service_offering"]["memory"] = "128"
 | |
| 
 | |
|         serviceOffering_static = ServiceOffering.create(
 | |
|             self.apiclient,
 | |
|             self.services["service_offering"])
 | |
| 
 | |
|         self.cleanup_co.append(serviceOffering_static)
 | |
|         self.cleanup_co.append(serviceOffering_dynamic)
 | |
| 
 | |
|         # deploy VM with dynamic service offering
 | |
|         try:
 | |
|             virtualMachine = VirtualMachine.create(
 | |
|                 apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering_dynamic.id,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid,
 | |
|                 customcpunumber=2,
 | |
|                 customcpuspeed=256,
 | |
|                 custommemory=128)
 | |
|         except Exception as e:
 | |
|             self.fail("vm creation failed: %s" % e)
 | |
| 
 | |
|         # Scale VM to static service offering
 | |
|         try:
 | |
|             virtualMachine.scale(
 | |
|                 apiclient,
 | |
|                 serviceOfferingId=serviceOffering_static.id)
 | |
|         except Exception as e:
 | |
|             self.fail("Failure while changing service offering: %s" % e)
 | |
| 
 | |
|         return
 | |
| 
 | |
|     @data(ADMIN_ACCOUNT, USER_ACCOUNT)
 | |
|     @attr(tags=["basic", "advanced"],required_hardware="true")
 | |
|     def test_change_so_running_vm_dynamic_to_dynamic(self, value):
 | |
|         """Test scale running VM from dynamic offering to dynamic offering"""
 | |
| 
 | |
|         # Steps:
 | |
|         # 1. Create Account (admin/user) and its api client
 | |
|         # 2. Make 2 dynamic service offerings
 | |
|         # 3. Deploy VM with dynamic service offering
 | |
|         # 4. Scale VM with same dynamic service offering
 | |
|         # 5. Scale VM with other dynamic service offering
 | |
|         # 6. Scale VM with same/other dynamic offering but providing custom
 | |
|         #    value for only cpu number
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. Scale operation in step 4 should be successful
 | |
|         # 2. Scale operation in step 5 should be successful
 | |
|         # 3. Scale operation in step 6 should fail
 | |
| 
 | |
|         hypervisor = get_hypervisor_type(self.apiclient)
 | |
|         if hypervisor.lower() in ["kvm", "hyperv", "lxc"]:
 | |
|             self.skipTest(
 | |
|                 "Scaling VM in running state is not supported on %s" % hypervisor)
 | |
| 
 | |
|         isadmin = True
 | |
|         if value == USER_ACCOUNT:
 | |
|             isadmin = False
 | |
| 
 | |
|         # Create account and api client
 | |
|         self.account = Account.create(
 | |
|             self.apiclient,
 | |
|             self.services["account"],
 | |
|             domainid=self.domain.id,
 | |
|             admin=isadmin)
 | |
|         apiclient = self.testClient.getUserApiClient(
 | |
|             UserName=self.account.name,
 | |
|             DomainName=self.account.domain)
 | |
|         self.cleanup.append(self.account)
 | |
| 
 | |
|         # Create dynamic service offerings
 | |
|         self.services["service_offering"]["cpunumber"] = ""
 | |
|         self.services["service_offering"]["cpuspeed"] = ""
 | |
|         self.services["service_offering"]["memory"] = ""
 | |
| 
 | |
|         serviceOffering_dynamic_1 = ServiceOffering.create(
 | |
|             self.apiclient,
 | |
|             self.services["service_offering"])
 | |
| 
 | |
|         serviceOffering_dynamic_2 = ServiceOffering.create(
 | |
|             self.apiclient,
 | |
|             self.services["service_offering"])
 | |
| 
 | |
|         self.cleanup_co.append(serviceOffering_dynamic_1)
 | |
|         self.cleanup_co.append(serviceOffering_dynamic_2)
 | |
| 
 | |
|         # Deploy VM with dynamic service offering
 | |
|         try:
 | |
|             virtualMachine = VirtualMachine.create(
 | |
|                 apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering_dynamic_1.id,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid,
 | |
|                 customcpunumber=2,
 | |
|                 customcpuspeed=256,
 | |
|                 custommemory=128)
 | |
|         except Exception as e:
 | |
|             self.fail("vm creation failed: %s" % e)
 | |
| 
 | |
|         # Scale VM with same dynamic offering
 | |
|         try:
 | |
|             virtualMachine.scale(
 | |
|                 apiclient,
 | |
|                 serviceOfferingId=serviceOffering_dynamic_1.id,
 | |
|                 customcpunumber=4,
 | |
|                 customcpuspeed=512,
 | |
|                 custommemory=256)
 | |
|         except Exception as e:
 | |
|             self.fail("Failure while changing service offering: %s" % e)
 | |
| 
 | |
|         # Scale VM with other dynamic service offering
 | |
|         try:
 | |
|             virtualMachine.scale(
 | |
|                 apiclient,
 | |
|                 serviceOfferingId=serviceOffering_dynamic_2.id,
 | |
|                 customcpunumber=4,
 | |
|                 customcpuspeed=512,
 | |
|                 custommemory=512)
 | |
|         except Exception as e:
 | |
|             self.fail("Failure while changing service offering: %s" % e)
 | |
| 
 | |
|         # Scale VM with dynamic offering proving custom value only for cpu
 | |
|         # number
 | |
|         try:
 | |
|             virtualMachine.scale(
 | |
|                 apiclient,
 | |
|                 serviceOfferingId=serviceOffering_dynamic_1.id,
 | |
|                 customcpunumber=4)
 | |
|             self.fail(
 | |
|                 "Changing service offering should have failed, it succeeded")
 | |
|         except Exception as e:
 | |
|             self.debug("Failure while changing service offering: %s" % e)
 | |
| 
 | |
|         return
 | |
| 
 | |
| 
 | |
| @ddt
 | |
| class TestAccountLimits(cloudstackTestCase):
 | |
| 
 | |
|     """Test max limit of account (cpunumber and memory) with dynamic
 | |
|        compute offering
 | |
|     """
 | |
| 
 | |
|     @classmethod
 | |
|     def setUpClass(cls):
 | |
|         cloudstackTestClient = super(TestAccountLimits, cls).getClsTestClient()
 | |
|         cls.api_client = cloudstackTestClient.getApiClient()
 | |
| 
 | |
|         # Fill services from the external config file
 | |
|         cls.services = cloudstackTestClient.getParsedTestDataConfig()
 | |
|         cls.hypervisor = cls.testClient.getHypervisorInfo()
 | |
|         if cls.hypervisor.lower() in ['lxc']:
 | |
|             raise unittest.SkipTest("dynamic scaling feature is not supported on %s" % cls.hypervisor.lower())
 | |
| 
 | |
|         # Get Zone, Domain and templates
 | |
|         cls.domain = get_domain(cls.api_client)
 | |
|         cls.zone = get_zone(
 | |
|             cls.api_client,
 | |
|             cloudstackTestClient.getZoneForTests())
 | |
|         cls.mode = str(cls.zone.networktype).lower()
 | |
|         cls.template = get_template(
 | |
|             cls.api_client,
 | |
|             cls.zone.id,
 | |
|             cls.services["ostype"]
 | |
|         )
 | |
|         cls.services["virtual_machine"]["zoneid"] = cls.zone.id
 | |
|         cls.services["virtual_machine"]["template"] = cls.template.id
 | |
|         cls._cleanup = []
 | |
|         return
 | |
| 
 | |
|     @classmethod
 | |
|     def tearDownClass(cls):
 | |
|         try:
 | |
|             # Cleanup resources used
 | |
|             cleanup_resources(cls.api_client, cls._cleanup)
 | |
|         except Exception as e:
 | |
|             raise Exception("Warning: Exception during cleanup : %s" % e)
 | |
|         return
 | |
| 
 | |
|     def setUp(self):
 | |
|         self.apiclient = self.testClient.getApiClient()
 | |
|         self.dbclient = self.testClient.getDbConnection()
 | |
|         self.cleanup_co = []
 | |
|         self.cleanup = []
 | |
|         return
 | |
| 
 | |
|     def tearDown(self):
 | |
|         try:
 | |
|             # Clean up compute offerings
 | |
|             cleanup_resources(self.apiclient, self.cleanup)
 | |
| 
 | |
|             # Clean up compute offerings
 | |
|             cleanup_resources(self.apiclient, self.cleanup_co)
 | |
| 
 | |
|             self.cleanup_co[:] = []
 | |
|             self.cleanup[:] = []
 | |
|         except Exception as e:
 | |
|             raise Exception("Warning: Exception during cleanup : %s" % e)
 | |
|         return
 | |
| 
 | |
|     @data(ADMIN_ACCOUNT, USER_ACCOUNT)
 | |
|     @attr(tags=["basic", "advanced"])
 | |
|     def test_max_account_cpus_deploy_VM(self, value):
 | |
|         """Test cpu limits of account while deploying VM with dynamic
 | |
|            compute offering"""
 | |
| 
 | |
|         # Steps:
 | |
|         # 1. Create Account (admin/user)
 | |
|         # 2. Update max cpu limit of account to 2
 | |
|         # 3. Create dynamic service offering
 | |
|         # 4. Deploy VM with dynamic service offering and cpu number 3
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. VM creation should fail
 | |
| 
 | |
|         isadmin = True
 | |
|         if value == USER_ACCOUNT:
 | |
|             isadmin = False
 | |
| 
 | |
|         # Create account and api client
 | |
|         self.account = Account.create(
 | |
|             self.apiclient,
 | |
|             self.services["account"],
 | |
|             domainid=self.domain.id,
 | |
|             admin=isadmin)
 | |
|         self.cleanup.append(self.account)
 | |
| 
 | |
|         Resources.updateLimit(self.apiclient,
 | |
|                               resourcetype=8,
 | |
|                               max=2,
 | |
|                               account=self.account.name,
 | |
|                               domainid=self.account.domainid)
 | |
| 
 | |
|         # Create dynamic service offerings
 | |
|         self.services["service_offering"]["cpunumber"] = ""
 | |
|         self.services["service_offering"]["cpuspeed"] = ""
 | |
|         self.services["service_offering"]["memory"] = ""
 | |
| 
 | |
|         serviceOffering_dynamic = ServiceOffering.create(
 | |
|             self.apiclient,
 | |
|             self.services["service_offering"])
 | |
| 
 | |
|         self.cleanup_co.append(serviceOffering_dynamic)
 | |
| 
 | |
|         # Deploy VM with dynamic service offering
 | |
|         try:
 | |
|             VirtualMachine.create(
 | |
|                 self.apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering_dynamic.id,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid,
 | |
|                 customcpunumber=3,
 | |
|                 customcpuspeed=256,
 | |
|                 custommemory=128)
 | |
|             self.fail("vm creation should have failed, it succeeded")
 | |
|         except Exception as e:
 | |
|             self.debug("vm creation failed as expected with error: %s" % e)
 | |
| 
 | |
|         return
 | |
| 
 | |
|     @data(ADMIN_ACCOUNT, USER_ACCOUNT)
 | |
|     @attr(tags=["basic", "advanced"])
 | |
|     def test_max_account_cpus_scale_VM(self, value):
 | |
|         """Test cpu limits of account while scaling VM with dynamic
 | |
|            compute offering"""
 | |
| 
 | |
|         # Steps:
 | |
|         # 1. Create Account (admin/user)
 | |
|         # 2. Update max cpu limit of account to 2
 | |
|         # 3. Create dynamic service offering
 | |
|         # 4. Deploy VM with dynamic service offering and cpu number 2
 | |
|         # 5. Try to Scale VM with dynamic service offering and cpu number 3
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. VM creation should succeed
 | |
|         # 2. VM scaling operation should fail
 | |
| 
 | |
|         isadmin = True
 | |
|         if value == USER_ACCOUNT:
 | |
|             isadmin = False
 | |
| 
 | |
|         # Create account and api client
 | |
|         self.account = Account.create(
 | |
|             self.apiclient,
 | |
|             self.services["account"],
 | |
|             domainid=self.domain.id,
 | |
|             admin=isadmin)
 | |
|         self.cleanup.append(self.account)
 | |
| 
 | |
|         Resources.updateLimit(self.apiclient,
 | |
|                               resourcetype=8,
 | |
|                               max=2,
 | |
|                               account=self.account.name,
 | |
|                               domainid=self.account.domainid)
 | |
| 
 | |
|         # Create dynamic service offerings
 | |
|         self.services["service_offering"]["cpunumber"] = ""
 | |
|         self.services["service_offering"]["cpuspeed"] = ""
 | |
|         self.services["service_offering"]["memory"] = ""
 | |
| 
 | |
|         serviceOffering_dynamic = ServiceOffering.create(
 | |
|             self.apiclient,
 | |
|             self.services["service_offering"])
 | |
| 
 | |
|         self.cleanup_co.append(serviceOffering_dynamic)
 | |
| 
 | |
|         # Deploy VM with dynamic service offering
 | |
|         try:
 | |
|             virtualMachine = VirtualMachine.create(
 | |
|                 self.apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering_dynamic.id,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid,
 | |
|                 customcpunumber=2,
 | |
|                 customcpuspeed=256,
 | |
|                 custommemory=128)
 | |
|         except Exception as e:
 | |
|             self.fail("vm creation failed: %s" % e)
 | |
| 
 | |
|         # Scale VM with same dynamic offering
 | |
|         try:
 | |
|             virtualMachine.scale(
 | |
|                 self.apiclient,
 | |
|                 serviceOfferingId=serviceOffering_dynamic.id,
 | |
|                 customcpunumber=4,
 | |
|                 customcpuspeed=512,
 | |
|                 custommemory=256)
 | |
|             self.fail("Scaling virtual machine with cpu number more than \
 | |
|                     allowed limit (of account) succeeded, should have failed")
 | |
|         except Exception as e:
 | |
|             self.debug(
 | |
|                 "Failure while changing service offering as expected: %s" %
 | |
|                 e)
 | |
| 
 | |
|         return
 | |
| 
 | |
|     @data(ADMIN_ACCOUNT, USER_ACCOUNT)
 | |
|     @attr(tags=["basic", "advanced"])
 | |
|     def test_max_account_memory_deploy_VM(self, value):
 | |
|         """Test memory limits of account while deploying VM with dynamic
 | |
|            compute offering"""
 | |
| 
 | |
|         # Steps:
 | |
|         # 1. Create Account (admin/user)
 | |
|         # 2. Update max memory limit of account to 256
 | |
|         # 3. Create dynamic service offering
 | |
|         # 4. Deploy VM with dynamic service offering and memory 512
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. VM creation should fail
 | |
| 
 | |
|         isadmin = True
 | |
|         if value == USER_ACCOUNT:
 | |
|             isadmin = False
 | |
| 
 | |
|         # Create account and api client
 | |
|         self.account = Account.create(
 | |
|             self.apiclient,
 | |
|             self.services["account"],
 | |
|             domainid=self.domain.id,
 | |
|             admin=isadmin)
 | |
|         self.cleanup.append(self.account)
 | |
| 
 | |
|         Resources.updateLimit(self.apiclient,
 | |
|                               resourcetype=9,
 | |
|                               max=256,
 | |
|                               account=self.account.name,
 | |
|                               domainid=self.account.domainid)
 | |
| 
 | |
|         # Create dynamic service offerings
 | |
|         self.services["service_offering"]["cpunumber"] = ""
 | |
|         self.services["service_offering"]["cpuspeed"] = ""
 | |
|         self.services["service_offering"]["memory"] = ""
 | |
| 
 | |
|         serviceOffering_dynamic = ServiceOffering.create(
 | |
|             self.apiclient,
 | |
|             self.services["service_offering"])
 | |
| 
 | |
|         self.cleanup_co.append(serviceOffering_dynamic)
 | |
| 
 | |
|         # Deploy VM with dynamic service offering
 | |
|         try:
 | |
|             VirtualMachine.create(
 | |
|                 self.apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering_dynamic.id,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid,
 | |
|                 customcpunumber=3,
 | |
|                 customcpuspeed=256,
 | |
|                 custommemory=512)
 | |
|             self.fail("vm creation should have failed, it succeeded")
 | |
|         except Exception as e:
 | |
|             self.debug("vm creation failed as expected with error: %s" % e)
 | |
| 
 | |
|         return
 | |
| 
 | |
|     @data(ADMIN_ACCOUNT, USER_ACCOUNT)
 | |
|     @attr(tags=["basic", "advanced"])
 | |
|     def test_max_account_memory_scale_VM(self, value):
 | |
|         """Test memory limits of account while scaling VM with
 | |
|            dynamic compute offering"""
 | |
| 
 | |
|         # Steps:
 | |
|         # 1. Create Account (admin/user)
 | |
|         # 2. Update max memory limit of account to 256
 | |
|         # 3. Create dynamic service offering
 | |
|         # 4. Deploy VM with dynamic service offering and memory 256
 | |
|         # 5. Try to Scale VM with dynamic service offering and memory 512
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. VM creation should succeed
 | |
|         # 2. VM scaling operation should fail
 | |
| 
 | |
|         isadmin = True
 | |
|         if value == USER_ACCOUNT:
 | |
|             isadmin = False
 | |
| 
 | |
|         # Create account and api client
 | |
|         self.account = Account.create(
 | |
|             self.apiclient,
 | |
|             self.services["account"],
 | |
|             domainid=self.domain.id,
 | |
|             admin=isadmin)
 | |
|         self.cleanup.append(self.account)
 | |
| 
 | |
|         Resources.updateLimit(self.apiclient,
 | |
|                               resourcetype=9,
 | |
|                               max=256,
 | |
|                               account=self.account.name,
 | |
|                               domainid=self.account.domainid)
 | |
| 
 | |
|         # Create dynamic service offerings
 | |
|         self.services["service_offering"]["cpunumber"] = ""
 | |
|         self.services["service_offering"]["cpuspeed"] = ""
 | |
|         self.services["service_offering"]["memory"] = ""
 | |
| 
 | |
|         serviceOffering_dynamic = ServiceOffering.create(
 | |
|             self.apiclient,
 | |
|             self.services["service_offering"])
 | |
| 
 | |
|         self.cleanup_co.append(serviceOffering_dynamic)
 | |
| 
 | |
|         # Deploy VM with dynamic service offering
 | |
|         try:
 | |
|             virtualMachine = VirtualMachine.create(
 | |
|                 self.apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering_dynamic.id,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid,
 | |
|                 customcpunumber=2,
 | |
|                 customcpuspeed=256,
 | |
|                 custommemory=256)
 | |
|         except Exception as e:
 | |
|             self.fail("vm creation failed: %s" % e)
 | |
| 
 | |
|         # Scale VM with same dynamic offering
 | |
|         try:
 | |
|             virtualMachine.scale(
 | |
|                 self.apiclient,
 | |
|                 serviceOfferingId=serviceOffering_dynamic.id,
 | |
|                 customcpunumber=4,
 | |
|                 customcpuspeed=512,
 | |
|                 custommemory=512)
 | |
|             self.fail("Scaling virtual machine with cpu number more than \
 | |
|                     allowed limit (of account) succeeded, should have failed")
 | |
|         except Exception as e:
 | |
|             self.debug(
 | |
|                 "Failure while changing service offering as expected: %s" %
 | |
|                 e)
 | |
| 
 | |
|         return
 | |
| 
 | |
| 
 | |
| @ddt
 | |
| class TestAffinityGroup(cloudstackTestCase):
 | |
| 
 | |
|     """Test affinity group working with VMs created with dynamic offering
 | |
|     """
 | |
| 
 | |
|     @classmethod
 | |
|     def setUpClass(cls):
 | |
|         cloudstackTestClient = super(TestAffinityGroup, cls).getClsTestClient()
 | |
|         cls.api_client = cloudstackTestClient.getApiClient()
 | |
| 
 | |
|         # Fill services from the external config file
 | |
|         cls.services = cloudstackTestClient.getParsedTestDataConfig()
 | |
|         cls.hypervisor = cls.testClient.getHypervisorInfo()
 | |
|         if cls.hypervisor.lower() in ['lxc']:
 | |
|             raise unittest.SkipTest("dynamic scaling feature is not supported on %s" % cls.hypervisor.lower())
 | |
| 
 | |
|         # Get Zone, Domain and templates
 | |
|         cls.domain = get_domain(cls.api_client)
 | |
|         cls.zone = get_zone(
 | |
|             cls.api_client,
 | |
|             cloudstackTestClient.getZoneForTests())
 | |
|         cls.mode = str(cls.zone.networktype).lower()
 | |
|         cls.template = get_template(
 | |
|             cls.api_client,
 | |
|             cls.zone.id,
 | |
|             cls.services["ostype"]
 | |
|         )
 | |
|         cls.services["virtual_machine"]["zoneid"] = cls.zone.id
 | |
|         cls.services["virtual_machine"]["template"] = cls.template.id
 | |
|         cls._cleanup = []
 | |
|         return
 | |
| 
 | |
|     @classmethod
 | |
|     def tearDownClass(cls):
 | |
|         try:
 | |
|             # Cleanup resources used
 | |
|             cleanup_resources(cls.api_client, cls._cleanup)
 | |
|         except Exception as e:
 | |
|             raise Exception("Warning: Exception during cleanup : %s" % e)
 | |
|         return
 | |
| 
 | |
|     def setUp(self):
 | |
|         self.apiclient = self.testClient.getApiClient()
 | |
|         self.dbclient = self.testClient.getDbConnection()
 | |
|         self.cleanup_co = []
 | |
|         self.cleanup = []
 | |
|         return
 | |
| 
 | |
|     def tearDown(self):
 | |
|         try:
 | |
|             # Clean up compute offerings
 | |
|             cleanup_resources(self.apiclient, self.cleanup)
 | |
| 
 | |
|             # Clean up compute offerings
 | |
|             cleanup_resources(self.apiclient, self.cleanup_co)
 | |
| 
 | |
|             self.cleanup_co[:] = []
 | |
|             self.cleanup[:] = []
 | |
|         except Exception as e:
 | |
|             raise Exception("Warning: Exception during cleanup : %s" % e)
 | |
|         return
 | |
| 
 | |
|     @data(ADMIN_ACCOUNT, USER_ACCOUNT)
 | |
|     @attr(tags=["basic", "advanced"], BugId="7180", required_hardware="true")
 | |
|     def test_deploy_VM_with_affinity_group(self, value):
 | |
|         """Test deploy VMs with affinity group and dynamic compute offering"""
 | |
| 
 | |
|         # Steps:
 | |
|         # 1. Create Account (admin/user)
 | |
|         # 2. Update max cpu limit of account to 2
 | |
|         # 3. Create dynamic service offering
 | |
|         # 4. Deploy VM with dynamic service offering and cpu number 3
 | |
| 
 | |
|         # Validations:
 | |
|         # 1. VM creation should fail
 | |
| 
 | |
|         isadmin = True
 | |
|         if value == USER_ACCOUNT:
 | |
|             isadmin = False
 | |
| 
 | |
|         # Create account and api client
 | |
|         self.account = Account.create(
 | |
|             self.apiclient,
 | |
|             self.services["account"],
 | |
|             domainid=self.domain.id,
 | |
|             admin=isadmin)
 | |
|         self.cleanup.append(self.account)
 | |
| 
 | |
|         # Create dynamic service offerings
 | |
|         self.services["service_offering"]["cpunumber"] = ""
 | |
|         self.services["service_offering"]["cpuspeed"] = ""
 | |
|         self.services["service_offering"]["memory"] = ""
 | |
| 
 | |
|         serviceOffering_dynamic = ServiceOffering.create(
 | |
|             self.apiclient,
 | |
|             self.services["service_offering"])
 | |
| 
 | |
|         self.cleanup_co.append(serviceOffering_dynamic)
 | |
| 
 | |
|         self.services["host_anti_affinity"][
 | |
|             "name"] = "aff_grp_" + random_gen(size=6)
 | |
|         affinityGroup = AffinityGroup.create(
 | |
|             self.apiclient,
 | |
|             self.services["host_anti_affinity"],
 | |
|             self.account.name,
 | |
|             self.domain.id)
 | |
| 
 | |
|         # Deploy VM with dynamic service offering
 | |
|         try:
 | |
|             virtualMachine = VirtualMachine.create(
 | |
|                 self.apiclient,
 | |
|                 self.services["virtual_machine"],
 | |
|                 serviceofferingid=serviceOffering_dynamic.id,
 | |
|                 accountid=self.account.name,
 | |
|                 domainid=self.account.domainid,
 | |
|                 customcpunumber=2,
 | |
|                 customcpuspeed=256,
 | |
|                 custommemory=128,
 | |
|                 affinitygroupnames=[
 | |
|                     affinityGroup.name])
 | |
|         except Exception as e:
 | |
|             self.fail("vm creation failed with error: %s" % e)
 | |
| 
 | |
|         otherHostsInCluster = Host.list(
 | |
|             self.apiclient,
 | |
|             virtualmachineid=virtualMachine.id)
 | |
|         if validateList(otherHostsInCluster)[0] == PASS:
 | |
|             try:
 | |
|                 VirtualMachine.create(
 | |
|                     self.apiclient,
 | |
|                     self.services["virtual_machine"],
 | |
|                     serviceofferingid=serviceOffering_dynamic.id,
 | |
|                     accountid=self.account.name,
 | |
|                     domainid=self.account.domainid,
 | |
|                     customcpunumber=2,
 | |
|                     customcpuspeed=256,
 | |
|                     custommemory=128,
 | |
|                     affinitygroupnames=[
 | |
|                         affinityGroup.name])
 | |
|             except Exception as e:
 | |
|                 self.fail("vm creation failed with error: %s" % e)
 | |
| 
 | |
|         else:
 | |
|             try:
 | |
|                 VirtualMachine.create(
 | |
|                     self.apiclient,
 | |
|                     self.services["virtual_machine"],
 | |
|                     serviceofferingid=serviceOffering_dynamic.id,
 | |
|                     accountid=self.account.name,
 | |
|                     domainid=self.account.domainid,
 | |
|                     customcpunumber=2,
 | |
|                     customcpuspeed=256,
 | |
|                     custommemory=128,
 | |
|                     affinitygroupnames=[
 | |
|                         affinityGroup.name])
 | |
|                 self.fail("vm creation should have failed, it succeeded")
 | |
|             except Exception as e:
 | |
|                 self.debug("vm creation failed as expected with error: %s" % e)
 | |
| 
 | |
|         return
 |