Merge "Add 'subnetpool' type support to rbac commands"

This commit is contained in:
Zuul 2020-04-15 08:44:49 +00:00 committed by Gerrit Code Review
commit 92254bb0ac
3 changed files with 18 additions and 5 deletions

View File

@ -62,6 +62,11 @@ def _get_attrs(client_manager, parsed_args):
object_id = network_client.find_address_scope( object_id = network_client.find_address_scope(
parsed_args.rbac_object, parsed_args.rbac_object,
ignore_missing=False).id ignore_missing=False).id
if parsed_args.type == 'subnetpool':
object_id = network_client.find_subnet_pool(
parsed_args.rbac_object,
ignore_missing=False).id
attrs['object_id'] = object_id attrs['object_id'] = object_id
identity_client = client_manager.identity identity_client = client_manager.identity
@ -101,10 +106,10 @@ class CreateNetworkRBAC(command.ShowOne):
'--type', '--type',
metavar="<type>", metavar="<type>",
required=True, required=True,
choices=['address_scope', 'security_group', choices=['address_scope', 'security_group', 'subnetpool',
'qos_policy', 'network'], 'qos_policy', 'network'],
help=_('Type of the object that RBAC policy ' help=_('Type of the object that RBAC policy '
'affects ("address_scope", "security_group", ' 'affects ("address_scope", "security_group", "subnetpool",'
' "qos_policy" or "network")') ' "qos_policy" or "network")')
) )
parser.add_argument( parser.add_argument(
@ -194,11 +199,11 @@ class ListNetworkRBAC(command.Lister):
parser.add_argument( parser.add_argument(
'--type', '--type',
metavar='<type>', metavar='<type>',
choices=['address_scope', 'security_group', choices=['address_scope', 'security_group', 'subnetpool',
'qos_policy', 'network'], 'qos_policy', 'network'],
help=_('List network RBAC policies according to ' help=_('List network RBAC policies according to '
'given object type ("address_scope", "security_group", ' 'given object type ("address_scope", "security_group", '
'"qos_policy" or "network")') '"subnetpool", "qos_policy" or "network")')
) )
parser.add_argument( parser.add_argument(
'--action', '--action',

View File

@ -41,6 +41,7 @@ class TestCreateNetworkRBAC(TestNetworkRBAC):
qos_object = network_fakes.FakeNetworkQosPolicy.create_one_qos_policy() qos_object = network_fakes.FakeNetworkQosPolicy.create_one_qos_policy()
sg_object = network_fakes.FakeNetworkSecGroup.create_one_security_group() sg_object = network_fakes.FakeNetworkSecGroup.create_one_security_group()
as_object = network_fakes.FakeAddressScope.create_one_address_scope() as_object = network_fakes.FakeAddressScope.create_one_address_scope()
snp_object = network_fakes.FakeSubnetPool.create_one_subnet_pool()
project = identity_fakes_v3.FakeProject.create_one_project() project = identity_fakes_v3.FakeProject.create_one_project()
rbac_policy = network_fakes.FakeNetworkRBAC.create_one_network_rbac( rbac_policy = network_fakes.FakeNetworkRBAC.create_one_network_rbac(
attrs={'tenant_id': project.id, attrs={'tenant_id': project.id,
@ -82,6 +83,8 @@ class TestCreateNetworkRBAC(TestNetworkRBAC):
return_value=self.sg_object) return_value=self.sg_object)
self.network.find_address_scope = mock.Mock( self.network.find_address_scope = mock.Mock(
return_value=self.as_object) return_value=self.as_object)
self.network.find_subnet_pool = mock.Mock(
return_value=self.snp_object)
self.projects_mock.get.return_value = self.project self.projects_mock.get.return_value = self.project
def test_network_rbac_create_no_type(self): def test_network_rbac_create_no_type(self):
@ -232,6 +235,7 @@ class TestCreateNetworkRBAC(TestNetworkRBAC):
@ddt.data( @ddt.data(
('qos_policy', "qos_object"), ('qos_policy', "qos_object"),
('security_group', "sg_object"), ('security_group', "sg_object"),
('subnetpool', "snp_object"),
('address_scope', "as_object") ('address_scope', "as_object")
) )
@ddt.unpack @ddt.unpack

View File

@ -0,0 +1,4 @@
features:
- |
Add ``subnetpool`` as a valid ``--type`` value for the
``network rbac create`` and ``network rbac list`` commands.