| # 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 |
| from marvin.lib.utils import * |
| from marvin.lib.base import * |
| from marvin.lib.common import * |
| |
| from nose.plugins.attrib import attr |
| from marvin.codes import PASS, ADMIN_ACCOUNT, USER_ACCOUNT |
| 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.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 succeded, 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 succeded, 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 succeded, 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 succeded, 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 succeded") |
| 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() |
| |
| # 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 = [] |
| 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 |
| |
| def stopVM(self, vm): |
| """Stop VM and verify that it is indeed in stopped state""" |
| try: |
| vm.stop(self.apiclient) |
| except Exception as e: |
| self.fail("Failed to stop VM: %s" % e) |
| |
| retriesCount = 10 |
| while True: |
| vmlist = VirtualMachine.list(self.apiclient, id=vm.id) |
| if str(vmlist[0].state).lower() == "stopped": |
| break |
| elif retriesCount == 0: |
| self.fail("Failed to stop VM even after 10 minutes") |
| else: |
| retriesCount -= 1 |
| time.sleep(60) |
| continue |
| # End while |
| 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 |
| |
| # 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 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 |
| 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) |
| |
| # Stop VM and verify it is in stopped state |
| self.stopVM(virtualMachine) |
| |
| # Scale VM to new 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"]) |
| 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 |
| |
| # 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 |
| 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) |
| |
| # Stop VM and verify it is in stopped state |
| self.stopVM(virtualMachine_1) |
| |
| # Scale VM to dynamic service offering proving all custom values |
| 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) |
| |
| # Deploy VM with static service offering |
| 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) |
| |
| # Stop VM and verify it is in stopped state |
| self.stopVM(virtualMachine_2) |
| |
| # Scale VM to dynamic service offering proving only custom cpu number |
| try: |
| virtualMachine_2.scale(apiclient, serviceOfferingId=serviceOffering_dynamic.id, |
| customcpunumber=4) |
| self.fail("Changing service offering with incomplete data should have failed, it succeded") |
| 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_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 |
| |
| # 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 |
| 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) |
| |
| # Stop VM and verify that it is in stopped state |
| self.stopVM(virtualMachine) |
| |
| # 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"]) |
| 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 |
| |
| # 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 |
| 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) |
| |
| # Stop VM and verify that it is in stopped state |
| self.stopVM(virtualMachine) |
| |
| # Scale VM with same dynamic service 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=256) |
| except Exception as e: |
| self.fail("Failure while changing service offering: %s" % e) |
| |
| # Scale VM with dynamic service 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 succeded") |
| except Exception as e: |
| self.debug("Failure while changing service offering: %s" % e) |
| |
| return |
| |
| @data(ADMIN_ACCOUNT, USER_ACCOUNT) |
| @attr(tags=["basic","advanced"]) |
| 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 |
| |
| 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"]) |
| 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 |
| |
| 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 succeded") |
| 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_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 |
| |
| 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"]) |
| 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 |
| |
| 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 succeded") |
| 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() |
| |
| # 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) succeded, 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) succeded, 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() |
| |
| # 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_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 succeded") |
| except Exception as e: |
| self.debug("vm creation failed as expected with error: %s" % e) |
| |
| return |