summaryrefslogtreecommitdiff
path: root/openstackclient/tests/functional/compute
diff options
context:
space:
mode:
authorJenkins <jenkins@review.openstack.org>2017-02-09 05:58:32 +0000
committerGerrit Code Review <review@openstack.org>2017-02-09 05:58:32 +0000
commit2966bd0639bba203f1f46216b52a41e7a6596375 (patch)
tree0c4cee65653aba66474d36560acf121ed83c3619 /openstackclient/tests/functional/compute
parente35c97a4fc323f9771908566656c172ba4bbd340 (diff)
parentc8ab58bf61afb7c1f16018ba79bb102d399c6466 (diff)
downloadpython-openstackclient-2966bd0639bba203f1f46216b52a41e7a6596375.tar.gz
Merge "Functional test for server group"
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)