Transfer "ip floating CRUD" to "floating ip CRUD"

This patch does the following things to transfer
"ip floating xxx" to "floating ip xxx":
* Add new command "floating ip create/delete/list/show", and doc.
* Deprecate "ip floating create/delete/list/show" command.

Change-Id: Ib071acaac81988431244e858bddafa7f93403df5
Implements: blueprint rework-ip-commands
Closes-bug: 1555990
Co-Authored-By: Dean Troyer <dtroyer@gmail.com>
This commit is contained in:
Tang Chen 2016-06-17 15:06:40 +08:00
parent 07e97b1a8a
commit 0aa2304f38
7 changed files with 214 additions and 18 deletions

View File

@ -0,0 +1,82 @@
===========
floating ip
===========
Compute v2, Network v2
floating ip create
------------------
Create floating IP
.. program:: floating ip create
.. code:: bash
os floating ip create
[--subnet <subnet>]
[--port <port>]
[--floating-ip-address <floating-ip-address>]
[--fixed-ip-address <fixed-ip-address>]
<network>
.. option:: --subnet <subnet>
Subnet on which you want to create the floating IP (name or ID)
*Network version 2 only*
.. option:: --port <port>
Port to be associated with the floating IP (name or ID)
*Network version 2 only*
.. option:: --floating-ip-address <floating-ip-address>
Floating IP address
*Network version 2 only*
.. option:: --fixed-ip-address <fixed-ip-address>
Fixed IP address mapped to the floating IP
*Network version 2 only*
.. describe:: <network>
Network to allocate floating IP from (name or ID)
floating ip delete
------------------
Delete floating IP(s)
.. program:: floating ip delete
.. code:: bash
os floating ip delete <floating-ip> [<floating-ip> ...]
.. describe:: <floating-ip>
Floating IP(s) to delete (IP address or ID)
floating ip list
----------------
List floating IP(s)
.. program:: floating ip list
.. code:: bash
os floating ip list
floating ip show
----------------
Display floating IP details
.. program:: floating ip show
.. code:: bash
os floating ip show <floating-ip>
.. describe:: <floating-ip>
Floating IP to display (IP address or ID)

View File

@ -29,6 +29,7 @@ ip floating create
------------------ ------------------
Create new floating IP address Create new floating IP address
(Deprecated, please use ``floating ip create`` instead)
.. program:: ip floating create .. program:: ip floating create
.. code:: bash .. code:: bash
@ -68,6 +69,7 @@ ip floating delete
------------------ ------------------
Delete floating IP(s) Delete floating IP(s)
(Deprecated, please use ``floating ip delete`` instead)
.. program:: ip floating delete .. program:: ip floating delete
.. code:: bash .. code:: bash
@ -83,6 +85,7 @@ ip floating list
---------------- ----------------
List floating IP addresses List floating IP addresses
(Deprecated, please use ``floating ip list`` instead)
.. program:: ip floating list .. program:: ip floating list
.. code:: bash .. code:: bash
@ -114,6 +117,7 @@ ip floating show
---------------- ----------------
Display floating IP details Display floating IP details
(Deprecated, please use ``floating ip show`` instead)
.. program:: ip floating show .. program:: ip floating show
.. code:: bash .. code:: bash

View File

@ -249,24 +249,25 @@ class ServerTests(test.TestCase):
self.wait_for_status("ACTIVE") self.wait_for_status("ACTIVE")
# attach ip # attach ip
opts = self.get_opts(["id", "floating_ip_address"]) opts = self.get_opts(["id", "floating_ip_address"])
raw_output = self.openstack('ip floating create ' + raw_output = self.openstack('floating ip create ' +
self.IP_POOL + self.IP_POOL +
opts) opts)
ip, ipid, rol = tuple(raw_output.split('\n')) ip, ipid, rol = tuple(raw_output.split('\n'))
self.assertNotEqual("", ipid) self.assertNotEqual("", ipid)
self.assertNotEqual("", ip) self.assertNotEqual("", ip)
raw_output = self.openstack('ip floating add ' + ip + ' ' + self.NAME) raw_output = self.openstack('server add floating ip ' + self.NAME +
' ' + ip)
self.assertEqual("", raw_output) self.assertEqual("", raw_output)
raw_output = self.openstack('server show ' + self.NAME) raw_output = self.openstack('server show ' + self.NAME)
self.assertIn(ip, raw_output) self.assertIn(ip, raw_output)
# detach ip # detach ip
raw_output = self.openstack('ip floating remove ' + ip + ' ' + raw_output = self.openstack('server remove floating ip ' + self.NAME +
self.NAME) ' ' + ip)
self.assertEqual("", raw_output) self.assertEqual("", raw_output)
raw_output = self.openstack('server show ' + self.NAME) raw_output = self.openstack('server show ' + self.NAME)
self.assertNotIn(ip, raw_output) self.assertNotIn(ip, raw_output)
raw_output = self.openstack('ip floating delete ' + ipid) raw_output = self.openstack('floating ip delete ' + ipid)
self.assertEqual("", raw_output) self.assertEqual("", raw_output)
def test_server_reboot(self): def test_server_reboot(self):

View File

@ -35,12 +35,12 @@ class FloatingIpTests(test.TestCase):
) )
opts = cls.get_opts(cls.FIELDS) opts = cls.get_opts(cls.FIELDS)
raw_output = cls.openstack( raw_output = cls.openstack(
'ip floating create ' + cls.NETWORK_NAME + opts) 'floating ip create ' + cls.NETWORK_NAME + opts)
cls.ID = raw_output.strip('\n') cls.ID = raw_output.strip('\n')
@classmethod @classmethod
def tearDownClass(cls): def tearDownClass(cls):
raw_output = cls.openstack('ip floating delete ' + cls.ID) raw_output = cls.openstack('floating ip delete ' + cls.ID)
cls.assertOutput('', raw_output) cls.assertOutput('', raw_output)
raw_output = cls.openstack('subnet delete ' + cls.SUBNET_NAME) raw_output = cls.openstack('subnet delete ' + cls.SUBNET_NAME)
cls.assertOutput('', raw_output) cls.assertOutput('', raw_output)
@ -49,10 +49,10 @@ class FloatingIpTests(test.TestCase):
def test_floating_ip_list(self): def test_floating_ip_list(self):
opts = self.get_opts(self.HEADERS) opts = self.get_opts(self.HEADERS)
raw_output = self.openstack('ip floating list' + opts) raw_output = self.openstack('floating ip list' + opts)
self.assertIn(self.ID, raw_output) self.assertIn(self.ID, raw_output)
def test_floating_ip_show(self): def test_floating_ip_show(self):
opts = self.get_opts(self.FIELDS) opts = self.get_opts(self.FIELDS)
raw_output = self.openstack('ip floating show ' + self.ID + opts) raw_output = self.openstack('floating ip show ' + self.ID + opts)
self.assertEqual(self.ID + "\n", raw_output) self.assertEqual(self.ID + "\n", raw_output)

View File

@ -13,6 +13,8 @@
"""IP Floating action implementations""" """IP Floating action implementations"""
import logging
from osc_lib import utils from osc_lib import utils
from openstackclient.i18n import _ from openstackclient.i18n import _
@ -31,25 +33,26 @@ def _get_attrs(client_manager, parsed_args):
attrs = {} attrs = {}
network_client = client_manager.network network_client = client_manager.network
# Name of a network could be empty string.
if parsed_args.network is not None: if parsed_args.network is not None:
network = network_client.find_network(parsed_args.network, network = network_client.find_network(parsed_args.network,
ignore_missing=False) ignore_missing=False)
attrs['floating_network_id'] = network.id attrs['floating_network_id'] = network.id
if parsed_args.subnet is not None: if parsed_args.subnet:
subnet = network_client.find_subnet(parsed_args.subnet, subnet = network_client.find_subnet(parsed_args.subnet,
ignore_missing=False) ignore_missing=False)
attrs['subnet_id'] = subnet.id attrs['subnet_id'] = subnet.id
if parsed_args.port is not None: if parsed_args.port:
port = network_client.find_port(parsed_args.port, port = network_client.find_port(parsed_args.port,
ignore_missing=False) ignore_missing=False)
attrs['port_id'] = port.id attrs['port_id'] = port.id
if parsed_args.floating_ip_address is not None: if parsed_args.floating_ip_address:
attrs['floating_ip_address'] = parsed_args.floating_ip_address attrs['floating_ip_address'] = parsed_args.floating_ip_address
if parsed_args.fixed_ip_address is not None: if parsed_args.fixed_ip_address:
attrs['fixed_ip_address'] = parsed_args.fixed_ip_address attrs['fixed_ip_address'] = parsed_args.fixed_ip_address
return attrs return attrs
@ -110,6 +113,30 @@ class CreateFloatingIP(common.NetworkAndComputeShowOne):
return (columns, data) return (columns, data)
class CreateIPFloating(CreateFloatingIP):
"""Create floating IP"""
# TODO(tangchen): Remove this class and ``ip floating create`` command
# two cycles after Mitaka.
# This notifies cliff to not display the help for this command
deprecated = True
log = logging.getLogger('deprecated')
def take_action_network(self, client, parsed_args):
self.log.warning(_('This command has been deprecated. '
'Please use "floating ip create" instead.'))
return super(CreateIPFloating, self).take_action_network(
client, parsed_args)
def take_action_compute(self, client, parsed_args):
self.log.warning(_('This command has been deprecated. '
'Please use "floating ip create" instead.'))
return super(CreateIPFloating, self).take_action_compute(
client, parsed_args)
class DeleteFloatingIP(common.NetworkAndComputeDelete): class DeleteFloatingIP(common.NetworkAndComputeDelete):
"""Delete floating IP(s)""" """Delete floating IP(s)"""
@ -135,6 +162,30 @@ class DeleteFloatingIP(common.NetworkAndComputeDelete):
client.floating_ips.delete(obj.id) client.floating_ips.delete(obj.id)
class DeleteIPFloating(DeleteFloatingIP):
"""Delete floating IP(s)"""
# TODO(tangchen): Remove this class and ``ip floating delete`` command
# two cycles after Mitaka.
# This notifies cliff to not display the help for this command
deprecated = True
log = logging.getLogger('deprecated')
def take_action_network(self, client, parsed_args):
self.log.warning(_('This command has been deprecated. '
'Please use "floating ip delete" instead.'))
return super(DeleteIPFloating, self).take_action_network(
client, parsed_args)
def take_action_compute(self, client, parsed_args):
self.log.warning(_('This command has been deprecated. '
'Please use "floating ip delete" instead.'))
return super(DeleteIPFloating, self).take_action_compute(
client, parsed_args)
class ListFloatingIP(common.NetworkAndComputeLister): class ListFloatingIP(common.NetworkAndComputeLister):
"""List floating IP(s)""" """List floating IP(s)"""
@ -186,8 +237,32 @@ class ListFloatingIP(common.NetworkAndComputeLister):
) for s in data)) ) for s in data))
class ListIPFloating(ListFloatingIP):
"""List floating IP(s)"""
# TODO(tangchen): Remove this class and ``ip floating list`` command
# two cycles after Mitaka.
# This notifies cliff to not display the help for this command
deprecated = True
log = logging.getLogger('deprecated')
def take_action_network(self, client, parsed_args):
self.log.warning(_('This command has been deprecated. '
'Please use "floating ip list" instead.'))
return super(ListIPFloating, self).take_action_network(
client, parsed_args)
def take_action_compute(self, client, parsed_args):
self.log.warning(_('This command has been deprecated. '
'Please use "floating ip list" instead.'))
return super(ListIPFloating, self).take_action_compute(
client, parsed_args)
class ShowFloatingIP(common.NetworkAndComputeShowOne): class ShowFloatingIP(common.NetworkAndComputeShowOne):
"""Show floating IP details""" """Display floating IP details"""
def update_parser_common(self, parser): def update_parser_common(self, parser):
parser.add_argument( parser.add_argument(
@ -211,3 +286,27 @@ class ShowFloatingIP(common.NetworkAndComputeShowOne):
columns = _get_columns(obj._info) columns = _get_columns(obj._info)
data = utils.get_dict_properties(obj._info, columns) data = utils.get_dict_properties(obj._info, columns)
return (columns, data) return (columns, data)
class ShowIPFloating(ShowFloatingIP):
"""Display floating IP details"""
# TODO(tangchen): Remove this class and ``ip floating show`` command
# two cycles after Mitaka.
# This notifies cliff to not display the help for this command
deprecated = True
log = logging.getLogger('deprecated')
def take_action_network(self, client, parsed_args):
self.log.warning(_('This command has been deprecated. '
'Please use "floating ip show" instead.'))
return super(ShowIPFloating, self).take_action_network(
client, parsed_args)
def take_action_compute(self, client, parsed_args):
self.log.warning(_('This command has been deprecated. '
'Please use "floating ip show" instead.'))
return super(ShowIPFloating, self).take_action_compute(
client, parsed_args)

View File

@ -10,6 +10,9 @@ features:
- Add new commands ``server add/remove fixed ip``. They are used to - Add new commands ``server add/remove fixed ip``. They are used to
replace the old commands ``ip fixed add/remove``. replace the old commands ``ip fixed add/remove``.
[Blueprint rework-ip-commands `<https://blueprints.launchpad.net/python-openstackclient/+spec/rework-ip-commands>`_] [Blueprint rework-ip-commands `<https://blueprints.launchpad.net/python-openstackclient/+spec/rework-ip-commands>`_]
- Add new commands ``floating ip create/delete/list/show``. It is used to
replace the old commands ``ip floating create/delete/list/show``.
[Blueprint rework-ip-commands `<https://blueprints.launchpad.net/python-openstackclient/+spec/rework-ip-commands>`_]
deprecations: deprecations:
- Deprecate command ``ip floating pool list``. - Deprecate command ``ip floating pool list``.
[Blueprint rework-ip-commands `<https://blueprints.launchpad.net/python-openstackclient/+spec/rework-ip-commands>`_] [Blueprint rework-ip-commands `<https://blueprints.launchpad.net/python-openstackclient/+spec/rework-ip-commands>`_]
@ -17,3 +20,5 @@ deprecations:
[Blueprint rework-ip-commands `<https://blueprints.launchpad.net/python-openstackclient/+spec/rework-ip-commands>`_] [Blueprint rework-ip-commands `<https://blueprints.launchpad.net/python-openstackclient/+spec/rework-ip-commands>`_]
- Deprecate commands ``ip fixed add/remove``. - Deprecate commands ``ip fixed add/remove``.
[Blueprint rework-ip-commands `<https://blueprints.launchpad.net/python-openstackclient/+spec/rework-ip-commands>`_] [Blueprint rework-ip-commands `<https://blueprints.launchpad.net/python-openstackclient/+spec/rework-ip-commands>`_]
- Deprecate commands ``ip floating create/delete/list/show``.
[Blueprint rework-ip-commands `<https://blueprints.launchpad.net/python-openstackclient/+spec/rework-ip-commands>`_]

View File

@ -337,15 +337,20 @@ openstack.network.v2 =
address_scope_set = openstackclient.network.v2.address_scope:SetAddressScope address_scope_set = openstackclient.network.v2.address_scope:SetAddressScope
address_scope_show = openstackclient.network.v2.address_scope:ShowAddressScope address_scope_show = openstackclient.network.v2.address_scope:ShowAddressScope
floating_ip_create = openstackclient.network.v2.floating_ip:CreateFloatingIP
floating_ip_delete = openstackclient.network.v2.floating_ip:DeleteFloatingIP
floating_ip_list = openstackclient.network.v2.floating_ip:ListFloatingIP
floating_ip_show = openstackclient.network.v2.floating_ip:ShowFloatingIP
floating_ip_pool_list = openstackclient.network.v2.floating_ip_pool:ListFloatingIPPool floating_ip_pool_list = openstackclient.network.v2.floating_ip_pool:ListFloatingIPPool
ip_availability_list = openstackclient.network.v2.ip_availability:ListIPAvailability ip_availability_list = openstackclient.network.v2.ip_availability:ListIPAvailability
ip_availability_show = openstackclient.network.v2.ip_availability:ShowIPAvailability ip_availability_show = openstackclient.network.v2.ip_availability:ShowIPAvailability
ip_floating_create = openstackclient.network.v2.floating_ip:CreateFloatingIP ip_floating_create = openstackclient.network.v2.floating_ip:CreateIPFloating
ip_floating_delete = openstackclient.network.v2.floating_ip:DeleteFloatingIP ip_floating_delete = openstackclient.network.v2.floating_ip:DeleteIPFloating
ip_floating_list = openstackclient.network.v2.floating_ip:ListFloatingIP ip_floating_list = openstackclient.network.v2.floating_ip:ListIPFloating
ip_floating_show = openstackclient.network.v2.floating_ip:ShowFloatingIP ip_floating_show = openstackclient.network.v2.floating_ip:ShowIPFloating
ip_floating_pool_list = openstackclient.network.v2.floating_ip_pool:ListIPFloatingPool ip_floating_pool_list = openstackclient.network.v2.floating_ip_pool:ListIPFloatingPool