Floating IP: Neutron support for "ip floating show" command
Change-Id: I30350076621c83c758927444e5f8bcc2b7d0fc74 Partial-Bug: 1519502 Related-to: blueprint neutron-client
This commit is contained in:
parent
e5fe9a7071
commit
f0960f0fef
@ -82,3 +82,17 @@ Remove floating IP address from server
|
||||
.. describe:: <server>
|
||||
|
||||
Server to remove the IP address from (name or ID)
|
||||
|
||||
ip floating show
|
||||
----------------
|
||||
|
||||
Display floating IP details
|
||||
|
||||
.. program:: ip floating show
|
||||
.. code:: bash
|
||||
|
||||
os ip floating show <floating-ip>
|
||||
|
||||
.. describe:: <floating-ip>
|
||||
|
||||
Floating IP to display (IP address or ID)
|
||||
|
@ -17,6 +17,14 @@ from openstackclient.common import utils
|
||||
from openstackclient.network import common
|
||||
|
||||
|
||||
def _get_columns(item):
|
||||
columns = item.keys()
|
||||
if 'tenant_id' in columns:
|
||||
columns.remove('tenant_id')
|
||||
columns.append('project_id')
|
||||
return tuple(sorted(columns))
|
||||
|
||||
|
||||
class DeleteFloatingIP(common.NetworkAndComputeCommand):
|
||||
"""Delete floating IP"""
|
||||
|
||||
@ -89,3 +97,30 @@ class ListFloatingIP(common.NetworkAndComputeLister):
|
||||
s, columns,
|
||||
formatters={},
|
||||
) for s in data))
|
||||
|
||||
|
||||
class ShowFloatingIP(common.NetworkAndComputeShowOne):
|
||||
"""Show floating IP details"""
|
||||
|
||||
def update_parser_common(self, parser):
|
||||
parser.add_argument(
|
||||
'floating_ip',
|
||||
metavar="<floating-ip>",
|
||||
help=("Floating IP to display (IP address or ID)")
|
||||
)
|
||||
return parser
|
||||
|
||||
def take_action_network(self, client, parsed_args):
|
||||
obj = client.find_ip(parsed_args.floating_ip, ignore_missing=False)
|
||||
columns = _get_columns(obj)
|
||||
data = utils.get_item_properties(obj, columns)
|
||||
return (columns, data)
|
||||
|
||||
def take_action_compute(self, client, parsed_args):
|
||||
obj = utils.find_resource(
|
||||
client.floating_ips,
|
||||
parsed_args.floating_ip,
|
||||
)
|
||||
columns = _get_columns(obj._info)
|
||||
data = utils.get_dict_properties(obj._info, columns)
|
||||
return (columns, data)
|
||||
|
@ -622,6 +622,7 @@ class FakeFloatingIP(object):
|
||||
info=copy.deepcopy(floating_ip_attrs),
|
||||
methods=copy.deepcopy(floating_ip_methods),
|
||||
loaded=True)
|
||||
|
||||
return floating_ip
|
||||
|
||||
@staticmethod
|
||||
|
@ -635,14 +635,24 @@ class FakeFloatingIP(object):
|
||||
'id': 'floating-ip-id-' + uuid.uuid4().hex,
|
||||
'floating_ip_address': '1.0.9.0',
|
||||
'fixed_ip_address': '2.0.9.0',
|
||||
'dns_domain': None,
|
||||
'dns_name': None,
|
||||
'status': 'DOWN',
|
||||
'floating_network_id': 'network-id-' + uuid.uuid4().hex,
|
||||
'router_id': 'router-id-' + uuid.uuid4().hex,
|
||||
'port_id': 'port-id-' + uuid.uuid4().hex,
|
||||
'tenant_id': 'project-id-' + uuid.uuid4().hex,
|
||||
}
|
||||
|
||||
# Overwrite default attributes.
|
||||
floating_ip_attrs.update(attrs)
|
||||
|
||||
# Set default methods.
|
||||
floating_ip_methods = {}
|
||||
floating_ip_methods = {
|
||||
'keys': ['id', 'floating_ip_address', 'fixed_ip_address',
|
||||
'dns_domain', 'dns_name', 'status', 'router_id',
|
||||
'floating_network_id', 'port_id', 'tenant_id']
|
||||
}
|
||||
|
||||
# Overwrite default methods.
|
||||
floating_ip_methods.update(methods)
|
||||
@ -650,7 +660,12 @@ class FakeFloatingIP(object):
|
||||
floating_ip = fakes.FakeResource(
|
||||
info=copy.deepcopy(floating_ip_attrs),
|
||||
methods=copy.deepcopy(floating_ip_methods),
|
||||
loaded=True)
|
||||
loaded=True
|
||||
)
|
||||
|
||||
# Set attributes with special mappings in OpenStack SDK.
|
||||
floating_ip.project_id = floating_ip_attrs['tenant_id']
|
||||
|
||||
return floating_ip
|
||||
|
||||
@staticmethod
|
||||
|
@ -100,6 +100,64 @@ class TestListFloatingIPNetwork(TestFloatingIPNetwork):
|
||||
self.assertEqual(self.data, list(data))
|
||||
|
||||
|
||||
class TestShowFloatingIPNetwork(TestFloatingIPNetwork):
|
||||
|
||||
# The floating ip to display.
|
||||
floating_ip = network_fakes.FakeFloatingIP.create_one_floating_ip()
|
||||
|
||||
columns = (
|
||||
'dns_domain',
|
||||
'dns_name',
|
||||
'fixed_ip_address',
|
||||
'floating_ip_address',
|
||||
'floating_network_id',
|
||||
'id',
|
||||
'port_id',
|
||||
'project_id',
|
||||
'router_id',
|
||||
'status',
|
||||
)
|
||||
|
||||
data = (
|
||||
floating_ip.dns_domain,
|
||||
floating_ip.dns_name,
|
||||
floating_ip.fixed_ip_address,
|
||||
floating_ip.floating_ip_address,
|
||||
floating_ip.floating_network_id,
|
||||
floating_ip.id,
|
||||
floating_ip.port_id,
|
||||
floating_ip.tenant_id,
|
||||
floating_ip.router_id,
|
||||
floating_ip.status,
|
||||
)
|
||||
|
||||
def setUp(self):
|
||||
super(TestShowFloatingIPNetwork, self).setUp()
|
||||
|
||||
self.network.find_ip = mock.Mock(return_value=self.floating_ip)
|
||||
|
||||
# Get the command object to test
|
||||
self.cmd = floating_ip.ShowFloatingIP(self.app, self.namespace)
|
||||
|
||||
def test_floating_ip_show(self):
|
||||
arglist = [
|
||||
self.floating_ip.id,
|
||||
]
|
||||
verifylist = [
|
||||
('floating_ip', self.floating_ip.id),
|
||||
]
|
||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||
|
||||
columns, data = self.cmd.take_action(parsed_args)
|
||||
|
||||
self.network.find_ip.assert_called_with(
|
||||
self.floating_ip.id,
|
||||
ignore_missing=False
|
||||
)
|
||||
self.assertEqual(self.columns, columns)
|
||||
self.assertEqual(self.data, data)
|
||||
|
||||
|
||||
# Tests for Nova network
|
||||
#
|
||||
class TestFloatingIPCompute(compute_fakes.TestComputev2):
|
||||
@ -189,3 +247,50 @@ class TestListFloatingIPCompute(TestFloatingIPCompute):
|
||||
self.compute.floating_ips.list.assert_called_with()
|
||||
self.assertEqual(self.columns, columns)
|
||||
self.assertEqual(self.data, list(data))
|
||||
|
||||
|
||||
class TestShowFloatingIPCompute(TestFloatingIPCompute):
|
||||
|
||||
# The floating ip to display.
|
||||
floating_ip = compute_fakes.FakeFloatingIP.create_one_floating_ip()
|
||||
|
||||
columns = (
|
||||
'fixed_ip',
|
||||
'id',
|
||||
'instance_id',
|
||||
'ip',
|
||||
'pool',
|
||||
)
|
||||
|
||||
data = (
|
||||
floating_ip.fixed_ip,
|
||||
floating_ip.id,
|
||||
floating_ip.instance_id,
|
||||
floating_ip.ip,
|
||||
floating_ip.pool,
|
||||
)
|
||||
|
||||
def setUp(self):
|
||||
super(TestShowFloatingIPCompute, self).setUp()
|
||||
|
||||
self.app.client_manager.network_endpoint_enabled = False
|
||||
|
||||
# Return value of utils.find_resource()
|
||||
self.compute.floating_ips.get.return_value = self.floating_ip
|
||||
|
||||
# Get the command object to test
|
||||
self.cmd = floating_ip.ShowFloatingIP(self.app, None)
|
||||
|
||||
def test_floating_ip_show(self):
|
||||
arglist = [
|
||||
self.floating_ip.id,
|
||||
]
|
||||
verifylist = [
|
||||
('floating_ip', self.floating_ip.id),
|
||||
]
|
||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||
|
||||
columns, data = self.cmd.take_action(parsed_args)
|
||||
|
||||
self.assertEqual(self.columns, columns)
|
||||
self.assertEqual(self.data, data)
|
||||
|
@ -4,3 +4,5 @@ features:
|
||||
[Bug `1519502 <https://bugs.launchpad.net/python-openstackclient/+bug/1519502>`_]
|
||||
- Command ``ip floating list`` is now available for neutron network.
|
||||
[Bug `1519502 <https://bugs.launchpad.net/python-openstackclient/+bug/1519502>`_]
|
||||
- Add command ``ip floating show`` for neutron and nova network.
|
||||
[Bug `1519502 <https://bugs.launchpad.net/python-openstackclient/+bug/1519502>`_]
|
||||
|
@ -326,6 +326,7 @@ openstack.image.v2 =
|
||||
openstack.network.v2 =
|
||||
ip_floating_delete = openstackclient.network.v2.floating_ip:DeleteFloatingIP
|
||||
ip_floating_list = openstackclient.network.v2.floating_ip:ListFloatingIP
|
||||
ip_floating_show = openstackclient.network.v2.floating_ip:ShowFloatingIP
|
||||
network_create = openstackclient.network.v2.network:CreateNetwork
|
||||
network_delete = openstackclient.network.v2.network:DeleteNetwork
|
||||
network_list = openstackclient.network.v2.network:ListNetwork
|
||||
|
Loading…
Reference in New Issue
Block a user