Subnet Pool: Add "subnet pool list" command
Change-Id: I7935be2488fb728ced9680d75880870e5d315655 Closes-Bug: 1544589 Implements: blueprint neutron-client
This commit is contained in:
parent
444fc6149d
commit
a04012c3d5
@ -19,3 +19,18 @@ Delete subnet pool
|
|||||||
.. describe:: <subnet-pool>
|
.. describe:: <subnet-pool>
|
||||||
|
|
||||||
Subnet pool to delete (name or ID)
|
Subnet pool to delete (name or ID)
|
||||||
|
|
||||||
|
subnet pool list
|
||||||
|
----------------
|
||||||
|
|
||||||
|
List subnet pools
|
||||||
|
|
||||||
|
.. program:: subnet pool list
|
||||||
|
.. code:: bash
|
||||||
|
|
||||||
|
os subnet pool list
|
||||||
|
[--long]
|
||||||
|
|
||||||
|
.. option:: --long
|
||||||
|
|
||||||
|
List additional fields in output
|
||||||
|
@ -14,6 +14,7 @@
|
|||||||
"""Subnet pool action implementations"""
|
"""Subnet pool action implementations"""
|
||||||
|
|
||||||
from openstackclient.common import command
|
from openstackclient.common import command
|
||||||
|
from openstackclient.common import utils
|
||||||
|
|
||||||
|
|
||||||
class DeleteSubnetPool(command.Command):
|
class DeleteSubnetPool(command.Command):
|
||||||
@ -32,3 +33,53 @@ class DeleteSubnetPool(command.Command):
|
|||||||
client = self.app.client_manager.network
|
client = self.app.client_manager.network
|
||||||
obj = client.find_subnet_pool(parsed_args.subnet_pool)
|
obj = client.find_subnet_pool(parsed_args.subnet_pool)
|
||||||
client.delete_subnet_pool(obj)
|
client.delete_subnet_pool(obj)
|
||||||
|
|
||||||
|
|
||||||
|
class ListSubnetPool(command.Lister):
|
||||||
|
"""List subnet pools"""
|
||||||
|
|
||||||
|
def get_parser(self, prog_name):
|
||||||
|
parser = super(ListSubnetPool, self).get_parser(prog_name)
|
||||||
|
parser.add_argument(
|
||||||
|
'--long',
|
||||||
|
action='store_true',
|
||||||
|
default=False,
|
||||||
|
help='List additional fields in output',
|
||||||
|
)
|
||||||
|
return parser
|
||||||
|
|
||||||
|
def take_action(self, parsed_args):
|
||||||
|
data = self.app.client_manager.network.subnet_pools()
|
||||||
|
|
||||||
|
if parsed_args.long:
|
||||||
|
headers = (
|
||||||
|
'ID',
|
||||||
|
'Name',
|
||||||
|
'Prefixes',
|
||||||
|
'Default Prefix Length',
|
||||||
|
'Address Scope',
|
||||||
|
)
|
||||||
|
columns = (
|
||||||
|
'id',
|
||||||
|
'name',
|
||||||
|
'prefixes',
|
||||||
|
'default_prefixlen',
|
||||||
|
'address_scope_id',
|
||||||
|
)
|
||||||
|
else:
|
||||||
|
headers = (
|
||||||
|
'ID',
|
||||||
|
'Name',
|
||||||
|
'Prefixes',
|
||||||
|
)
|
||||||
|
columns = (
|
||||||
|
'id',
|
||||||
|
'name',
|
||||||
|
'prefixes',
|
||||||
|
)
|
||||||
|
|
||||||
|
return (headers,
|
||||||
|
(utils.get_item_properties(
|
||||||
|
s, columns,
|
||||||
|
formatters={},
|
||||||
|
) for s in data))
|
||||||
|
@ -699,6 +699,9 @@ class FakeSubnetPool(object):
|
|||||||
subnet_pool_attrs = {
|
subnet_pool_attrs = {
|
||||||
'id': 'subnet-pool-id-' + uuid.uuid4().hex,
|
'id': 'subnet-pool-id-' + uuid.uuid4().hex,
|
||||||
'name': 'subnet-pool-name-' + uuid.uuid4().hex,
|
'name': 'subnet-pool-name-' + uuid.uuid4().hex,
|
||||||
|
'prefixes': ['10.0.0.0/24', '10.1.0.0/24'],
|
||||||
|
'default_prefixlen': 8,
|
||||||
|
'address_scope_id': 'address-scope-id-' + uuid.uuid4().hex,
|
||||||
}
|
}
|
||||||
|
|
||||||
# Overwrite default attributes.
|
# Overwrite default attributes.
|
||||||
@ -706,7 +709,8 @@ class FakeSubnetPool(object):
|
|||||||
|
|
||||||
# Set default methods.
|
# Set default methods.
|
||||||
subnet_pool_methods = {
|
subnet_pool_methods = {
|
||||||
'keys': ['id', 'name']
|
'keys': ['id', 'name', 'prefixes', 'default_prefixlen',
|
||||||
|
'address_scope_id']
|
||||||
}
|
}
|
||||||
|
|
||||||
# Overwrite default methods.
|
# Overwrite default methods.
|
||||||
|
@ -55,3 +55,72 @@ class TestDeleteSubnetPool(TestSubnetPool):
|
|||||||
|
|
||||||
self.network.delete_subnet_pool.assert_called_with(self._subnet_pool)
|
self.network.delete_subnet_pool.assert_called_with(self._subnet_pool)
|
||||||
self.assertIsNone(result)
|
self.assertIsNone(result)
|
||||||
|
|
||||||
|
|
||||||
|
class TestListSubnetPool(TestSubnetPool):
|
||||||
|
# The subnet pools going to be listed up.
|
||||||
|
_subnet_pools = network_fakes.FakeSubnetPool.create_subnet_pools(count=3)
|
||||||
|
|
||||||
|
columns = (
|
||||||
|
'ID',
|
||||||
|
'Name',
|
||||||
|
'Prefixes',
|
||||||
|
)
|
||||||
|
columns_long = columns + (
|
||||||
|
'Default Prefix Length',
|
||||||
|
'Address Scope',
|
||||||
|
)
|
||||||
|
|
||||||
|
data = []
|
||||||
|
for pool in _subnet_pools:
|
||||||
|
data.append((
|
||||||
|
pool.id,
|
||||||
|
pool.name,
|
||||||
|
pool.prefixes,
|
||||||
|
))
|
||||||
|
|
||||||
|
data_long = []
|
||||||
|
for pool in _subnet_pools:
|
||||||
|
data_long.append((
|
||||||
|
pool.id,
|
||||||
|
pool.name,
|
||||||
|
pool.prefixes,
|
||||||
|
pool.default_prefixlen,
|
||||||
|
pool.address_scope_id,
|
||||||
|
))
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
super(TestListSubnetPool, self).setUp()
|
||||||
|
|
||||||
|
# Get the command object to test
|
||||||
|
self.cmd = subnet_pool.ListSubnetPool(self.app, self.namespace)
|
||||||
|
|
||||||
|
self.network.subnet_pools = mock.Mock(return_value=self._subnet_pools)
|
||||||
|
|
||||||
|
def test_subnet_pool_list_no_option(self):
|
||||||
|
arglist = []
|
||||||
|
verifylist = [
|
||||||
|
('long', False),
|
||||||
|
]
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
|
columns, data = self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
|
self.network.subnet_pools.assert_called_with()
|
||||||
|
self.assertEqual(self.columns, columns)
|
||||||
|
self.assertEqual(self.data, list(data))
|
||||||
|
|
||||||
|
def test_subnet_pool_list_long(self):
|
||||||
|
arglist = [
|
||||||
|
'--long',
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('long', True),
|
||||||
|
]
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
|
columns, data = self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
|
self.network.subnet_pools.assert_called_with()
|
||||||
|
self.assertEqual(self.columns_long, columns)
|
||||||
|
self.assertEqual(self.data_long, list(data))
|
||||||
|
4
releasenotes/notes/bug-1544589-b9f669ef71aa5e57.yaml
Normal file
4
releasenotes/notes/bug-1544589-b9f669ef71aa5e57.yaml
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
---
|
||||||
|
features:
|
||||||
|
- Add support for ``subnet pool list`` command.
|
||||||
|
[Bug `1544589 <https://bugs.launchpad.net/python-openstackclient/+bug/1544589>`_]
|
@ -342,6 +342,7 @@ openstack.network.v2 =
|
|||||||
security_group_rule_delete = openstackclient.network.v2.security_group_rule:DeleteSecurityGroupRule
|
security_group_rule_delete = openstackclient.network.v2.security_group_rule:DeleteSecurityGroupRule
|
||||||
subnet_list = openstackclient.network.v2.subnet:ListSubnet
|
subnet_list = openstackclient.network.v2.subnet:ListSubnet
|
||||||
subnet_pool_delete = openstackclient.network.v2.subnet_pool:DeleteSubnetPool
|
subnet_pool_delete = openstackclient.network.v2.subnet_pool:DeleteSubnetPool
|
||||||
|
subnet_pool_list = openstackclient.network.v2.subnet_pool:ListSubnetPool
|
||||||
|
|
||||||
openstack.object_store.v1 =
|
openstack.object_store.v1 =
|
||||||
object_store_account_set = openstackclient.object.v1.account:SetAccount
|
object_store_account_set = openstackclient.object.v1.account:SetAccount
|
||||||
|
Loading…
Reference in New Issue
Block a user