summaryrefslogtreecommitdiff
path: root/openstackclient/tests/functional/compute
diff options
context:
space:
mode:
authorzhiyong.dai <zhiyong.dai@easystack.cn>2016-11-24 22:45:21 +0800
committerzhiyong.dai <zhiyong.dai@easystack.cn>2016-11-24 22:50:44 +0800
commitc8ab58bf61afb7c1f16018ba79bb102d399c6466 (patch)
tree8388b39029c64e15820f4a71df7413726e2bc841 /openstackclient/tests/functional/compute
parent083b115d09b7ccf15bb3c3ab5c799a47efc2d6ac (diff)
downloadpython-openstackclient-c8ab58bf61afb7c1f16018ba79bb102d399c6466.tar.gz
Functional test for server group
Rework functional tests to remove resource create/delete from setupClass() and teardownClass() methods. Change-Id: Ia852e48d3bcf706eefa56b03ba1f02b3fd7605cd
Diffstat (limited to 'openstackclient/tests/functional/compute')
-rw-r--r--openstackclient/tests/functional/compute/v2/test_server_group.py112
1 files changed, 86 insertions, 26 deletions
diff --git a/openstackclient/tests/functional/compute/v2/test_server_group.py b/openstackclient/tests/functional/compute/v2/test_server_group.py
index 3f0a24e5..44ecda1d 100644
--- a/openstackclient/tests/functional/compute/v2/test_server_group.py
+++ b/openstackclient/tests/functional/compute/v2/test_server_group.py
@@ -10,6 +10,7 @@
# License for the specific language governing permissions and limitations
# under the License.
+import json
import uuid
from openstackclient.tests.functional import base
@@ -18,29 +19,88 @@ from openstackclient.tests.functional import base
class ServerGroupTests(base.TestCase):
"""Functional tests for servergroup."""
- NAME = uuid.uuid4().hex
- HEADERS = ['Name']
- FIELDS = ['name']
-
- @classmethod
- def setUpClass(cls):
- opts = cls.get_opts(cls.FIELDS)
- raw_output = cls.openstack('server group create --policy affinity ' +
- cls.NAME + opts)
- expected = cls.NAME + '\n'
- cls.assertOutput(expected, raw_output)
-
- @classmethod
- def tearDownClass(cls):
- raw_output = cls.openstack('server group delete ' + cls.NAME)
- cls.assertOutput('', raw_output)
-
- def test_server_group_list(self):
- opts = self.get_opts(self.HEADERS)
- raw_output = self.openstack('server group list' + opts)
- self.assertIn(self.NAME, raw_output)
-
- def test_server_group_show(self):
- opts = self.get_opts(self.FIELDS)
- raw_output = self.openstack('server group show ' + self.NAME + opts)
- self.assertEqual(self.NAME + "\n", raw_output)
+ def test_server_group_delete(self):
+ """Test create, delete multiple"""
+ name1 = uuid.uuid4().hex
+ name2 = uuid.uuid4().hex
+ cmd_output = json.loads(self.openstack(
+ 'server group create -f json ' +
+ '--policy affinity ' +
+ name1
+ ))
+ self.assertEqual(
+ name1,
+ cmd_output['name']
+ )
+ self.assertEqual(
+ 'affinity',
+ cmd_output['policies']
+ )
+
+ cmd_output = json.loads(self.openstack(
+ 'server group create -f json ' +
+ '--policy anti-affinity ' +
+ name2
+ ))
+ self.assertEqual(
+ name2,
+ cmd_output['name']
+ )
+ self.assertEqual(
+ 'anti-affinity',
+ cmd_output['policies']
+ )
+
+ del_output = self.openstack(
+ 'server group delete ' + name1 + ' ' + name2)
+ self.assertOutput('', del_output)
+
+ def test_server_group_show_and_list(self):
+ """Test server group create, show, and list"""
+ name1 = uuid.uuid4().hex
+ name2 = uuid.uuid4().hex
+
+ # test server gorup show
+ cmd_output = json.loads(self.openstack(
+ 'server group create -f json ' +
+ '--policy affinity ' +
+ name1
+ ))
+ self.addCleanup(self.openstack, 'server group delete ' + name1)
+ cmd_output = json.loads(self.openstack(
+ 'server group show -f json ' + name1))
+ self.assertEqual(
+ name1,
+ cmd_output['name']
+ )
+ self.assertEqual(
+ 'affinity',
+ cmd_output['policies']
+ )
+
+ cmd_output = json.loads(self.openstack(
+ 'server group create -f json ' +
+ '--policy anti-affinity ' +
+ name2
+ ))
+ self.addCleanup(self.openstack, 'server group delete ' + name2)
+ cmd_output = json.loads(self.openstack(
+ 'server group show -f json ' + name2))
+ self.assertEqual(
+ name2,
+ cmd_output['name']
+ )
+ self.assertEqual(
+ 'anti-affinity',
+ cmd_output['policies']
+ )
+
+ # test server group list
+ cmd_output = json.loads(self.openstack(
+ 'server group list -f json'))
+ names = [x["Name"] for x in cmd_output]
+ self.assertIn(name1, names)
+ self.assertIn(name2, names)
+ policies = [x["Policies"] for x in cmd_output]
+ self.assertIn('affinity', policies)
+ self.assertIn('anti-affinity', policies)