summaryrefslogtreecommitdiff
path: root/openstackclient/tests/functional
diff options
context:
space:
mode:
authorzhiyong.dai <zhiyong.dai@easystack.cn>2016-11-25 19:44:23 +0800
committerzhiyong.dai <zhiyong.dai@easystack.cn>2016-11-28 02:32:48 +0800
commit7d8602c9bc86e16ec23b3fedaee112202d4f6632 (patch)
tree306b1d9b912797e8feebc3ac61cb9e6e276e6748 /openstackclient/tests/functional
parent083b115d09b7ccf15bb3c3ab5c799a47efc2d6ac (diff)
downloadpython-openstackclient-7d8602c9bc86e16ec23b3fedaee112202d4f6632.tar.gz
Functional test for aggregate
Using json format output in aggregate functional tests. Remove resource create/delete from setupClass() and teardownClass() methods Change-Id: I6494ca63bfe8a51de0f65570fddcaf38f6c42dbb
Diffstat (limited to 'openstackclient/tests/functional')
-rw-r--r--openstackclient/tests/functional/compute/v2/test_aggregate.py209
1 files changed, 142 insertions, 67 deletions
diff --git a/openstackclient/tests/functional/compute/v2/test_aggregate.py b/openstackclient/tests/functional/compute/v2/test_aggregate.py
index 38368103..95068fc2 100644
--- a/openstackclient/tests/functional/compute/v2/test_aggregate.py
+++ b/openstackclient/tests/functional/compute/v2/test_aggregate.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,90 +19,164 @@ from openstackclient.tests.functional import base
class AggregateTests(base.TestCase):
"""Functional tests for aggregate."""
- NAME = uuid.uuid4().hex
- HEADERS = ['Name']
- FIELDS = ['name']
+ def test_aggregate_create_and_delete(self):
+ """Test create, delete multiple"""
+ name1 = uuid.uuid4().hex
+ cmd_output = json.loads(self.openstack(
+ 'aggregate create -f json ' +
+ '--zone nova ' +
+ name1))
+ self.assertEqual(
+ name1,
+ cmd_output['name']
+ )
+ self.assertEqual(
+ 'nova',
+ cmd_output['availability_zone']
+ )
- @classmethod
- def setUpClass(cls):
- opts = cls.get_opts(cls.FIELDS)
- # Use the default 'nova' availability zone for the aggregate.
- raw_output = cls.openstack(
- 'aggregate create --zone nova ' + cls.NAME + opts
+ name2 = uuid.uuid4().hex
+ cmd_output = json.loads(self.openstack(
+ 'aggregate create -f json ' +
+ '--zone nova ' +
+ name2))
+ self.assertEqual(
+ name2,
+ cmd_output['name']
+ )
+ self.assertEqual(
+ 'nova',
+ cmd_output['availability_zone']
)
- expected = cls.NAME + '\n'
- cls.assertOutput(expected, raw_output)
- @classmethod
- def tearDownClass(cls):
- raw_output = cls.openstack('aggregate delete ' + cls.NAME)
- cls.assertOutput('', raw_output)
+ del_output = self.openstack(
+ 'aggregate delete ' + name1 + ' ' + name2)
+ self.assertOutput('', del_output)
def test_aggregate_list(self):
- opts = self.get_opts(self.HEADERS)
- raw_output = self.openstack('aggregate list' + opts)
- self.assertIn(self.NAME, raw_output)
-
- def test_aggregate_show(self):
- opts = self.get_opts(self.FIELDS)
- raw_output = self.openstack('aggregate show ' + self.NAME + opts)
- self.assertEqual(self.NAME + "\n", raw_output)
+ """Test aggregate list"""
+ name1 = uuid.uuid4().hex
+ self.openstack(
+ 'aggregate create ' +
+ '--zone nova ' +
+ '--property a=b ' +
+ name1)
+ self.addCleanup(self.openstack, 'aggregate delete ' + name1)
- def test_aggregate_properties(self):
- opts = self.get_opts(['name', 'properties'])
+ name2 = uuid.uuid4().hex
+ self.openstack(
+ 'aggregate create ' +
+ '--zone internal ' +
+ '--property c=d ' +
+ name2)
+ self.addCleanup(self.openstack, 'aggregate delete ' + name2)
+
+ cmd_output = json.loads(self.openstack(
+ 'aggregate list -f json'))
+ names = [x['Name'] for x in cmd_output]
+ self.assertIn(name1, names)
+ self.assertIn(name2, names)
+ zones = [x['Availability Zone'] for x in cmd_output]
+ self.assertIn('nova', zones)
+ self.assertIn('internal', zones)
+
+ # Test aggregate list --long
+ cmd_output = json.loads(self.openstack(
+ 'aggregate list --long -f json'))
+ names = [x['Name'] for x in cmd_output]
+ self.assertIn(name1, names)
+ self.assertIn(name2, names)
+ zones = [x['Availability Zone'] for x in cmd_output]
+ self.assertIn('nova', zones)
+ self.assertIn('internal', zones)
+ properties = [x['Properties'] for x in cmd_output]
+ self.assertIn({'a': 'b'}, properties)
+ self.assertIn({'c': 'd'}, properties)
+
+ def test_aggregate_set_and_unset(self):
+ """Test aggregate set, show and unset"""
+ name1 = uuid.uuid4().hex
+ name2 = uuid.uuid4().hex
+ self.openstack(
+ 'aggregate create ' +
+ '--zone nova ' +
+ '--property a=b ' +
+ name1)
+ self.addCleanup(self.openstack, 'aggregate delete ' + name2)
raw_output = self.openstack(
- 'aggregate set --property a=b --property c=d ' + self.NAME
+ 'aggregate set --name ' +
+ name2 +
+ ' --zone internal ' +
+ '--no-property ' +
+ '--property c=d ' +
+ name1
)
- self.assertEqual('', raw_output)
-
- raw_output = self.openstack('aggregate show ' + self.NAME + opts)
- self.assertIn(self.NAME + "\na='b', c='d'\n", raw_output)
+ self.assertOutput('', raw_output)
- raw_output = self.openstack(
- 'aggregate unset --property a ' + self.NAME
+ cmd_output = json.loads(self.openstack(
+ 'aggregate show -f json ' + name2))
+ self.assertEqual(
+ name2,
+ cmd_output['name']
)
- self.assertEqual('', raw_output)
-
- raw_output = self.openstack('aggregate show ' + self.NAME + opts)
- self.assertIn(self.NAME + "\nc='d'\n", raw_output)
-
- raw_output = self.openstack(
- 'aggregate set --property a=b --property c=d ' + self.NAME
+ self.assertEqual(
+ 'internal',
+ cmd_output['availability_zone']
)
- self.assertEqual('', raw_output)
-
- raw_output = self.openstack(
- 'aggregate set --no-property ' + self.NAME
+ self.assertIn(
+ "c='d'",
+ cmd_output['properties']
+ )
+ self.assertNotIn(
+ "a='b'",
+ cmd_output['properties']
)
- self.assertEqual('', raw_output)
-
- raw_output = self.openstack('aggregate show ' + self.NAME + opts)
- self.assertNotIn("a='b', c='d'", raw_output)
-
- def test_aggregate_set(self):
- opts = self.get_opts(["name", "availability_zone"])
+ # Test unset
raw_output = self.openstack(
- 'aggregate set --zone Zone_1 ' + self.NAME)
- self.assertEqual("", raw_output)
+ 'aggregate unset --property c ' +
+ name2
+ )
+ self.assertOutput('', raw_output)
- raw_output = self.openstack('aggregate show ' + self.NAME + opts)
- self.assertEqual("Zone_1\n" + self.NAME + "\n", raw_output)
+ cmd_output = json.loads(self.openstack(
+ 'aggregate show -f json ' + name2))
+ self.assertNotIn(
+ "c='d'",
+ cmd_output['properties']
+ )
def test_aggregate_add_and_remove_host(self):
- opts = self.get_opts(["hosts", "name"])
-
- raw_output = self.openstack('host list -f value -c "Host Name"')
- host_name = raw_output.split()[0]
-
+ """Test aggregate add and remove host"""
+ name = uuid.uuid4().hex
self.openstack(
- 'aggregate add host ' + self.NAME + ' ' + host_name)
- raw_output = self.openstack('aggregate show ' + self.NAME + opts)
- self.assertEqual("[u'" + host_name + "']" + "\n" + self.NAME + "\n",
- raw_output)
+ 'aggregate create ' + name)
+ self.addCleanup(self.openstack, 'aggregate delete ' + name)
+
+ # Get a host
+ cmd_output = json.loads(self.openstack(
+ 'host list -f json'))
+ host_name = cmd_output[0]['Host Name']
+
+ # Test add host
+ cmd_output = json.loads(self.openstack(
+ 'aggregate add host -f json ' +
+ name + ' ' +
+ host_name
+ ))
+ self.assertIn(
+ host_name,
+ cmd_output['hosts']
+ )
- self.openstack(
- 'aggregate remove host ' + self.NAME + ' ' + host_name)
- raw_output = self.openstack('aggregate show ' + self.NAME + opts)
- self.assertEqual("[]\n" + self.NAME + "\n", raw_output)
+ # Test remove host
+ cmd_output = json.loads(self.openstack(
+ 'aggregate remove host -f json ' +
+ name + ' ' +
+ host_name
+ ))
+ self.assertNotIn(
+ host_name,
+ cmd_output['hosts']
+ )