Merge "Add long option to network trunk list command"

This commit is contained in:
Jenkins 2016-08-09 21:27:46 +00:00 committed by Gerrit Code Review
commit 70557dc564
3 changed files with 128 additions and 22 deletions

View File

@ -26,8 +26,6 @@ from osc_lib import utils
from openstackclient.identity import common as identity_common from openstackclient.identity import common as identity_common
from neutronclient._i18n import _ from neutronclient._i18n import _
# TODO(abhiraut): Switch to client methods
from neutronclient.neutron import v2_0 as neutronV20
LOG = logging.getLogger(__name__) LOG = logging.getLogger(__name__)
@ -58,7 +56,7 @@ class CreateNetworkTrunk(command.ShowOne):
action=parseractions.MultiKeyValueAction, dest='add_subports', action=parseractions.MultiKeyValueAction, dest='add_subports',
help=_("Subport to add. Subport is of form " help=_("Subport to add. Subport is of form "
"\'port=<name or ID>,segmentation-type=,segmentation-ID=\' " "\'port=<name or ID>,segmentation-type=,segmentation-ID=\' "
"(--subport) option can be repeated)") "(--subport) option can be repeated")
) )
admin_group = parser.add_mutually_exclusive_group() admin_group = parser.add_mutually_exclusive_group()
admin_group.add_argument( admin_group.add_argument(
@ -127,12 +125,38 @@ class DeleteNetworkTrunk(command.Command):
class ListNetworkTrunk(command.Lister): class ListNetworkTrunk(command.Lister):
"""List all network trunks""" """List all network trunks"""
def get_parser(self, prog_name):
parser = super(ListNetworkTrunk, self).get_parser(prog_name)
parser.add_argument(
'--long',
action='store_true',
default=False,
help=_("List additional fields in output")
)
return parser
def take_action(self, parsed_args): def take_action(self, parsed_args):
client = self.app.client_manager.neutronclient client = self.app.client_manager.neutronclient
data = client.list_trunks() data = client.list_trunks()
# TODO(abhiraut): List more columns using --long headers = (
headers = ('ID', 'Name', 'Parent Port') 'ID',
columns = ('id', 'name', 'port_id') 'Name',
'Parent Port'
)
columns = (
'id',
'name',
'port_id'
)
if parsed_args.long:
headers += (
'Status',
'State',
)
columns += (
'status',
'admin_state_up',
)
return (headers, return (headers,
(utils.get_dict_properties( (utils.get_dict_properties(
s, columns, s, columns,
@ -161,7 +185,7 @@ class SetNetworkTrunk(command.Command):
action=parseractions.MultiKeyValueAction, dest='set_subports', action=parseractions.MultiKeyValueAction, dest='set_subports',
help=_("Subport to add. Subport is of form " help=_("Subport to add. Subport is of form "
"\'port=<name or ID>,segmentation-type=,segmentation-ID=\'" "\'port=<name or ID>,segmentation-type=,segmentation-ID=\'"
"(--subport) option can be repeated)") "(--subport) option can be repeated")
) )
admin_group = parser.add_mutually_exclusive_group() admin_group = parser.add_mutually_exclusive_group()
admin_group.add_argument( admin_group.add_argument(
@ -181,11 +205,21 @@ class SetNetworkTrunk(command.Command):
trunk_id = _get_id(client, parsed_args.trunk, TRUNK) trunk_id = _get_id(client, parsed_args.trunk, TRUNK)
attrs = _get_attrs_for_trunk(self.app.client_manager, parsed_args) attrs = _get_attrs_for_trunk(self.app.client_manager, parsed_args)
body = {TRUNK: attrs} body = {TRUNK: attrs}
client.update_trunk(trunk_id, body) try:
client.update_trunk(trunk_id, body)
except Exception as e:
msg = (_("Failed to set trunk '%(t)s': %(e)s")
% {'t': parsed_args.trunk, 'e': e})
raise exceptions.CommandError(msg)
if parsed_args.set_subports: if parsed_args.set_subports:
subport_attrs = _get_attrs_for_subports(self.app.client_manager, subport_attrs = _get_attrs_for_subports(self.app.client_manager,
parsed_args) parsed_args)
client.trunk_add_subports(trunk_id, subport_attrs) try:
client.trunk_add_subports(trunk_id, subport_attrs)
except Exception as e:
msg = (_("Failed to add subports to trunk '%(t)s': %(e)s")
% {'t': parsed_args.trunk, 'e': e})
raise exceptions.CommandError(msg)
class ShowNetworkTrunk(command.ShowOne): class ShowNetworkTrunk(command.ShowOne):
@ -343,5 +377,4 @@ def _get_attrs_for_subports(client_manager, parsed_args):
def _get_id(client, id_or_name, resource): def _get_id(client, id_or_name, resource):
return neutronV20.find_resourceid_by_name_or_id( return client.find_resource(resource, str(id_or_name))['id']
client, resource, str(id_or_name))

View File

@ -14,7 +14,7 @@
import argparse import argparse
import mock import mock
from openstackclient.tests import utils from osc_lib.tests import utils
class TestNeutronClientOSCV2(utils.TestCommand): class TestNeutronClientOSCV2(utils.TestCommand):

View File

@ -15,13 +15,12 @@
import mock import mock
from mock import call from mock import call
import testtools
from osc_lib import exceptions from osc_lib import exceptions
from osc_lib.tests import utils as tests_utils
from osc_lib import utils from osc_lib import utils
# TODO(abhiraut): Switch to osc-lib test utils
from openstackclient.tests import utils as tests_utils
from neutronclient.osc.v2.trunk import network_trunk as trunk from neutronclient.osc.v2.trunk import network_trunk as trunk
from neutronclient.tests.unit.osc.v2 import fakes as test_fakes from neutronclient.tests.unit.osc.v2 import fakes as test_fakes
from neutronclient.tests.unit.osc.v2.trunk import fakes from neutronclient.tests.unit.osc.v2.trunk import fakes
@ -147,10 +146,8 @@ class TestCreateNetworkTrunk(test_fakes.TestNeutronClientOSCV2):
] ]
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
try: with testtools.ExpectedException(exceptions.CommandError) as e:
self.cmd.take_action(parsed_args) self.cmd.take_action(parsed_args)
self.fail('CommandError should be raised.')
except exceptions.CommandError as e:
self.assertEqual("Segmentation-id 'boom' is not an integer", self.assertEqual("Segmentation-id 'boom' is not an integer",
str(e)) str(e))
@ -217,10 +214,8 @@ class TestDeleteNetworkTrunk(test_fakes.TestNeutronClientOSCV2):
trunk._get_id = ( trunk._get_id = (
mock.MagicMock(side_effect=get_mock_result) mock.MagicMock(side_effect=get_mock_result)
) )
try: with testtools.ExpectedException(exceptions.CommandError) as e:
self.cmd.take_action(parsed_args) self.cmd.take_action(parsed_args)
self.fail('CommandError should be raised.')
except exceptions.CommandError as e:
self.assertEqual('1 of 2 trunks failed to delete.', str(e)) self.assertEqual('1 of 2 trunks failed to delete.', str(e))
self.neutronclient.delete_trunk.assert_called_once_with( self.neutronclient.delete_trunk.assert_called_once_with(
self._trunks[0] self._trunks[0]
@ -295,6 +290,10 @@ class TestListNetworkTrunk(test_fakes.TestNeutronClientOSCV2):
'Name', 'Name',
'Parent Port', 'Parent Port',
) )
columns_long = columns + (
'Status',
'State',
)
data = [] data = []
for t in _trunks: for t in _trunks:
data.append(( data.append((
@ -302,6 +301,15 @@ class TestListNetworkTrunk(test_fakes.TestNeutronClientOSCV2):
t['name'], t['name'],
t['port_id'], t['port_id'],
)) ))
data_long = []
for t in _trunks:
data_long.append((
t['id'],
t['name'],
t['port_id'],
t['status'],
trunk._format_admin_state(t['admin_state_up']),
))
def setUp(self): def setUp(self):
super(TestListNetworkTrunk, self).setUp() super(TestListNetworkTrunk, self).setUp()
@ -324,6 +332,21 @@ class TestListNetworkTrunk(test_fakes.TestNeutronClientOSCV2):
self.assertEqual(self.columns, columns) self.assertEqual(self.columns, columns)
self.assertEqual(self.data, list(data)) self.assertEqual(self.data, list(data))
def test_trunk_list_long(self):
arglist = [
'--long',
]
verifylist = [
('long', True),
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
columns, data = self.cmd.take_action(parsed_args)
self.neutronclient.list_trunks.assert_called_once_with()
self.assertEqual(self.columns_long, columns)
self.assertEqual(self.data_long, list(data))
class TestSetNetworkTrunk(test_fakes.TestNeutronClientOSCV2): class TestSetNetworkTrunk(test_fakes.TestNeutronClientOSCV2):
# Create trunks to be listed. # Create trunks to be listed.
@ -435,7 +458,7 @@ class TestSetNetworkTrunk(test_fakes.TestNeutronClientOSCV2):
def test_set_network_trunk_subports(self): def test_set_network_trunk_subports(self):
subport = self._trunk['sub_ports'][0] subport = self._trunk['sub_ports'][0]
arglist = [ arglist = [
"--subport", 'port=%(port)s,segmentation-type=%(seg_type)s,' '--subport', 'port=%(port)s,segmentation-type=%(seg_type)s,'
'segmentation-id=%(seg_id)s' % { 'segmentation-id=%(seg_id)s' % {
'seg_id': subport['segmentation_id'], 'seg_id': subport['segmentation_id'],
'seg_type': subport['segmentation_type'], 'seg_type': subport['segmentation_type'],
@ -458,6 +481,56 @@ class TestSetNetworkTrunk(test_fakes.TestNeutronClientOSCV2):
) )
self.assertIsNone(result) self.assertIsNone(result)
def test_set_trunk_attrs_with_exception(self):
arglist = [
'--name', 'reallylongname',
self._trunk['name'],
]
verifylist = [
('trunk', self._trunk['name']),
('name', 'reallylongname'),
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
self.neutronclient.update_trunk = (
mock.MagicMock(side_effect=exceptions.CommandError)
)
with testtools.ExpectedException(exceptions.CommandError) as e:
self.cmd.take_action(parsed_args)
self.assertEqual(
"Failed to set trunk '%s': " % self._trunk['name'],
str(e))
attrs = {'name': 'reallylongname'}
self.neutronclient.update_trunk.assert_called_once_with(
self._trunk['name'], {trunk.TRUNK: attrs})
self.neutronclient.trunk_add_subports.assert_not_called()
def test_set_trunk_add_subport_with_exception(self):
arglist = [
'--subport', 'port=invalid_subport',
self._trunk['name'],
]
verifylist = [
('trunk', self._trunk['name']),
('set_subports', [{'port': 'invalid_subport'}]),
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
self.neutronclient.trunk_add_subports = (
mock.MagicMock(side_effect=exceptions.CommandError)
)
with testtools.ExpectedException(exceptions.CommandError) as e:
self.cmd.take_action(parsed_args)
self.assertEqual(
"Failed to add subports to trunk '%s': " % self._trunk['name'],
str(e))
self.neutronclient.update_trunk.assert_called_once_with(
self._trunk['name'], {trunk.TRUNK: {}})
self.neutronclient.trunk_add_subports.assert_called_once_with(
self._trunk['name'],
{'sub_ports': [{'port_id': 'invalid_subport'}]}
)
class TestListNetworkSubport(test_fakes.TestNeutronClientOSCV2): class TestListNetworkSubport(test_fakes.TestNeutronClientOSCV2):