Merge "port: add --host to list command"
This commit is contained in:
commit
abfca138d9
@ -514,6 +514,10 @@ class ListPort(command.Lister):
|
|||||||
"This is the entity that uses the port (for example, "
|
"This is the entity that uses the port (for example, "
|
||||||
"network:dhcp).")
|
"network:dhcp).")
|
||||||
)
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
'--host',
|
||||||
|
metavar='<host-id>',
|
||||||
|
help=_("List only ports bound to this host ID"))
|
||||||
parser.add_argument(
|
parser.add_argument(
|
||||||
'--network',
|
'--network',
|
||||||
metavar='<network>',
|
metavar='<network>',
|
||||||
@ -602,6 +606,8 @@ class ListPort(command.Lister):
|
|||||||
server = utils.find_resource(compute_client.servers,
|
server = utils.find_resource(compute_client.servers,
|
||||||
parsed_args.server)
|
parsed_args.server)
|
||||||
filters['device_id'] = server.id
|
filters['device_id'] = server.id
|
||||||
|
if parsed_args.host:
|
||||||
|
filters['binding:host_id'] = parsed_args.host
|
||||||
if parsed_args.network:
|
if parsed_args.network:
|
||||||
network = network_client.find_network(parsed_args.network,
|
network = network_client.find_network(parsed_args.network,
|
||||||
ignore_missing=False)
|
ignore_missing=False)
|
||||||
|
@ -1054,6 +1054,22 @@ class TestListPort(TestPort):
|
|||||||
self.assertEqual(self.columns_long, columns)
|
self.assertEqual(self.columns_long, columns)
|
||||||
self.assertListItemEqual(self.data_long, list(data))
|
self.assertListItemEqual(self.data_long, list(data))
|
||||||
|
|
||||||
|
def test_port_list_host(self):
|
||||||
|
arglist = [
|
||||||
|
'--host', 'foobar',
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('host', 'foobar'),
|
||||||
|
]
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
|
columns, data = self.cmd.take_action(parsed_args)
|
||||||
|
filters = {'binding:host_id': 'foobar'}
|
||||||
|
|
||||||
|
self.network.ports.assert_called_once_with(**filters)
|
||||||
|
self.assertEqual(self.columns, columns)
|
||||||
|
self.assertListItemEqual(self.data, list(data))
|
||||||
|
|
||||||
def test_port_list_project(self):
|
def test_port_list_project(self):
|
||||||
project = identity_fakes.FakeProject.create_one_project()
|
project = identity_fakes.FakeProject.create_one_project()
|
||||||
self.projects_mock.get.return_value = project
|
self.projects_mock.get.return_value = project
|
||||||
|
Loading…
x
Reference in New Issue
Block a user