From 4a12280999eed4f35e9e2d61a475ffc7c2b001b2 Mon Sep 17 00:00:00 2001 From: Dean Troyer Date: Fri, 27 Jan 2017 19:26:34 -0600 Subject: [PATCH] Fix address scope list --share Remove the 'shared' key from the attrs passed in to the SDK with 0.9.13. Also convert the functional tests to the JSON-style (that's how I found this). Closes-bug: 1659993 Change-Id: I614fbce967cdd07fe7360242547dbf52e7677939 --- openstackclient/network/v2/address_scope.py | 2 - .../network/v2/test_address_scope.py | 135 ++++++++++-------- .../unit/network/v2/test_address_scope.py | 4 +- 3 files changed, 79 insertions(+), 62 deletions(-) diff --git a/openstackclient/network/v2/address_scope.py b/openstackclient/network/v2/address_scope.py index 9f77aed685..71c1a9afb7 100644 --- a/openstackclient/network/v2/address_scope.py +++ b/openstackclient/network/v2/address_scope.py @@ -204,10 +204,8 @@ class ListAddressScope(command.Lister): if parsed_args.ip_version: attrs['ip_version'] = parsed_args.ip_version if parsed_args.share: - attrs['shared'] = True attrs['is_shared'] = True if parsed_args.no_share: - attrs['shared'] = False attrs['is_shared'] = False if 'project' in parsed_args and parsed_args.project is not None: identity_client = self.app.client_manager.identity diff --git a/openstackclient/tests/functional/network/v2/test_address_scope.py b/openstackclient/tests/functional/network/v2/test_address_scope.py index 75f843445b..eaf88969ad 100644 --- a/openstackclient/tests/functional/network/v2/test_address_scope.py +++ b/openstackclient/tests/functional/network/v2/test_address_scope.py @@ -10,7 +10,7 @@ # License for the specific language governing permissions and limitations # under the License. -import re +import json import uuid from openstackclient.tests.functional import base @@ -24,36 +24,31 @@ class AddressScopeTests(base.TestCase): # has its own needs and there are collisions when running # tests in parallel. - @classmethod - def setUpClass(cls): - # Set up some regex for matching below - cls.re_name = re.compile("name\s+\|\s+([^|]+?)\s+\|") - cls.re_ip_version = re.compile("ip_version\s+\|\s+(\S+)") - cls.re_shared = re.compile("shared\s+\|\s+(\S+)") - def test_address_scope_delete(self): """Test create, delete multiple""" name1 = uuid.uuid4().hex - raw_output = self.openstack( - 'address scope create ' + name1, - ) + cmd_output = json.loads(self.openstack( + 'address scope create -f json ' + + name1 + )) self.assertEqual( name1, - re.search(self.re_name, raw_output).group(1), + cmd_output['name'], ) # Check the default values self.assertEqual( - 'False', - re.search(self.re_shared, raw_output).group(1), + False, + cmd_output['shared'], ) name2 = uuid.uuid4().hex - raw_output = self.openstack( - 'address scope create ' + name2, - ) + cmd_output = json.loads(self.openstack( + 'address scope create -f json ' + + name2 + )) self.assertEqual( name2, - re.search(self.re_name, raw_output).group(1), + cmd_output['name'], ) raw_output = self.openstack( @@ -64,72 +59,93 @@ class AddressScopeTests(base.TestCase): def test_address_scope_list(self): """Test create defaults, list filters, delete""" name1 = uuid.uuid4().hex - raw_output = self.openstack( - 'address scope create --ip-version 4 --share ' + name1, - ) + cmd_output = json.loads(self.openstack( + 'address scope create -f json ' + + '--ip-version 4 ' + + '--share ' + + name1 + )) self.addCleanup(self.openstack, 'address scope delete ' + name1) self.assertEqual( - '4', - re.search(self.re_ip_version, raw_output).group(1), + name1, + cmd_output['name'], ) self.assertEqual( - 'True', - re.search(self.re_shared, raw_output).group(1), + 4, + cmd_output['ip_version'], + ) + self.assertEqual( + True, + cmd_output['shared'], ) name2 = uuid.uuid4().hex - raw_output = self.openstack( - 'address scope create --ip-version 6 --no-share ' + name2, - ) + cmd_output = json.loads(self.openstack( + 'address scope create -f json ' + + '--ip-version 6 ' + + '--no-share ' + + name2 + )) self.addCleanup(self.openstack, 'address scope delete ' + name2) self.assertEqual( - '6', - re.search(self.re_ip_version, raw_output).group(1), + name2, + cmd_output['name'], ) self.assertEqual( - 'False', - re.search(self.re_shared, raw_output).group(1), + 6, + cmd_output['ip_version'], + ) + self.assertEqual( + False, + cmd_output['shared'], ) # Test list - raw_output = self.openstack('address scope list') - self.assertIsNotNone(re.search(name1 + "\s+\|\s+4", raw_output)) - self.assertIsNotNone(re.search(name2 + "\s+\|\s+6", raw_output)) + cmd_output = json.loads(self.openstack( + 'address scope list -f json ', + )) + col_data = [x["IP Version"] for x in cmd_output] + self.assertIn(4, col_data) + self.assertIn(6, col_data) # Test list --share - # TODO(dtroyer): returns 'HttpException: Bad Request' - # raw_output = self.openstack('address scope list --share') - # self.assertIsNotNone(re.search(name1 + "\s+\|\s+4", raw_output)) - # self.assertIsNotNone(re.search(name2 + "\s+\|\s+6", raw_output)) + cmd_output = json.loads(self.openstack( + 'address scope list -f json --share', + )) + col_data = [x["Shared"] for x in cmd_output] + self.assertIn(True, col_data) + self.assertNotIn(False, col_data) # Test list --no-share - # TODO(dtroyer): returns 'HttpException: Bad Request' - # raw_output = self.openstack('address scope list --no-share') - # self.assertIsNotNone(re.search(name1 + "\s+\|\s+4", raw_output)) - # self.assertIsNotNone(re.search(name2 + "\s+\|\s+6", raw_output)) + cmd_output = json.loads(self.openstack( + 'address scope list -f json --no-share', + )) + col_data = [x["Shared"] for x in cmd_output] + self.assertIn(False, col_data) + self.assertNotIn(True, col_data) def test_address_scope_set(self): """Tests create options, set, show, delete""" name = uuid.uuid4().hex newname = name + "_" - raw_output = self.openstack( - 'address scope create ' + + cmd_output = json.loads(self.openstack( + 'address scope create -f json ' + '--ip-version 4 ' + '--no-share ' + - name, - ) + name + )) self.addCleanup(self.openstack, 'address scope delete ' + newname) self.assertEqual( name, - re.search(self.re_name, raw_output).group(1), + cmd_output['name'], ) self.assertEqual( - '4', - re.search(self.re_ip_version, raw_output).group(1), + 4, + cmd_output['ip_version'], ) self.assertEqual( - 'False', - re.search(self.re_shared, raw_output).group(1), + False, + cmd_output['shared'], ) raw_output = self.openstack( @@ -140,16 +156,19 @@ class AddressScopeTests(base.TestCase): ) self.assertOutput('', raw_output) - raw_output = self.openstack('address scope show ' + newname) + cmd_output = json.loads(self.openstack( + 'address scope show -f json ' + + newname, + )) self.assertEqual( newname, - re.search(self.re_name, raw_output).group(1), + cmd_output['name'], ) self.assertEqual( - '4', - re.search(self.re_ip_version, raw_output).group(1), + 4, + cmd_output['ip_version'], ) self.assertEqual( - 'True', - re.search(self.re_shared, raw_output).group(1), + True, + cmd_output['shared'], ) diff --git a/openstackclient/tests/unit/network/v2/test_address_scope.py b/openstackclient/tests/unit/network/v2/test_address_scope.py index 516b879589..400671881f 100644 --- a/openstackclient/tests/unit/network/v2/test_address_scope.py +++ b/openstackclient/tests/unit/network/v2/test_address_scope.py @@ -352,7 +352,7 @@ class TestListAddressScope(TestAddressScope): columns, data = self.cmd.take_action(parsed_args) self.network.address_scopes.assert_called_once_with( - **{'shared': True, 'is_shared': True} + **{'is_shared': True} ) self.assertEqual(self.columns, columns) self.assertEqual(self.data, list(data)) @@ -368,7 +368,7 @@ class TestListAddressScope(TestAddressScope): columns, data = self.cmd.take_action(parsed_args) self.network.address_scopes.assert_called_once_with( - **{'shared': False, 'is_shared': False} + **{'is_shared': False} ) self.assertEqual(self.columns, columns) self.assertEqual(self.data, list(data))