From 7a74b75a729deda3bccf4d57b0fe707f6270e444 Mon Sep 17 00:00:00 2001 From: Adit Sarfaty Date: Thu, 3 Nov 2016 18:05:06 +0200 Subject: [PATCH] Add security group policy extension to OSC Change-Id: I87fdcc937da36adbf4b9f620c205ee1dcdf6fcd2 --- vmware_nsx/osc/v2/security_group.py | 11 ++++ .../tests/unit/osc/v2/test_security_group.py | 61 ++++++++++++++++++- 2 files changed, 71 insertions(+), 1 deletion(-) diff --git a/vmware_nsx/osc/v2/security_group.py b/vmware_nsx/osc/v2/security_group.py index 17c73075b1..cc6cb1edc8 100644 --- a/vmware_nsx/osc/v2/security_group.py +++ b/vmware_nsx/osc/v2/security_group.py @@ -46,6 +46,13 @@ def add_nsx_extensions_to_parser(parser, client_manager, for_create=True): action='store_true', help=_("Provider security group") ) + if 'security-group-policy' in utils.get_extensions(client_manager): + # policy + parser.add_argument( + '--policy', + metavar='', + help=_("NSX Policy Id") + ) def _get_plugin_attrs(attrs, parsed_args, client_manager): @@ -59,6 +66,10 @@ def _get_plugin_attrs(attrs, parsed_args, client_manager): # provider if hasattr(parsed_args, 'provider') and parsed_args.provider: attrs['provider'] = True + if 'security-group-policy' in utils.get_extensions(client_manager): + # policy + if parsed_args.policy is not None: + attrs['policy'] = parsed_args.policy return attrs diff --git a/vmware_nsx/tests/unit/osc/v2/test_security_group.py b/vmware_nsx/tests/unit/osc/v2/test_security_group.py index 401005cf68..18feaa3608 100644 --- a/vmware_nsx/tests/unit/osc/v2/test_security_group.py +++ b/vmware_nsx/tests/unit/osc/v2/test_security_group.py @@ -22,7 +22,9 @@ from openstackclient.tests.unit import utils as tests_utils from vmware_nsx.osc.v2 import security_group -supported_extensions = ('security-group-logging', 'provider-security-group') +supported_extensions = ('security-group-logging', + 'provider-security-group', + 'security-group-policy') class TestCreateSecurityGroup( @@ -75,6 +77,37 @@ class TestCreateSecurityGroup( def test_create_with_provider(self): self._test_create_with_flag_arg('provider', 'provider', True) + def _test_create_with_arg_val(self, arg_name, arg_val): + self.network.create_security_group = mock.Mock( + return_value=self._security_group) + # add '--' to the arg name and change '_' to '-' + conv_name = '--' + re.sub('_', '-', arg_name) + arglist = [ + '--description', self._security_group.description, + conv_name, str(arg_val), + self._security_group.name + ] + verifylist = [ + ('description', self._security_group.description), + ('name', self._security_group.name), + (arg_name, arg_val), + ] + + parsed_args = self.check_parser(self.cmd, arglist, verifylist) + + columns, data = self.cmd.take_action(parsed_args) + + self.network.create_security_group.assert_called_once_with(**{ + 'description': self._security_group.description, + 'name': self._security_group.name, + arg_name: arg_val, + }) + self.assertEqual(self.columns, columns) + self.assertEqual(self.data, data) + + def test_create_with_policy(self): + self._test_create_with_arg_val('policy', 'policy-1') + class TestSetSecurityGroup(test_security_group.TestSetSecurityGroupNetwork): @@ -126,3 +159,29 @@ class TestSetSecurityGroup(test_security_group.TestSetSecurityGroupNetwork): # modifying the provider flag should fail self._test_set_with_flag_arg('provider', 'provider', True, is_valid=False) + + def _test_set_with_arg_val(self, arg_name, arg_val): + self.network.create_security_group = mock.Mock( + return_value=self._security_group) + # add '--' to the arg name and change '_' to '-' + conv_name = '--' + re.sub('_', '-', arg_name) + arglist = [ + conv_name, str(arg_val), + self._security_group.name + ] + verifylist = [ + (arg_name, arg_val), + ('group', self._security_group.name), + ] + + parsed_args = self.check_parser(self.cmd, arglist, verifylist) + + result = self.cmd.take_action(parsed_args) + + self.network.update_security_group.assert_called_once_with( + self._security_group, + **{arg_name: arg_val}) + self.assertIsNone(result) + + def test_set_with_policyr(self): + self._test_set_with_arg_val('policy', 'policy-1')