Merge "Doc, help and message updates for port unset"

This commit is contained in:
Jenkins 2016-09-17 02:04:50 +00:00 committed by Gerrit Code Review
commit 7e990ba1e2
2 changed files with 28 additions and 37 deletions

View File

@ -292,9 +292,9 @@ Unset subnet properties
.. option:: --allocation-pool start=<ip-address>,end=<ip-address> .. option:: --allocation-pool start=<ip-address>,end=<ip-address>
Allocation pool to be removed from this subnet e.g.: Allocation pool IP addresses to be removed from this
``start=192.168.199.2,end=192.168.199.254`` subnet e.g.: ``start=192.168.199.2,end=192.168.199.254``
(repeat option to unset multiple Allocation pools) (repeat option to unset multiple allocation pools)
.. option:: --host-route destination=<subnet>,gateway=<ip-address> .. option:: --host-route destination=<subnet>,gateway=<ip-address>
@ -314,4 +314,4 @@ Unset subnet properties
.. _subnet_unset-subnet: .. _subnet_unset-subnet:
.. describe:: <subnet> .. describe:: <subnet>
subnet to modify (name or ID) Subnet to modify (name or ID)

View File

@ -28,9 +28,14 @@ from openstackclient.identity import common as identity_common
LOG = logging.getLogger(__name__) LOG = logging.getLogger(__name__)
def _update_arguments(obj_list, parsed_args_list): def _update_arguments(obj_list, parsed_args_list, option):
for item in parsed_args_list: for item in parsed_args_list:
try:
obj_list.remove(item) obj_list.remove(item)
except ValueError:
msg = (_("Subnet does not contain %(option)s %(value)s") %
{'option': option, 'value': item})
raise exceptions.CommandError(msg)
def _format_allocation_pools(data): def _format_allocation_pools(data):
@ -493,9 +498,9 @@ class UnsetSubnet(command.Command):
dest='allocation_pools', dest='allocation_pools',
action=parseractions.MultiKeyValueAction, action=parseractions.MultiKeyValueAction,
required_keys=['start', 'end'], required_keys=['start', 'end'],
help=_('Allocation pool to be removed from this subnet ' help=_('Allocation pool IP addresses to be removed from this '
'e.g.: start=192.168.199.2,end=192.168.199.254 ' 'subnet e.g.: start=192.168.199.2,end=192.168.199.254 '
'(repeat option to unset multiple Allocation pools)') '(repeat option to unset multiple allocation pools)')
) )
parser.add_argument( parser.add_argument(
'--dns-nameserver', '--dns-nameserver',
@ -503,7 +508,7 @@ class UnsetSubnet(command.Command):
action='append', action='append',
dest='dns_nameservers', dest='dns_nameservers',
help=_('DNS server to be removed from this subnet ' help=_('DNS server to be removed from this subnet '
'(repeat option to set multiple DNS servers)') '(repeat option to unset multiple DNS servers)')
) )
parser.add_argument( parser.add_argument(
'--host-route', '--host-route',
@ -540,39 +545,25 @@ class UnsetSubnet(command.Command):
tmp_obj = copy.deepcopy(obj) tmp_obj = copy.deepcopy(obj)
attrs = {} attrs = {}
if parsed_args.dns_nameservers: if parsed_args.dns_nameservers:
try:
_update_arguments(tmp_obj.dns_nameservers, _update_arguments(tmp_obj.dns_nameservers,
parsed_args.dns_nameservers) parsed_args.dns_nameservers,
except ValueError as error: 'dns-nameserver')
msg = (_("%s not in dns-nameservers") % str(error))
raise exceptions.CommandError(msg)
attrs['dns_nameservers'] = tmp_obj.dns_nameservers attrs['dns_nameservers'] = tmp_obj.dns_nameservers
if parsed_args.host_routes: if parsed_args.host_routes:
try:
_update_arguments( _update_arguments(
tmp_obj.host_routes, tmp_obj.host_routes,
convert_entries_to_nexthop(parsed_args.host_routes)) convert_entries_to_nexthop(parsed_args.host_routes),
except ValueError as error: 'host-route')
msg = (_("Subnet does not have %s in host-routes") %
str(error))
raise exceptions.CommandError(msg)
attrs['host_routes'] = tmp_obj.host_routes attrs['host_routes'] = tmp_obj.host_routes
if parsed_args.allocation_pools: if parsed_args.allocation_pools:
try:
_update_arguments(tmp_obj.allocation_pools, _update_arguments(tmp_obj.allocation_pools,
parsed_args.allocation_pools) parsed_args.allocation_pools,
except ValueError as error: 'allocation-pool')
msg = (_("Subnet does not have %s in allocation-pools") %
str(error))
raise exceptions.CommandError(msg)
attrs['allocation_pools'] = tmp_obj.allocation_pools attrs['allocation_pools'] = tmp_obj.allocation_pools
if parsed_args.service_types: if parsed_args.service_types:
try:
_update_arguments(tmp_obj.service_types, _update_arguments(tmp_obj.service_types,
parsed_args.service_types) parsed_args.service_types,
except ValueError as error: 'service-type')
msg = (_("%s not in service-types") % str(error))
raise exceptions.CommandError(msg)
attrs['service_types'] = tmp_obj.service_types attrs['service_types'] = tmp_obj.service_types
if attrs: if attrs:
client.update_subnet(obj, **attrs) client.update_subnet(obj, **attrs)