Add --description to Neutron commands
Added simple option for floating ip description when creating a floating ip. Added option for create and set router as well. Partially Implements: blueprint neutron-client-descriptions Partially Implements: blueprint network-commands-options Change-Id: Ib8cd8af449e9ff33b980017b2527a6b196894a00
This commit is contained in:
parent
ccd2d658d1
commit
0981931628
@ -17,6 +17,7 @@ Create floating IP
|
|||||||
[--port <port>]
|
[--port <port>]
|
||||||
[--floating-ip-address <floating-ip-address>]
|
[--floating-ip-address <floating-ip-address>]
|
||||||
[--fixed-ip-address <fixed-ip-address>]
|
[--fixed-ip-address <fixed-ip-address>]
|
||||||
|
[--description <description>]
|
||||||
<network>
|
<network>
|
||||||
|
|
||||||
.. option:: --subnet <subnet>
|
.. option:: --subnet <subnet>
|
||||||
@ -39,6 +40,11 @@ Create floating IP
|
|||||||
Fixed IP address mapped to the floating IP
|
Fixed IP address mapped to the floating IP
|
||||||
*Network version 2 only*
|
*Network version 2 only*
|
||||||
|
|
||||||
|
.. option:: --description <description>
|
||||||
|
|
||||||
|
Set floating IP description
|
||||||
|
*Network version 2 only*
|
||||||
|
|
||||||
.. describe:: <network>
|
.. describe:: <network>
|
||||||
|
|
||||||
Network to allocate floating IP from (name or ID)
|
Network to allocate floating IP from (name or ID)
|
||||||
|
@ -64,6 +64,7 @@ Create new router
|
|||||||
[--project <project> [--project-domain <project-domain>]]
|
[--project <project> [--project-domain <project-domain>]]
|
||||||
[--enable | --disable]
|
[--enable | --disable]
|
||||||
[--distributed]
|
[--distributed]
|
||||||
|
[--description <description>]
|
||||||
[--availability-zone-hint <availability-zone>]
|
[--availability-zone-hint <availability-zone>]
|
||||||
<name>
|
<name>
|
||||||
|
|
||||||
@ -88,6 +89,10 @@ Create new router
|
|||||||
|
|
||||||
Create a distributed router
|
Create a distributed router
|
||||||
|
|
||||||
|
.. option:: --description <description>
|
||||||
|
|
||||||
|
Set router description
|
||||||
|
|
||||||
.. option:: --availability-zone-hint <availability-zone>
|
.. option:: --availability-zone-hint <availability-zone>
|
||||||
|
|
||||||
Availability Zone in which to create this router
|
Availability Zone in which to create this router
|
||||||
@ -186,6 +191,7 @@ Set router properties
|
|||||||
[--name <name>]
|
[--name <name>]
|
||||||
[--enable | --disable]
|
[--enable | --disable]
|
||||||
[--distributed | --centralized]
|
[--distributed | --centralized]
|
||||||
|
[--description <description>]
|
||||||
[--route destination=<subnet>,gateway=<ip-address> | --no-route]
|
[--route destination=<subnet>,gateway=<ip-address> | --no-route]
|
||||||
<router>
|
<router>
|
||||||
|
|
||||||
@ -209,6 +215,10 @@ Set router properties
|
|||||||
|
|
||||||
Set router to centralized mode (disabled router only)
|
Set router to centralized mode (disabled router only)
|
||||||
|
|
||||||
|
.. option:: --description <description>
|
||||||
|
|
||||||
|
Set router description
|
||||||
|
|
||||||
.. option:: --route destination=<subnet>,gateway=<ip-address>
|
.. option:: --route destination=<subnet>,gateway=<ip-address>
|
||||||
|
|
||||||
Routes associated with the router
|
Routes associated with the router
|
||||||
|
@ -55,6 +55,9 @@ def _get_attrs(client_manager, parsed_args):
|
|||||||
if parsed_args.fixed_ip_address:
|
if parsed_args.fixed_ip_address:
|
||||||
attrs['fixed_ip_address'] = parsed_args.fixed_ip_address
|
attrs['fixed_ip_address'] = parsed_args.fixed_ip_address
|
||||||
|
|
||||||
|
if parsed_args.description is not None:
|
||||||
|
attrs['description'] = parsed_args.description
|
||||||
|
|
||||||
return attrs
|
return attrs
|
||||||
|
|
||||||
|
|
||||||
@ -97,6 +100,11 @@ class CreateFloatingIP(common.NetworkAndComputeShowOne):
|
|||||||
dest='fixed_ip_address',
|
dest='fixed_ip_address',
|
||||||
help=_("Fixed IP address mapped to the floating IP")
|
help=_("Fixed IP address mapped to the floating IP")
|
||||||
)
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
'--description',
|
||||||
|
metavar='<description>',
|
||||||
|
help=_('Set floating IP description')
|
||||||
|
)
|
||||||
return parser
|
return parser
|
||||||
|
|
||||||
def take_action_network(self, client, parsed_args):
|
def take_action_network(self, client, parsed_args):
|
||||||
|
@ -82,7 +82,8 @@ def _get_attrs(client_manager, parsed_args):
|
|||||||
if ('availability_zone_hints' in parsed_args
|
if ('availability_zone_hints' in parsed_args
|
||||||
and parsed_args.availability_zone_hints is not None):
|
and parsed_args.availability_zone_hints is not None):
|
||||||
attrs['availability_zone_hints'] = parsed_args.availability_zone_hints
|
attrs['availability_zone_hints'] = parsed_args.availability_zone_hints
|
||||||
|
if parsed_args.description is not None:
|
||||||
|
attrs['description'] = parsed_args.description
|
||||||
# "router set" command doesn't support setting project.
|
# "router set" command doesn't support setting project.
|
||||||
if 'project' in parsed_args and parsed_args.project is not None:
|
if 'project' in parsed_args and parsed_args.project is not None:
|
||||||
identity_client = client_manager.identity
|
identity_client = client_manager.identity
|
||||||
@ -179,6 +180,11 @@ class CreateRouter(command.ShowOne):
|
|||||||
default=False,
|
default=False,
|
||||||
help=_("Create a distributed router")
|
help=_("Create a distributed router")
|
||||||
)
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
'--description',
|
||||||
|
metavar='<description>',
|
||||||
|
help=_('Set router description')
|
||||||
|
)
|
||||||
parser.add_argument(
|
parser.add_argument(
|
||||||
'--project',
|
'--project',
|
||||||
metavar='<project>',
|
metavar='<project>',
|
||||||
@ -370,6 +376,11 @@ class SetRouter(command.Command):
|
|||||||
metavar='<name>',
|
metavar='<name>',
|
||||||
help=_("Set router name")
|
help=_("Set router name")
|
||||||
)
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
'--description',
|
||||||
|
metavar='<description>',
|
||||||
|
help=_('Set router description')
|
||||||
|
)
|
||||||
admin_group = parser.add_mutually_exclusive_group()
|
admin_group = parser.add_mutually_exclusive_group()
|
||||||
admin_group.add_argument(
|
admin_group.add_argument(
|
||||||
'--enable',
|
'--enable',
|
||||||
|
@ -651,6 +651,7 @@ class FakeRouter(object):
|
|||||||
'name': 'router-name-' + uuid.uuid4().hex,
|
'name': 'router-name-' + uuid.uuid4().hex,
|
||||||
'status': 'ACTIVE',
|
'status': 'ACTIVE',
|
||||||
'admin_state_up': True,
|
'admin_state_up': True,
|
||||||
|
'description': 'router-description-' + uuid.uuid4().hex,
|
||||||
'distributed': False,
|
'distributed': False,
|
||||||
'ha': False,
|
'ha': False,
|
||||||
'tenant_id': 'project-id-' + uuid.uuid4().hex,
|
'tenant_id': 'project-id-' + uuid.uuid4().hex,
|
||||||
@ -970,6 +971,7 @@ class FakeFloatingIP(object):
|
|||||||
'router_id': 'router-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,
|
'tenant_id': 'project-id-' + uuid.uuid4().hex,
|
||||||
|
'description': 'floating-ip-description-' + uuid.uuid4().hex,
|
||||||
}
|
}
|
||||||
|
|
||||||
# Overwrite default attributes.
|
# Overwrite default attributes.
|
||||||
|
@ -49,6 +49,7 @@ class TestCreateFloatingIPNetwork(TestFloatingIPNetwork):
|
|||||||
)
|
)
|
||||||
|
|
||||||
columns = (
|
columns = (
|
||||||
|
'description',
|
||||||
'dns_domain',
|
'dns_domain',
|
||||||
'dns_name',
|
'dns_name',
|
||||||
'fixed_ip_address',
|
'fixed_ip_address',
|
||||||
@ -62,6 +63,7 @@ class TestCreateFloatingIPNetwork(TestFloatingIPNetwork):
|
|||||||
)
|
)
|
||||||
|
|
||||||
data = (
|
data = (
|
||||||
|
floating_ip.description,
|
||||||
floating_ip.dns_domain,
|
floating_ip.dns_domain,
|
||||||
floating_ip.dns_name,
|
floating_ip.dns_name,
|
||||||
floating_ip.fixed_ip_address,
|
floating_ip.fixed_ip_address,
|
||||||
@ -117,14 +119,16 @@ class TestCreateFloatingIPNetwork(TestFloatingIPNetwork):
|
|||||||
'--port', self.floating_ip.port_id,
|
'--port', self.floating_ip.port_id,
|
||||||
'--floating-ip-address', self.floating_ip.floating_ip_address,
|
'--floating-ip-address', self.floating_ip.floating_ip_address,
|
||||||
'--fixed-ip-address', self.floating_ip.fixed_ip_address,
|
'--fixed-ip-address', self.floating_ip.fixed_ip_address,
|
||||||
|
'--description', self.floating_ip.description,
|
||||||
self.floating_ip.floating_network_id,
|
self.floating_ip.floating_network_id,
|
||||||
]
|
]
|
||||||
verifylist = [
|
verifylist = [
|
||||||
('subnet', self.subnet.id),
|
('subnet', self.subnet.id),
|
||||||
('port', self.floating_ip.port_id),
|
('port', self.floating_ip.port_id),
|
||||||
('floating_ip_address', self.floating_ip.floating_ip_address),
|
|
||||||
('fixed_ip_address', self.floating_ip.fixed_ip_address),
|
('fixed_ip_address', self.floating_ip.fixed_ip_address),
|
||||||
('network', self.floating_ip.floating_network_id),
|
('network', self.floating_ip.floating_network_id),
|
||||||
|
('description', self.floating_ip.description),
|
||||||
|
('floating_ip_address', self.floating_ip.floating_ip_address),
|
||||||
]
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
@ -136,6 +140,7 @@ class TestCreateFloatingIPNetwork(TestFloatingIPNetwork):
|
|||||||
'floating_ip_address': self.floating_ip.floating_ip_address,
|
'floating_ip_address': self.floating_ip.floating_ip_address,
|
||||||
'fixed_ip_address': self.floating_ip.fixed_ip_address,
|
'fixed_ip_address': self.floating_ip.fixed_ip_address,
|
||||||
'floating_network_id': self.floating_ip.floating_network_id,
|
'floating_network_id': self.floating_ip.floating_network_id,
|
||||||
|
'description': self.floating_ip.description,
|
||||||
})
|
})
|
||||||
self.assertEqual(self.columns, columns)
|
self.assertEqual(self.columns, columns)
|
||||||
self.assertEqual(self.data, data)
|
self.assertEqual(self.data, data)
|
||||||
@ -269,6 +274,7 @@ class TestShowFloatingIPNetwork(TestFloatingIPNetwork):
|
|||||||
floating_ip = network_fakes.FakeFloatingIP.create_one_floating_ip()
|
floating_ip = network_fakes.FakeFloatingIP.create_one_floating_ip()
|
||||||
|
|
||||||
columns = (
|
columns = (
|
||||||
|
'description',
|
||||||
'dns_domain',
|
'dns_domain',
|
||||||
'dns_name',
|
'dns_name',
|
||||||
'fixed_ip_address',
|
'fixed_ip_address',
|
||||||
@ -282,6 +288,7 @@ class TestShowFloatingIPNetwork(TestFloatingIPNetwork):
|
|||||||
)
|
)
|
||||||
|
|
||||||
data = (
|
data = (
|
||||||
|
floating_ip.description,
|
||||||
floating_ip.dns_domain,
|
floating_ip.dns_domain,
|
||||||
floating_ip.dns_name,
|
floating_ip.dns_name,
|
||||||
floating_ip.fixed_ip_address,
|
floating_ip.fixed_ip_address,
|
||||||
|
@ -119,6 +119,7 @@ class TestCreateRouter(TestRouter):
|
|||||||
'admin_state_up',
|
'admin_state_up',
|
||||||
'availability_zone_hints',
|
'availability_zone_hints',
|
||||||
'availability_zones',
|
'availability_zones',
|
||||||
|
'description',
|
||||||
'distributed',
|
'distributed',
|
||||||
'external_gateway_info',
|
'external_gateway_info',
|
||||||
'ha',
|
'ha',
|
||||||
@ -132,6 +133,7 @@ class TestCreateRouter(TestRouter):
|
|||||||
router._format_admin_state(new_router.admin_state_up),
|
router._format_admin_state(new_router.admin_state_up),
|
||||||
osc_utils.format_list(new_router.availability_zone_hints),
|
osc_utils.format_list(new_router.availability_zone_hints),
|
||||||
osc_utils.format_list(new_router.availability_zones),
|
osc_utils.format_list(new_router.availability_zones),
|
||||||
|
new_router.description,
|
||||||
new_router.distributed,
|
new_router.distributed,
|
||||||
router._format_external_gateway_info(new_router.external_gateway_info),
|
router._format_external_gateway_info(new_router.external_gateway_info),
|
||||||
new_router.ha,
|
new_router.ha,
|
||||||
@ -503,12 +505,14 @@ class TestSetRouter(TestRouter):
|
|||||||
'--enable',
|
'--enable',
|
||||||
'--distributed',
|
'--distributed',
|
||||||
'--name', 'noob',
|
'--name', 'noob',
|
||||||
|
'--description', 'router',
|
||||||
]
|
]
|
||||||
verifylist = [
|
verifylist = [
|
||||||
('router', self._router.name),
|
('router', self._router.name),
|
||||||
('enable', True),
|
('enable', True),
|
||||||
('distributed', True),
|
('distributed', True),
|
||||||
('name', 'noob'),
|
('name', 'noob'),
|
||||||
|
('description', 'router'),
|
||||||
]
|
]
|
||||||
|
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
@ -518,6 +522,7 @@ class TestSetRouter(TestRouter):
|
|||||||
'admin_state_up': True,
|
'admin_state_up': True,
|
||||||
'distributed': True,
|
'distributed': True,
|
||||||
'name': 'noob',
|
'name': 'noob',
|
||||||
|
'description': 'router',
|
||||||
}
|
}
|
||||||
self.network.update_router.assert_called_once_with(
|
self.network.update_router.assert_called_once_with(
|
||||||
self._router, **attrs)
|
self._router, **attrs)
|
||||||
@ -681,6 +686,7 @@ class TestShowRouter(TestRouter):
|
|||||||
'admin_state_up',
|
'admin_state_up',
|
||||||
'availability_zone_hints',
|
'availability_zone_hints',
|
||||||
'availability_zones',
|
'availability_zones',
|
||||||
|
'description',
|
||||||
'distributed',
|
'distributed',
|
||||||
'external_gateway_info',
|
'external_gateway_info',
|
||||||
'ha',
|
'ha',
|
||||||
@ -694,6 +700,7 @@ class TestShowRouter(TestRouter):
|
|||||||
router._format_admin_state(_router.admin_state_up),
|
router._format_admin_state(_router.admin_state_up),
|
||||||
osc_utils.format_list(_router.availability_zone_hints),
|
osc_utils.format_list(_router.availability_zone_hints),
|
||||||
osc_utils.format_list(_router.availability_zones),
|
osc_utils.format_list(_router.availability_zones),
|
||||||
|
_router.description,
|
||||||
_router.distributed,
|
_router.distributed,
|
||||||
router._format_external_gateway_info(_router.external_gateway_info),
|
router._format_external_gateway_info(_router.external_gateway_info),
|
||||||
_router.ha,
|
_router.ha,
|
||||||
|
@ -0,0 +1,7 @@
|
|||||||
|
---
|
||||||
|
features:
|
||||||
|
- |
|
||||||
|
Add ``--description`` option for core network resources. Allows users to
|
||||||
|
set a description for: ``floating ip create`` and ``router set/create``.
|
||||||
|
[Blueprint :oscbp:`neutron-client-descriptions`]
|
||||||
|
[Blueprint :oscbp:`network-commands-options`]
|
Loading…
Reference in New Issue
Block a user