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>
|
.. describe:: <server>
|
||||||
|
|
||||||
Server to remove the IP address from (name or ID)
|
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
|
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):
|
class DeleteFloatingIP(common.NetworkAndComputeCommand):
|
||||||
"""Delete floating IP"""
|
"""Delete floating IP"""
|
||||||
|
|
||||||
@ -89,3 +97,30 @@ class ListFloatingIP(common.NetworkAndComputeLister):
|
|||||||
s, columns,
|
s, columns,
|
||||||
formatters={},
|
formatters={},
|
||||||
) for s in data))
|
) 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),
|
info=copy.deepcopy(floating_ip_attrs),
|
||||||
methods=copy.deepcopy(floating_ip_methods),
|
methods=copy.deepcopy(floating_ip_methods),
|
||||||
loaded=True)
|
loaded=True)
|
||||||
|
|
||||||
return floating_ip
|
return floating_ip
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
|
@ -635,14 +635,24 @@ class FakeFloatingIP(object):
|
|||||||
'id': 'floating-ip-id-' + uuid.uuid4().hex,
|
'id': 'floating-ip-id-' + uuid.uuid4().hex,
|
||||||
'floating_ip_address': '1.0.9.0',
|
'floating_ip_address': '1.0.9.0',
|
||||||
'fixed_ip_address': '2.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,
|
'port_id': 'port-id-' + uuid.uuid4().hex,
|
||||||
|
'tenant_id': 'project-id-' + uuid.uuid4().hex,
|
||||||
}
|
}
|
||||||
|
|
||||||
# Overwrite default attributes.
|
# Overwrite default attributes.
|
||||||
floating_ip_attrs.update(attrs)
|
floating_ip_attrs.update(attrs)
|
||||||
|
|
||||||
# Set default methods.
|
# 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.
|
# Overwrite default methods.
|
||||||
floating_ip_methods.update(methods)
|
floating_ip_methods.update(methods)
|
||||||
@ -650,7 +660,12 @@ class FakeFloatingIP(object):
|
|||||||
floating_ip = fakes.FakeResource(
|
floating_ip = fakes.FakeResource(
|
||||||
info=copy.deepcopy(floating_ip_attrs),
|
info=copy.deepcopy(floating_ip_attrs),
|
||||||
methods=copy.deepcopy(floating_ip_methods),
|
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
|
return floating_ip
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
|
@ -100,6 +100,64 @@ class TestListFloatingIPNetwork(TestFloatingIPNetwork):
|
|||||||
self.assertEqual(self.data, list(data))
|
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
|
# Tests for Nova network
|
||||||
#
|
#
|
||||||
class TestFloatingIPCompute(compute_fakes.TestComputev2):
|
class TestFloatingIPCompute(compute_fakes.TestComputev2):
|
||||||
@ -189,3 +247,50 @@ class TestListFloatingIPCompute(TestFloatingIPCompute):
|
|||||||
self.compute.floating_ips.list.assert_called_with()
|
self.compute.floating_ips.list.assert_called_with()
|
||||||
self.assertEqual(self.columns, columns)
|
self.assertEqual(self.columns, columns)
|
||||||
self.assertEqual(self.data, list(data))
|
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>`_]
|
[Bug `1519502 <https://bugs.launchpad.net/python-openstackclient/+bug/1519502>`_]
|
||||||
- Command ``ip floating list`` is now available for neutron network.
|
- Command ``ip floating list`` is now available for neutron network.
|
||||||
[Bug `1519502 <https://bugs.launchpad.net/python-openstackclient/+bug/1519502>`_]
|
[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 =
|
openstack.network.v2 =
|
||||||
ip_floating_delete = openstackclient.network.v2.floating_ip:DeleteFloatingIP
|
ip_floating_delete = openstackclient.network.v2.floating_ip:DeleteFloatingIP
|
||||||
ip_floating_list = openstackclient.network.v2.floating_ip:ListFloatingIP
|
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_create = openstackclient.network.v2.network:CreateNetwork
|
||||||
network_delete = openstackclient.network.v2.network:DeleteNetwork
|
network_delete = openstackclient.network.v2.network:DeleteNetwork
|
||||||
network_list = openstackclient.network.v2.network:ListNetwork
|
network_list = openstackclient.network.v2.network:ListNetwork
|
||||||
|
Loading…
x
Reference in New Issue
Block a user