CLOUDSTACK-7594: Adding automation test cases for stopped VM test path

Signed-off-by: SrikanteswaraRao Talluri <tall...@apache.org>


Project: http://git-wip-us.apache.org/repos/asf/cloudstack/repo
Commit: http://git-wip-us.apache.org/repos/asf/cloudstack/commit/04409609
Tree: http://git-wip-us.apache.org/repos/asf/cloudstack/tree/04409609
Diff: http://git-wip-us.apache.org/repos/asf/cloudstack/diff/04409609

Branch: refs/heads/master
Commit: 04409609336f3aee1bc91c875dd3c3badcc71ae5
Parents: ba08229
Author: Ashutosh K <ashut...@clogeny.com>
Authored: Sun Feb 15 20:46:40 2015 -0800
Committer: SrikanteswaraRao Talluri <tall...@apache.org>
Committed: Fri Feb 20 20:02:08 2015 +0530

----------------------------------------------------------------------
 .../testpaths/testpath_stopped_vm.py            | 1006 ++++++++++++++++++
 1 file changed, 1006 insertions(+)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/cloudstack/blob/04409609/test/integration/testpaths/testpath_stopped_vm.py
----------------------------------------------------------------------
diff --git a/test/integration/testpaths/testpath_stopped_vm.py 
b/test/integration/testpaths/testpath_stopped_vm.py
new file mode 100644
index 0000000..18a17c3
--- /dev/null
+++ b/test/integration/testpaths/testpath_stopped_vm.py
@@ -0,0 +1,1006 @@
+# 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.
+""" Test Path for Deploy VM in stopped state
+"""
+from nose.plugins.attrib import attr
+from marvin.cloudstackTestCase import cloudstackTestCase
+from marvin.lib.utils import (cleanup_resources,
+                              validateList)
+from marvin.lib.base import (Account,
+                             ServiceOffering,
+                             VirtualMachine,
+                             User,
+                             Network,
+                             Router,
+                             DiskOffering,
+                             Volume,
+                             Iso,
+                             Template,
+                             Resources)
+from marvin.lib.common import (get_domain,
+                               get_zone,
+                               get_template,
+                               createEnabledNetworkOffering,
+                               wait_for_cleanup)
+from marvin.codes import (PASS,
+                          STOPPED,
+                          RUNNING,
+                          FAIL)
+from marvin.sshClient import SshClient
+import time
+
+
+def VerifyChangeInServiceOffering(self, virtualmachine, serviceoffering):
+    """List the VM and verify that the new values for cpuspeed,
+       cpunumber and memory match with the new service offering"""
+
+    exceptionOccured = False
+    exceptionMessage = ""
+    try:
+        vmlist = VirtualMachine.list(self.userapiclient, 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(serviceoffering.cpunumber),
+                         "vm cpu number %s not matching with cpu number in\
+                      service offering %s" %
+                         (vm.cpunumber, serviceoffering.cpunumber))
+
+        self.assertEqual(str(vm.cpuspeed), str(serviceoffering.cpuspeed),
+                         "vm cpu speed %s not matching with cpu speed in\
+                     service offering %s" %
+                         (vm.cpuspeed, serviceoffering.cpuspeed))
+
+        self.assertEqual(str(vm.memory), str(serviceoffering.memory),
+                         "vm memory %s not matching with memory in\
+                     service offering %s" %
+                         (vm.memory, serviceoffering.memory))
+    except Exception as e:
+        exceptionOccured = True
+        exceptionMessage = e
+    return [exceptionOccured, exceptionMessage]
+
+
+def VerifyRouterState(apiclient, account, domainid, desiredState,
+                      retries=0):
+    """List the router associated with the account and
+       verify that router state matches with the desired state
+       Return PASS/FAIL depending upon whether router state matches
+       or not"""
+
+    isRouterStateDesired = False
+    failureMessage = ""
+    while retries >= 0:
+        routers = Router.list(
+            apiclient,
+            account=account,
+            domainid=domainid,
+            listall=True
+        )
+        if str(routers[0].state).lower() == str(desiredState).lower():
+            isRouterStateDesired = True
+            break
+        time.sleep(60)
+        retries -= 1
+    # whileEnd
+
+    if not isRouterStateDesired:
+        failureMessage = "Router state should be %s,\
+                but it is %s" %\
+            (desiredState, routers[0].state)
+    return [isRouterStateDesired, failureMessage]
+
+
+def CreateEnabledNetworkOffering(apiclient, networkServices):
+    """Create network offering of given services and enable it"""
+
+    result = createEnabledNetworkOffering(apiclient, networkServices)
+    assert result[0] == PASS,\
+        "Network offering creation/enabling failed due to %s" % result[2]
+    return result[1]
+
+
+class TestAdvancedZoneStoppedVM(cloudstackTestCase):
+
+    @classmethod
+    def setUpClass(cls):
+        testClient = super(TestAdvancedZoneStoppedVM, cls).getClsTestClient()
+        cls.apiclient = testClient.getApiClient()
+        cls.testdata = testClient.getParsedTestDataConfig()
+
+        # Get Zone, Domain and templates
+        cls.domain = get_domain(cls.apiclient)
+        cls.zone = get_zone(cls.apiclient)
+        cls._cleanup = []
+
+        try:
+            # Create an account
+            cls.account = Account.create(
+                cls.apiclient,
+                cls.testdata["account"],
+                domainid=cls.domain.id
+            )
+            cls._cleanup.append(cls.account)
+
+            # If local storage is enabled, alter the offerings to use
+            # localstorage
+            if cls.zone.localstorageenable:
+                cls.testdata["service_offering"]["storagetype"] = 'local'
+
+            # Create 2 service offerings with different values for
+            # for cpunumber, cpuspeed, and memory
+
+            cls.testdata["service_offering"]["cpunumber"] = "1"
+            cls.testdata["service_offering"]["cpuspeed"] = "128"
+            cls.testdata["service_offering"]["memory"] = "256"
+
+            cls.service_offering = ServiceOffering.create(
+                cls.apiclient,
+                cls.testdata["service_offering"]
+            )
+            cls._cleanup.append(cls.service_offering)
+
+            cls.testdata["service_offering"]["cpunumber"] = "2"
+            cls.testdata["service_offering"]["cpuspeed"] = "256"
+            cls.testdata["service_offering"]["memory"] = "512"
+
+            cls.service_offering_2 = ServiceOffering.create(
+                cls.apiclient,
+                cls.testdata["service_offering"]
+            )
+            cls._cleanup.append(cls.service_offering_2)
+
+            # Create isolated network offering
+            cls.isolated_network_offering = CreateEnabledNetworkOffering(
+                cls.apiclient,
+                cls.testdata["isolated_network_offering"]
+            )
+            cls._cleanup.append(cls.isolated_network_offering)
+
+            cls.networkid = None
+            if str(cls.zone.networktype).lower() == "advanced":
+                cls.network = Network.create(
+                    cls.apiclient, cls.testdata["isolated_network"],
+                    networkofferingid=cls.isolated_network_offering.id,
+                    accountid=cls.account.name,
+                    domainid=cls.account.domainid,
+                    zoneid=cls.zone.id)
+                cls.networkid = cls.network.id
+
+            # Create user api client of the account
+            cls.userapiclient = testClient.getUserApiClient(
+                UserName=cls.account.name,
+                DomainName=cls.account.domain
+            )
+
+            template = get_template(
+                cls.apiclient,
+                cls.zone.id,
+                cls.testdata["ostype"])
+            cls.defaultTemplateId = template.id
+            # Set Zones and disk offerings
+
+            # Check that we are able to login to the created account
+            respose = User.login(
+                cls.apiclient,
+                username=cls.account.name,
+                password=cls.testdata["account"]["password"]
+            )
+
+            assert respose.sessionkey is not None,\
+                "Login to the CloudStack should be successful\
+                            response shall have non Null key"
+
+        except Exception as e:
+            cls.tearDownClass()
+            raise e
+        return
+
+    @classmethod
+    def tearDownClass(cls):
+        try:
+            cleanup_resources(cls.apiclient, cls._cleanup)
+        except Exception as e:
+            raise Exception("Warning: Exception during cleanup : %s" % e)
+
+    def setUp(self):
+        self.apiclient = self.testClient.getApiClient()
+        self.cleanup = []
+
+    def tearDown(self):
+        try:
+            cleanup_resources(self.apiclient, self.cleanup)
+            # Wait for Router cleanup before runnign further test case
+            wait_for_cleanup(
+                self.apiclient, [
+                    "network.gc.interval", "network.gc.wait"])
+        except Exception as e:
+            raise Exception("Warning: Exception during cleanup : %s" % e)
+        return
+
+    @attr(tags=["advanced", "basic"], required_hardware="False")
+    def test_01_pt_deploy_vm_without_startvm(self):
+        """ Positive test for stopped VM test path - T1
+
+        # 1.  Deploy VM in the network without specifying startvm parameter
+        # 2.  List VMs and verify that VM is in running state
+        # 3.  Verify that router is in running state (Advanced zone)
+        # 4.  Add network rules for VM (done in base.py itself) to make
+        #     it accessible
+        # 5.  Verify that VM is accessible
+        # 6.  Destroy and expunge the VM
+        # 7.  Wait for network gc time interval and check that router is
+        #     in Stopped state
+        """
+        # Create VM in account
+        virtual_machine = VirtualMachine.create(
+            self.userapiclient,
+            self.testdata["small"],
+            templateid=self.defaultTemplateId,
+            accountid=self.account.name,
+            domainid=self.account.domainid,
+            serviceofferingid=self.service_offering.id,
+            networkids=[self.networkid, ] if self.networkid else None,
+            zoneid=self.zone.id,
+            mode=self.zone.networktype
+        )
+
+        response = virtual_machine.getState(
+            self.userapiclient,
+            VirtualMachine.RUNNING)
+        self.assertEqual(response[0], PASS, response[1])
+
+        if str(self.zone.networktype).lower() == "advanced":
+            response = VerifyRouterState(
+                self.apiclient,
+                self.account.name,
+                self.account.domainid,
+                RUNNING
+            )
+            self.assertTrue(response[0], response[1])
+
+        # Check VM accessibility
+        try:
+            SshClient(host=virtual_machine.ssh_ip,
+                      port=self.testdata["natrule"]["publicport"],
+                      user=virtual_machine.username,
+                      passwd=virtual_machine.password)
+        except Exception as e:
+            self.fail("Exception while SSHing to VM: %s" % e)
+
+        virtual_machine.delete(self.apiclient)
+
+        if str(self.zone.networktype).lower() == "advanced":
+            # Wait for router to go into stopped state
+            wait_for_cleanup(
+                self.apiclient, [
+                    "network.gc.interval", "network.gc.wait"])
+
+            response = VerifyRouterState(
+                self.apiclient,
+                self.account.name,
+                self.account.domainid,
+                STOPPED,
+                retries=10
+            )
+            self.assertTrue(response[0], response[1])
+        return
+
+    @attr(tags=["advanced", "basic"], required_hardware="False")
+    def test_02_pt_deploy_vm_with_startvm_true(self):
+        """ Positive test for stopped VM test path - T1 variant
+
+        # 1.  Deploy VM in the network specifying startvm parameter as True
+        # 2.  List VMs and verify that VM is in running state
+        # 3.  Verify that router is in running state (Advanced zone)
+        # 4.  Add network rules for VM (done in base.py itself) to make
+        #     it accessible
+        # 5.  Verify that VM is accessible
+        # 6.  Destroy and expunge the VM
+        # 7.  Wait for network gc time interval and check that router is
+        #     in stopped state
+        """
+        # Create VM in account
+        virtual_machine = VirtualMachine.create(
+            self.userapiclient,
+            self.testdata["small"],
+            templateid=self.defaultTemplateId,
+            accountid=self.account.name,
+            domainid=self.account.domainid,
+            serviceofferingid=self.service_offering.id,
+            networkids=[self.networkid, ] if self.networkid else None,
+            zoneid=self.zone.id,
+            startvm=True,
+            mode=self.zone.networktype
+        )
+
+        response = virtual_machine.getState(
+            self.userapiclient,
+            VirtualMachine.RUNNING)
+        self.assertEqual(response[0], PASS, response[1])
+
+        if str(self.zone.networktype).lower() == "advanced":
+            response = VerifyRouterState(
+                self.apiclient,
+                self.account.name,
+                self.account.domainid,
+                RUNNING
+            )
+            self.assertTrue(response[0], response[1])
+
+        # Check VM accessibility
+        try:
+            SshClient(host=virtual_machine.ssh_ip,
+                      port=self.testdata["natrule"]["publicport"],
+                      user=virtual_machine.username,
+                      passwd=virtual_machine.password)
+        except Exception as e:
+            self.fail("Exception while SSHing to VM: %s" % e)
+
+        virtual_machine.delete(self.apiclient)
+
+        if str(self.zone.networktype).lower() == "advanced":
+            # Wait for router to get router in stopped state
+            wait_for_cleanup(
+                self.apiclient, [
+                    "network.gc.interval", "network.gc.wait"])
+
+            response = VerifyRouterState(
+                self.apiclient,
+                self.account.name,
+                self.account.domainid,
+                STOPPED,
+                retries=10
+            )
+            self.assertTrue(response[0], response[1])
+        return
+
+    @attr(tags=["advanced", "basic"], required_hardware="False")
+    def test_03_pt_deploy_vm_with_startvm_false(self):
+        """ Positive test for stopped VM test path - T2
+
+        # 1.  Deploy VM in the network with specifying startvm parameter
+        #     as False
+        # 2.  List VMs and verify that VM is in stopped state
+        # For Advanced zone
+        # 3.  Start the VM, now router should be in running state
+        """
+        # Create VM in account
+        virtual_machine = VirtualMachine.create(
+            self.userapiclient,
+            self.testdata["small"],
+            templateid=self.defaultTemplateId,
+            accountid=self.account.name,
+            domainid=self.account.domainid,
+            serviceofferingid=self.service_offering.id,
+            networkids=[self.networkid, ] if self.networkid else None,
+            zoneid=self.zone.id,
+            startvm=False,
+            mode=self.zone.networktype
+        )
+        self.cleanup.append(virtual_machine)
+
+        response = virtual_machine.getState(
+            self.apiclient,
+            VirtualMachine.STOPPED)
+        self.assertEqual(response[0], PASS, response[1])
+
+        if str(self.zone.networktype).lower() == "advanced":
+            virtual_machine.start(self.userapiclient)
+
+            response = VerifyRouterState(
+                self.apiclient,
+                self.account.name,
+                self.account.domainid,
+                RUNNING
+            )
+            self.assertTrue(response[0], response[1])
+        return
+
+    @attr(tags=["advanced", "basic"], required_hardware="False")
+    def test_04_pt_startvm_false_attach_disk(self):
+        """ Positive test for stopped VM test path - T3 and variant, T9
+
+        # 1.  Deploy VM in the network with specifying startvm parameter
+        #     as False
+        # 2.  List VMs and verify that VM is in stopped state
+        # 3.  Create a data disk and attach it to VM
+        # 4.  Now detach the disk from the VM
+        # 5.  Verify that attach and detach operations are successful
+        # 6.  Deploy another VM in the account with startVM = False
+        # 7.  Attach the same volume to this VM
+        # 8.  Detach the volume
+        # 9.  Both attach and detach operations should be successful
+        """
+
+        disk_offering = DiskOffering.create(
+            self.apiclient,
+            self.testdata["disk_offering"]
+        )
+        self.cleanup.append(disk_offering)
+
+        volume = Volume.create(
+            self.apiclient, self.testdata["volume"],
+            zoneid=self.zone.id, account=self.account.name,
+            domainid=self.account.domainid, diskofferingid=disk_offering.id
+        )
+        self.cleanup.append(volume)
+
+        # Create VM in account
+        virtual_machine = VirtualMachine.create(
+            self.userapiclient,
+            self.testdata["small"],
+            templateid=self.defaultTemplateId,
+            accountid=self.account.name,
+            domainid=self.account.domainid,
+            serviceofferingid=self.service_offering.id,
+            networkids=[self.networkid, ] if self.networkid else None,
+            zoneid=self.zone.id,
+            startvm=False,
+            mode=self.zone.networktype
+        )
+        self.cleanup.append(virtual_machine)
+
+        response = virtual_machine.getState(
+            self.apiclient,
+            VirtualMachine.STOPPED)
+        self.assertEqual(response[0], PASS, response[1])
+
+        virtual_machine.attach_volume(self.userapiclient, volume=volume)
+
+        volumes = Volume.list(
+            self.userapiclient,
+            virtualmachineid=virtual_machine.id,
+            type="DATADISK",
+            listall=True
+        )
+        self.assertEqual(
+            validateList(volumes)[0],
+            PASS,
+            "Volumes list validation failed"
+        )
+        self.assertEqual(
+            volumes[0].id,
+            volume.id,
+            "Listed Volume id not matching with attached volume id"
+        )
+
+        virtual_machine.detach_volume(
+            self.userapiclient,
+            volume)
+
+        volumes = Volume.list(
+            self.userapiclient,
+            virtualmachineid=virtual_machine.id,
+            type="DATADISK",
+            listall=True
+        )
+        self.assertEqual(
+            validateList(volumes)[0],
+            FAIL,
+            "Detached volume should not be listed"
+        )
+
+        virtual_machine_2 = VirtualMachine.create(
+            self.userapiclient,
+            self.testdata["small"],
+            templateid=self.defaultTemplateId,
+            accountid=self.account.name,
+            domainid=self.account.domainid,
+            serviceofferingid=self.service_offering.id,
+            networkids=[self.networkid, ] if self.networkid else None,
+            zoneid=self.zone.id,
+            startvm=False,
+            mode=self.zone.networktype
+        )
+        self.cleanup.append(virtual_machine_2)
+
+        response = virtual_machine_2.getState(
+            self.apiclient,
+            VirtualMachine.STOPPED)
+        self.assertEqual(response[0], PASS, response[1])
+
+        virtual_machine_2.attach_volume(self.userapiclient, volume=volume)
+
+        volumes = Volume.list(
+            self.userapiclient,
+            virtualmachineid=virtual_machine_2.id,
+            type="DATADISK",
+            listall=True
+        )
+        self.assertEqual(
+            validateList(volumes)[0],
+            PASS,
+            "Volumes list validation failed"
+        )
+        self.assertEqual(
+            volumes[0].id,
+            volume.id,
+            "Listed Volume id not matching with attached volume id"
+        )
+
+        virtual_machine_2.detach_volume(
+            self.userapiclient,
+            volume)
+
+        volumes = Volume.list(
+            self.userapiclient,
+            virtualmachineid=virtual_machine_2.id,
+            type="DATADISK",
+            listall=True
+        )
+        self.assertEqual(
+            validateList(volumes)[0],
+            FAIL,
+            "Detached volume should not be listed"
+        )
+        return
+
+    @attr(tags=["advanced", "basic"], required_hardware="False")
+    def test_05_pt_startvm_false_attach_disk_change_SO(self):
+        """ Positive test for stopped VM test path - T4
+
+        # 1.  Deploy VM in the network with specifying startvm parameter
+        #     as False
+        # 2.  List VMs and verify that VM is in stopped state
+        # 3.  Create a data disk and attach it to VM
+        # 4.  Change the service offering of VM from small to medium,
+              verify that the operation is successful
+        # 5.  Start the VM
+        # 6.  Now detach the disk from the VM
+        # 7.  Verify that attach and detach operations are successful
+        """
+
+        disk_offering = DiskOffering.create(
+            self.apiclient,
+            self.testdata["disk_offering"]
+        )
+        self.cleanup.append(disk_offering)
+
+        volume = Volume.create(
+            self.apiclient, self.testdata["volume"],
+            zoneid=self.zone.id, account=self.account.name,
+            domainid=self.account.domainid, diskofferingid=disk_offering.id
+        )
+        self.cleanup.append(volume)
+
+        # Create VM in account
+        virtual_machine = VirtualMachine.create(
+            self.userapiclient,
+            self.testdata["small"],
+            templateid=self.defaultTemplateId,
+            accountid=self.account.name,
+            domainid=self.account.domainid,
+            serviceofferingid=self.service_offering.id,
+            networkids=[self.networkid, ] if self.networkid else None,
+            zoneid=self.zone.id,
+            startvm=False,
+            mode=self.zone.networktype
+        )
+        self.cleanup.append(virtual_machine)
+
+        response = virtual_machine.getState(
+            self.apiclient,
+            VirtualMachine.STOPPED)
+        self.assertEqual(response[0], PASS, response[1])
+
+        virtual_machine.attach_volume(self.userapiclient, volume=volume)
+
+        volumes = Volume.list(
+            self.userapiclient,
+            virtualmachineid=virtual_machine.id,
+            type="DATADISK",
+            listall=True
+        )
+        self.assertEqual(
+            validateList(volumes)[0],
+            PASS,
+            "Volumes list validation failed"
+        )
+        self.assertEqual(
+            volumes[0].id,
+            volume.id,
+            "Listed Volume id not matching with attached volume id"
+        )
+
+        # Change service offering of VM and verify that it is changed
+        virtual_machine.change_service_offering(
+            self.userapiclient,
+            serviceOfferingId=self.service_offering_2.id
+        )
+
+        response = VerifyChangeInServiceOffering(
+            self,
+            virtual_machine,
+            self.service_offering_2
+        )
+        exceptionOccured, exceptionMessage = response[0], response[1]
+        self.assertFalse(exceptionOccured, exceptionMessage)
+
+        virtual_machine.detach_volume(
+            self.userapiclient,
+            volume)
+
+        volumes = Volume.list(
+            self.userapiclient,
+            virtualmachineid=virtual_machine.id,
+            type="DATADISK",
+            listall=True
+        )
+        self.assertEqual(
+            validateList(volumes)[0],
+            FAIL,
+            "Detached volume should not be listed"
+        )
+        return
+
+    @attr(tags=["advanced", "basic"], required_hardware="False")
+    def test_06_pt_startvm_false_attach_iso(self):
+        """ Positive test for stopped VM test path - T5
+
+        # 1.  Deploy VM in the network with specifying startvm parameter
+        #     as False
+        # 2.  List VMs and verify that VM is in stopped state
+        # 3.  Register an ISO and attach it to the VM
+        # 4.  Verify that ISO is attached to the VM
+        """
+
+        # Create VM in account
+        virtual_machine = VirtualMachine.create(
+            self.userapiclient,
+            self.testdata["small"],
+            templateid=self.defaultTemplateId,
+            accountid=self.account.name,
+            domainid=self.account.domainid,
+            serviceofferingid=self.service_offering.id,
+            networkids=[self.networkid, ] if self.networkid else None,
+            zoneid=self.zone.id,
+            startvm=False,
+            mode=self.zone.networktype
+        )
+        self.cleanup.append(virtual_machine)
+
+        response = virtual_machine.getState(
+            self.apiclient,
+            VirtualMachine.STOPPED)
+        self.assertEqual(response[0], PASS, response[1])
+
+        iso = Iso.create(
+            self.userapiclient,
+            self.testdata["iso"],
+            account=self.account.name,
+            domainid=self.account.domainid,
+            zoneid=self.zone.id
+        )
+
+        iso.download(self.userapiclient)
+        virtual_machine.attach_iso(self.userapiclient, iso)
+
+        vms = VirtualMachine.list(
+            self.userapiclient,
+            id=virtual_machine.id,
+            listall=True
+        )
+        self.assertEqual(
+            validateList(vms)[0],
+            PASS,
+            "List vms should return a valid list"
+        )
+        vm = vms[0]
+        self.assertEqual(
+            vm.isoid,
+            iso.id,
+            "The ISO status should be reflected in list Vm call"
+        )
+        return
+
+    @attr(tags=["advanced", "basic"], required_hardware="False")
+    def test_07_pt_startvm_false_attach_iso_running_vm(self):
+        """ Positive test for stopped VM test path - T5 variant
+
+        # 1.  Deploy VM in the network with specifying startvm parameter
+        #     as False
+        # 2.  List VMs and verify that VM is in stopped state
+        # 3.  Start the VM and verify that it is in running state
+        # 3.  Register an ISO and attach it to the VM
+        # 4.  Verify that ISO is attached to the VM
+        """
+
+        # Create VM in account
+        virtual_machine = VirtualMachine.create(
+            self.userapiclient,
+            self.testdata["small"],
+            templateid=self.defaultTemplateId,
+            accountid=self.account.name,
+            domainid=self.account.domainid,
+            serviceofferingid=self.service_offering.id,
+            networkids=[self.networkid, ] if self.networkid else None,
+            zoneid=self.zone.id,
+            startvm=False,
+            mode=self.zone.networktype
+        )
+        self.cleanup.append(virtual_machine)
+
+        response = virtual_machine.getState(
+            self.apiclient,
+            VirtualMachine.STOPPED)
+        self.assertEqual(response[0], PASS, response[1])
+
+        virtual_machine.start(self.userapiclient)
+
+        response = virtual_machine.getState(
+            self.apiclient,
+            VirtualMachine.RUNNING)
+        self.assertEqual(response[0], PASS, response[1])
+
+        iso = Iso.create(
+            self.userapiclient,
+            self.testdata["iso"],
+            account=self.account.name,
+            domainid=self.account.domainid,
+            zoneid=self.zone.id
+        )
+
+        iso.download(self.userapiclient)
+        virtual_machine.attach_iso(self.userapiclient, iso)
+
+        vms = VirtualMachine.list(
+            self.userapiclient,
+            id=virtual_machine.id,
+            listall=True
+        )
+        self.assertEqual(
+            validateList(vms)[0],
+            PASS,
+            "List vms should return a valid list"
+        )
+        vm = vms[0]
+        self.assertEqual(
+            vm.isoid,
+            iso.id,
+            "The ISO status should be reflected in list Vm call"
+        )
+        return
+
+    @attr(tags=["advanced", "basic"], required_hardware="False")
+    def test_08_pt_startvm_false_password_enabled_template(self):
+        """ Positive test for stopped VM test path - T10
+
+        # 1   Create a password enabled template
+        # 2.  Deploy a new VM with password enabled template
+        # 3.  Verify that VM is in stopped state
+        # 4.  Start the VM, verify that it is in running state
+        # 5.  Verify that new password is generated for the VM
+        """
+        vm_for_template = VirtualMachine.create(
+            self.userapiclient,
+            self.testdata["small"],
+            templateid=self.defaultTemplateId,
+            accountid=self.account.name,
+            domainid=self.account.domainid,
+            serviceofferingid=self.service_offering.id,
+            zoneid=self.zone.id,
+            mode=self.zone.networktype,
+            networkids=[self.networkid, ] if self.networkid else None)
+
+        vm_for_template.password = self.testdata["virtual_machine"]["password"]
+        ssh = vm_for_template.get_ssh_client()
+
+        # below steps are required to get the new password from
+        # VR(reset password)
+        # http://cloudstack.org/dl/cloud-set-guest-password
+        # Copy this file to /etc/init.d
+        # chmod +x /etc/init.d/cloud-set-guest-password
+        # chkconfig --add cloud-set-guest-password
+        # similar steps to get SSH key from web so as to make it ssh enabled
+
+        cmds = [
+            "cd /etc/init.d;wget http://people.apache.org/~tsp/\
+                    cloud-set-guest-password",
+            "chmod +x /etc/init.d/cloud-set-guest-password",
+            "chkconfig --add cloud-set-guest-password"]
+        for c in cmds:
+            ssh.execute(c)
+
+        # Stop virtual machine
+        vm_for_template.stop(self.userapiclient)
+
+        list_volume = Volume.list(
+            self.userapiclient,
+            virtualmachineid=vm_for_template.id,
+            type='ROOT',
+            listall=True)
+
+        if isinstance(list_volume, list):
+            self.volume = list_volume[0]
+        else:
+            raise Exception(
+                "Exception: Unable to find root volume for VM: %s" %
+                vm_for_template.id)
+
+        self.testdata["template"]["ostype"] = self.testdata["ostype"]
+        # Create templates for Edit, Delete & update permissions testcases
+        pw_ssh_enabled_template = Template.create(
+            self.userapiclient,
+            self.testdata["template"],
+            self.volume.id,
+            account=self.account.name,
+            domainid=self.account.domainid
+        )
+        self.cleanup.append(pw_ssh_enabled_template)
+        # Delete the VM - No longer needed
+        vm_for_template.delete(self.apiclient)
+
+        # Create VM in account
+        virtual_machine = VirtualMachine.create(
+            self.userapiclient,
+            self.testdata["small"],
+            templateid=self.defaultTemplateId,
+            accountid=self.account.name,
+            domainid=self.account.domainid,
+            serviceofferingid=self.service_offering.id,
+            zoneid=self.zone.id,
+            startvm=False,
+            mode=self.zone.networktype,
+            networkids=[self.networkid, ] if self.networkid else None
+        )
+        self.cleanup.append(virtual_machine)
+
+        response = virtual_machine.getState(
+            self.apiclient,
+            VirtualMachine.STOPPED)
+        self.assertEqual(response[0], PASS, response[1])
+
+        virtual_machine.start(self.userapiclient)
+
+        vms = virtual_machine.list(
+            self.userapiclient,
+            id=virtual_machine.id,
+            listall=True)
+
+        self.assertEqual(
+            validateList(vms)[0],
+            PASS,
+            "vms list validation failed"
+        )
+        self.assertNotEqual(
+            str(vms[0].password),
+            str(virtual_machine.password),
+            "New password should be generated for the VM"
+        )
+        return
+
+    @attr(tags=["advanced", "basic"], required_hardware="False")
+    def test_09_pt_destroy_stopped_vm(self):
+        """ Positive test for stopped VM test path - T11
+
+        # 1.  Deploy VM in the network with specifying startvm parameter
+        #     as False
+        # 2.  Verify that VM is in Stopped state
+        # 3.  Start the VM and verify that it is in running state
+        # 3.  Stop the VM, verify that it is in Stopped state
+        # 4.  Destroy the VM and verify that it is in Destroyed state
+        """
+        # Create VM in account
+        virtual_machine = VirtualMachine.create(
+            self.userapiclient,
+            self.testdata["small"],
+            templateid=self.defaultTemplateId,
+            accountid=self.account.name,
+            domainid=self.account.domainid,
+            serviceofferingid=self.service_offering.id,
+            networkids=[self.networkid, ] if self.networkid else None,
+            zoneid=self.zone.id,
+            startvm=False,
+            mode=self.zone.networktype
+        )
+
+        response = virtual_machine.getState(
+            self.apiclient,
+            VirtualMachine.STOPPED)
+        self.assertEqual(response[0], PASS, response[1])
+
+        virtual_machine.start(self.userapiclient)
+
+        response = virtual_machine.getState(
+            self.apiclient,
+            VirtualMachine.RUNNING)
+        self.assertEqual(response[0], PASS, response[1])
+
+        virtual_machine.stop(self.userapiclient)
+
+        response = virtual_machine.getState(
+            self.apiclient,
+            VirtualMachine.STOPPED)
+        self.assertEqual(response[0], PASS, response[1])
+
+        virtual_machine.delete(self.apiclient, expunge=False)
+        response = virtual_machine.getState(
+            self.apiclient,
+            VirtualMachine.DESTROYED)
+        self.assertEqual(response[0], PASS, response[1])
+        return
+
+    @attr(tags=["advanced", "basic"], required_hardware="False")
+    def test_10_max_account_limit(self):
+        """ Positive test for stopped VM test path - T12
+
+        # 1.  Create an account in root domain and set the VM limit
+        #     to max 2 VMs
+        # 2.  Deploy two VMs in the account with startvm parameter
+        #     as false
+        # 3.  Deployment of both VMs should be successful
+        # 4.  Try to deploy 3rd VM with startvm False, deployment should fail
+        """
+
+        # Create an account
+        account = Account.create(
+            self.apiclient,
+            self.testdata["account"],
+            domainid=self.domain.id
+        )
+        self.cleanup.append(account)
+
+        Resources.updateLimit(
+            self.apiclient,
+            resourcetype=0,
+            max=2,
+            account=account.name,
+            domainid=account.domainid
+        )
+
+        VirtualMachine.create(
+            self.apiclient,
+            self.testdata["small"],
+            templateid=self.defaultTemplateId,
+            accountid=account.name,
+            domainid=account.domainid,
+            serviceofferingid=self.service_offering.id,
+            zoneid=self.zone.id,
+            startvm=False,
+            mode=self.zone.networktype
+        )
+
+        VirtualMachine.create(
+            self.apiclient,
+            self.testdata["small"],
+            templateid=self.defaultTemplateId,
+            accountid=account.name,
+            domainid=account.domainid,
+            serviceofferingid=self.service_offering.id,
+            zoneid=self.zone.id,
+            startvm=False,
+            mode=self.zone.networktype
+        )
+
+        with self.assertRaises(Exception):
+            VirtualMachine.create(
+                self.apiclient,
+                self.testdata["small"],
+                templateid=self.defaultTemplateId,
+                accountid=account.name,
+                domainid=account.domainid,
+                serviceofferingid=self.service_offering.id,
+                zoneid=self.zone.id,
+                startvm=False,
+                mode=self.zone.networktype
+            )
+        return

Reply via email to