rhtyd closed pull request #2219: CLOUDSTACK-9989: Extend smoketests suite
URL: https://github.com/apache/cloudstack/pull/2219
 
 
   

This is a PR merged from a forked repository.
As GitHub hides the original diff on merge, it is displayed below for
the sake of provenance:

As this is a foreign pull request (from a fork), the diff is supplied
below (as it won't show otherwise due to GitHub magic):

diff --git a/.travis.yml b/.travis.yml
index 032b4f47aeb..d8e6f96ea15 100644
--- a/.travis.yml
+++ b/.travis.yml
@@ -99,7 +99,7 @@ env:
              smoke/misc/test_vm_sync"
 
     - TESTS="component/find_hosts_for_migration
-             component/test_accounts
+             smoke/test_accounts
              component/test_acl_isolatednetwork_delete
              component/test_acl_listsnapshot
              component/test_acl_listvm
@@ -124,28 +124,30 @@ env:
              component/test_non_contiguous_vlan
              component/test_persistent_networks"
 
-    - TESTS="component/test_projects
+    - TESTS="smoke/test_projects
              component/test_project_configs
              component/test_project_usage
-             component/test_regions
+             smoke/test_regions
              component/test_regions_accounts
              component/test_routers
              component/test_snapshots"
 
     - TESTS="component/test_project_limits
-             component/test_resource_limits"
+             component/test_resource_limits
+             smoke/test_host_maintenance"
 
     - TESTS="component/test_stopped_vm
              component/test_tags
              component/test_templates
              component/test_update_vm
-             component/test_usage"
+             smoke/test_usage"
 
     - TESTS="component/test_volumes
              component/test_vpc_network
              component/test_vpc_offerings
              component/test_vpn_users"
 
+
 # FIXME: fix following tests and include them in Travis
 #    - TESTS="component/test_affinity_groups_projects"
 #    - TESTS="component/test_allocation_states"
diff --git a/test/integration/component/test_regions.py 
b/test/integration/component/test_regions.py
deleted file mode 100644
index 38b96d59bcd..00000000000
--- a/test/integration/component/test_regions.py
+++ /dev/null
@@ -1,139 +0,0 @@
-# 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.
-
-from marvin.cloudstackTestCase import *
-from marvin.cloudstackAPI import *
-from marvin.lib.utils import *
-from marvin.lib.base import *
-from marvin.lib.common import *
-from nose.plugins.attrib import attr
-from random import choice
-
-class Services:
-    def __init__(self):
-        self.services = {
-            "region": {
-                "regionid": "2",
-                "regionname": "Region2",
-                "regionendpoint": "http://region2:8080/client";
-            }
-        }
-
-class TestRegions(cloudstackTestCase):
-    """Test Regions - CRUD tests for regions
-    """
-
-    @classmethod
-    def setUpClass(cls):
-        cls.api_client = super(TestRegions, 
cls).getClsTestClient().getApiClient()
-        cls.services = Services().services
-        cls.domain = get_domain(cls.api_client)
-        cls.cleanup = []
-        return
-
-    def setUp(self):
-        pseudo_random_int = choice(xrange(2, 200))
-        self.services["region"]["regionid"] = pseudo_random_int
-        self.services["region"]["regionname"] = "region" + 
str(pseudo_random_int)
-        self.services["region"]["regionendpoint"] = "http://region"; + 
str(pseudo_random_int) + ":8080/client"
-
-        self.region = Region.create(self.api_client,
-            self.services["region"]
-        )
-        self.cleanup = []
-        self.cleanup.append(self.region)
-
-        list_region = Region.list(self.api_client,
-            id=self.services["region"]["regionid"]
-        )
-
-        self.assertEqual(
-            isinstance(list_region, list),
-            True,
-            msg="Region creation failed"
-        )
-
-    @attr(tags=["simulator", "basic", "advanced"], required_hardware="false")
-    def test_createRegionWithExistingRegionId(self):
-        """Test for duplicate checks on region id
-        """
-        self.services["region"]["regionname"] = random_gen() #alter region 
name but not id
-        self.assertRaises(Exception, Region.create, self.api_client, 
self.services["region"])
-
-    @attr(tags=["simulator", "basic", "advanced"], required_hardware="false")
-    def test_createRegionWithExistingRegionName(self):
-        """Test for duplicate checks on region name
-        """
-        random_int = choice(xrange(2, 200))
-        self.services["region"]["regionid"] = random_int  #alter id but not 
name
-        self.services["region"]["regionendpoint"] = "http://region"; + 
str(random_int) + ":8080/client"
-        self.assertRaises(Exception, Region.create, self.api_client, 
self.services["region"])
-
-    @attr(tags=["simulator", "basic", "advanced"], required_hardware="false")
-    def test_updateRegion(self):
-       """ Test for update Region
-       """
-       self.services["region"]["regionname"] = "Region3" + random_gen()
-       self.services["region"]["regionendpoint"] = 
"http://region3updated:8080/client";
-
-       updated_region = self.region.update(self.api_client,
-           self.services["region"]
-       )
-
-       list_region = Region.list(self.api_client,
-           id=self.services["region"]["regionid"]
-       )
-
-       self.assertEqual(
-           isinstance(list_region, list),
-           True,
-           "Check for list Region response"
-       )
-       region_response = list_region[0]
-
-       self.assertEqual(
-           region_response.id,
-           updated_region.id,
-           "listRegion response does not match with region Id created"
-       )
-
-       self.assertEqual(
-           region_response.name,
-           updated_region.name,
-           "listRegion response does not match with region name created"
-       )
-       self.assertEqual(
-           region_response.endpoint,
-           updated_region.endpoint,
-           "listRegion response does not match with region endpoint created"
-       )
-
-    def tearDown(self):
-        """ Test for delete region as cleanup
-        """
-        try:
-            #Clean up
-            cleanup_resources(self.api_client, self.cleanup)
-        except Exception as e:
-            raise Exception("Warning: Exception during cleanup : %s" % e)
-
-    @classmethod
-    def tearDownClass(cls):
-        """
-        Nothing to do
-        """
-        pass
diff --git a/test/integration/component/test_accounts.py 
b/test/integration/smoke/test_accounts.py
similarity index 100%
rename from test/integration/component/test_accounts.py
rename to test/integration/smoke/test_accounts.py
diff --git a/test/integration/component/test_host_maintenance.py 
b/test/integration/smoke/test_host_maintenance.py
similarity index 100%
rename from test/integration/component/test_host_maintenance.py
rename to test/integration/smoke/test_host_maintenance.py
diff --git a/test/integration/component/test_projects.py 
b/test/integration/smoke/test_projects.py
similarity index 100%
rename from test/integration/component/test_projects.py
rename to test/integration/smoke/test_projects.py
diff --git a/test/integration/smoke/test_regions.py 
b/test/integration/smoke/test_regions.py
index 7b0dec3c6ee..a6823c6ea35 100644
--- a/test/integration/smoke/test_regions.py
+++ b/test/integration/smoke/test_regions.py
@@ -21,28 +21,53 @@
 from marvin.lib.base import *
 from marvin.lib.common import *
 from nose.plugins.attrib import attr
+from random import choice
+
+class Services:
+    def __init__(self):
+        self.services = {
+            "region": {
+                "regionid": "2",
+                "regionname": "Region2",
+                "regionendpoint": "http://region2:8080/client";
+            }
+        }
 
 class TestRegions(cloudstackTestCase):
     """Test Regions - basic region creation
     """
+    def setUp(self):
+        testClient = super(TestRegions, self).getClsTestClient()
+        self.apiclient = testClient.getApiClient()
+        self.services = testClient.getParsedTestDataConfig()
+
+        self.domain = get_domain(self.apiclient)
+        self.cleanup = []
+        pseudo_random_int = choice(xrange(2, 200))
+        self.services["region"]["regionid"] = pseudo_random_int
+        self.services["region"]["regionname"] = "region" + 
str(pseudo_random_int)
+        self.services["region"]["regionendpoint"] = "http://region"; + 
str(pseudo_random_int) + ":8080/client"
+
+        self.region = Region.create(self.apiclient,
+            self.services["region"]
+        )
+        self.cleanup = []
+        self.cleanup.append(self.region)
 
-    @classmethod
-    def setUpClass(cls):
-        testClient = super(TestRegions, cls).getClsTestClient()
-        cls.apiclient = testClient.getApiClient()
-        cls.services = testClient.getParsedTestDataConfig()
+        list_region = Region.list(self.apiclient,
+            id=self.services["region"]["regionid"]
+        )
 
-        cls.domain = get_domain(cls.apiclient)
-        cls.cleanup = []
+        self.assertEqual(
+            isinstance(list_region, list),
+            True,
+            msg="Region creation failed"
+        )
 
     @attr(tags=["basic", "advanced"], required_hardware="false")
     def test_createRegion(self):
         """ Test for create region
         """
-        region = Region.create(self.apiclient,
-            self.services["region"]
-        )
-
         list_region = Region.list(self.apiclient,
             id=self.services["region"]["regionid"]
         )
@@ -53,9 +78,9 @@ def test_createRegion(self):
             "Check for list Region response"
         )
         region_response = list_region[0]
-
+        id = self.services["region"]["regionid"]
         self.assertEqual(
-            str(region_response.id),
+            region_response.id,
             self.services["region"]["regionid"],
             "listRegion response does not match with region Id created"
         )
@@ -70,15 +95,67 @@ def test_createRegion(self):
             self.services["region"]["regionendpoint"],
             "listRegion response does not match with region endpoint created"
         )
-        self.cleanup.append(region)
-        return
 
-    @classmethod
-    def tearDownClass(cls):
+    @attr(tags=["simulator", "basic", "advanced"], required_hardware="false")
+    def test_createRegionWithExistingRegionId(self):
+        """Test for duplicate checks on region id
+        """
+        self.services["region"]["regionname"] = random_gen()  # alter region 
name but not id
+        self.assertRaises(Exception, Region.create, self.apiclient, 
self.services["region"])
+
+    @attr(tags=["simulator", "basic", "advanced"], required_hardware="false")
+    def test_createRegionWithExistingRegionName(self):
+        """Test for duplicate checks on region name
+        """
+        random_int = choice(xrange(2, 200))
+        self.services["region"]["regionid"] = random_int  # alter id but not 
name
+        self.services["region"]["regionendpoint"] = "http://region"; + 
str(random_int) + ":8080/client"
+        self.assertRaises(Exception, Region.create, self.apiclient, 
self.services["region"])
+
+    @attr(tags=["simulator", "basic", "advanced"], required_hardware="false")
+    def test_updateRegion(self):
+        """ Test for update Region
+        """
+        self.services["region"]["regionname"] = "Region3" + random_gen()
+        self.services["region"]["regionendpoint"] = 
"http://region3updated:8080/client";
+
+        updated_region = self.region.update(self.apiclient,
+                                            self.services["region"]
+                                            )
+
+        list_region = Region.list(self.apiclient,
+                                  id=self.services["region"]["regionid"]
+                                  )
+
+        self.assertEqual(
+            isinstance(list_region, list),
+            True,
+            "Check for list Region response"
+        )
+        region_response = list_region[0]
+
+        self.assertEqual(
+            region_response.id,
+            updated_region.id,
+            "listRegion response does not match with region Id created"
+        )
+
+        self.assertEqual(
+            region_response.name,
+            updated_region.name,
+            "listRegion response does not match with region name created"
+        )
+        self.assertEqual(
+            region_response.endpoint,
+            updated_region.endpoint,
+            "listRegion response does not match with region endpoint created"
+        )
+
+    def tearDown(self):
+        """ Test for delete region as cleanup
+        """
         try:
             #Clean up
-            cleanup_resources(cls.apiclient, cls.cleanup)
-            list_region = Region.list(cls.apiclient, 
id=cls.services["region"]["regionid"])
-            assert list_region is None, "Region deletion fails"
+            cleanup_resources(self.apiclient, self.cleanup)
         except Exception as e:
-            raise Exception("Warning: Region cleanup/delete fails with : %s" % 
e)
+            raise Exception("Warning: Exception during cleanup : %s" % e)
diff --git a/test/integration/component/test_usage.py 
b/test/integration/smoke/test_usage.py
similarity index 100%
rename from test/integration/component/test_usage.py
rename to test/integration/smoke/test_usage.py


 

----------------------------------------------------------------
This is an automated message from the Apache Git Service.
To respond to the message, please log on GitHub and use the
URL above to go to the specific comment.
 
For queries about this service, please contact Infrastructure at:
us...@infra.apache.org


With regards,
Apache Git Services

Reply via email to