Added --no-route to the router set command
Deprecated --clear-routes Closes-Bug #1565034 Change-Id: I4a8975edc026aecd2a362fd1929c984cfab8ade6
This commit is contained in:
parent
e1c53250bc
commit
bc93ebfe5c
@ -186,7 +186,7 @@ Set router properties
|
|||||||
[--name <name>]
|
[--name <name>]
|
||||||
[--enable | --disable]
|
[--enable | --disable]
|
||||||
[--distributed | --centralized]
|
[--distributed | --centralized]
|
||||||
[--route destination=<subnet>,gateway=<ip-address> | --clear-routes]
|
[--route destination=<subnet>,gateway=<ip-address> | --no-route]
|
||||||
<router>
|
<router>
|
||||||
|
|
||||||
.. option:: --name <name>
|
.. option:: --name <name>
|
||||||
@ -216,7 +216,7 @@ Set router properties
|
|||||||
gateway: nexthop IP address
|
gateway: nexthop IP address
|
||||||
(repeat option to set multiple routes)
|
(repeat option to set multiple routes)
|
||||||
|
|
||||||
.. option:: --clear-routes
|
.. option:: --no-route
|
||||||
|
|
||||||
Clear routes associated with the router
|
Clear routes associated with the router
|
||||||
|
|
||||||
|
@ -13,7 +13,9 @@
|
|||||||
|
|
||||||
"""Router action implementations"""
|
"""Router action implementations"""
|
||||||
|
|
||||||
|
import argparse
|
||||||
import json
|
import json
|
||||||
|
import logging
|
||||||
|
|
||||||
from openstackclient.common import command
|
from openstackclient.common import command
|
||||||
from openstackclient.common import exceptions
|
from openstackclient.common import exceptions
|
||||||
@ -23,6 +25,9 @@ from openstackclient.i18n import _
|
|||||||
from openstackclient.identity import common as identity_common
|
from openstackclient.identity import common as identity_common
|
||||||
|
|
||||||
|
|
||||||
|
LOG = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
def _format_admin_state(state):
|
def _format_admin_state(state):
|
||||||
return 'UP' if state else 'DOWN'
|
return 'UP' if state else 'DOWN'
|
||||||
|
|
||||||
@ -379,10 +384,15 @@ class SetRouter(command.Command):
|
|||||||
"(repeat option to set multiple routes)")
|
"(repeat option to set multiple routes)")
|
||||||
)
|
)
|
||||||
routes_group.add_argument(
|
routes_group.add_argument(
|
||||||
'--clear-routes',
|
'--no-route',
|
||||||
action='store_true',
|
action='store_true',
|
||||||
help=_("Clear routes associated with the router")
|
help=_("Clear routes associated with the router")
|
||||||
)
|
)
|
||||||
|
routes_group.add_argument(
|
||||||
|
'--clear-routes',
|
||||||
|
action='store_true',
|
||||||
|
help=argparse.SUPPRESS,
|
||||||
|
)
|
||||||
|
|
||||||
# TODO(tangchen): Support setting 'ha' property in 'router set'
|
# TODO(tangchen): Support setting 'ha' property in 'router set'
|
||||||
# command. It appears that changing the ha state is supported by
|
# command. It appears that changing the ha state is supported by
|
||||||
@ -401,8 +411,14 @@ class SetRouter(command.Command):
|
|||||||
attrs = _get_attrs(self.app.client_manager, parsed_args)
|
attrs = _get_attrs(self.app.client_manager, parsed_args)
|
||||||
|
|
||||||
# Get the route attributes.
|
# Get the route attributes.
|
||||||
if parsed_args.clear_routes:
|
if parsed_args.no_route:
|
||||||
attrs['routes'] = []
|
attrs['routes'] = []
|
||||||
|
elif parsed_args.clear_routes:
|
||||||
|
attrs['routes'] = []
|
||||||
|
LOG.warning(_(
|
||||||
|
'The --clear-routes option is deprecated, '
|
||||||
|
'please use --no-route instead.'
|
||||||
|
))
|
||||||
elif parsed_args.routes is not None:
|
elif parsed_args.routes is not None:
|
||||||
# Map the route keys and append to the current routes.
|
# Map the route keys and append to the current routes.
|
||||||
# The REST API will handle route validation and duplicates.
|
# The REST API will handle route validation and duplicates.
|
||||||
|
@ -495,6 +495,42 @@ class TestSetRouter(TestRouter):
|
|||||||
self._router, **attrs)
|
self._router, **attrs)
|
||||||
self.assertIsNone(result)
|
self.assertIsNone(result)
|
||||||
|
|
||||||
|
def test_set_no_route(self):
|
||||||
|
arglist = [
|
||||||
|
self._router.name,
|
||||||
|
'--no-route',
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('router', self._router.name),
|
||||||
|
('no_route', True),
|
||||||
|
]
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
|
result = self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
|
attrs = {
|
||||||
|
'routes': [],
|
||||||
|
}
|
||||||
|
self.network.update_router.assert_called_once_with(
|
||||||
|
self._router, **attrs)
|
||||||
|
self.assertIsNone(result)
|
||||||
|
|
||||||
|
def test_set_route_no_route(self):
|
||||||
|
arglist = [
|
||||||
|
self._router.name,
|
||||||
|
'--route', 'destination=10.20.30.0/24,gateway=10.20.30.1',
|
||||||
|
'--no-route',
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('router', self._router.name),
|
||||||
|
('routes', [{'destination': '10.20.30.0/24',
|
||||||
|
'gateway': '10.20.30.1'}]),
|
||||||
|
('no_route', True),
|
||||||
|
]
|
||||||
|
|
||||||
|
self.assertRaises(tests_utils.ParserException, self.check_parser,
|
||||||
|
self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
def test_set_clear_routes(self):
|
def test_set_clear_routes(self):
|
||||||
arglist = [
|
arglist = [
|
||||||
self._router.name,
|
self._router.name,
|
||||||
|
5
releasenotes/notes/bug-1565034-dd404bfb42d7778d.yaml
Normal file
5
releasenotes/notes/bug-1565034-dd404bfb42d7778d.yaml
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
---
|
||||||
|
fixes:
|
||||||
|
- Added ``--no-route`` to the ``router set`` command.
|
||||||
|
Deprecated ``--clear-routes``.
|
||||||
|
[Bug `1565034 <https://bugs.launchpad.net/bugs/1565034>`_]
|
Loading…
Reference in New Issue
Block a user