Add 'command list' command
* Add method to CommandManager to retrieve command names by group * Add ListCommands To list command groups loaded by cliff Change-Id: I37fe2471aa2fafa8aa223159452d52b1981021d6
This commit is contained in:
parent
5b6c24fdb0
commit
d32185cb34
@ -16,6 +16,7 @@
|
|||||||
"""Modify cliff.CommandManager"""
|
"""Modify cliff.CommandManager"""
|
||||||
|
|
||||||
import logging
|
import logging
|
||||||
|
import pkg_resources
|
||||||
|
|
||||||
import cliff.commandmanager
|
import cliff.commandmanager
|
||||||
|
|
||||||
@ -46,3 +47,17 @@ class CommandManager(cliff.commandmanager.CommandManager):
|
|||||||
def get_command_groups(self):
|
def get_command_groups(self):
|
||||||
"""Returns a list of the loaded command groups"""
|
"""Returns a list of the loaded command groups"""
|
||||||
return self.group_list
|
return self.group_list
|
||||||
|
|
||||||
|
def get_command_names(self, group=None):
|
||||||
|
"""Returns a list of commands loaded for the specified group"""
|
||||||
|
group_list = []
|
||||||
|
if group is not None:
|
||||||
|
for ep in pkg_resources.iter_entry_points(group):
|
||||||
|
cmd_name = (
|
||||||
|
ep.name.replace('_', ' ')
|
||||||
|
if self.convert_underscores
|
||||||
|
else ep.name
|
||||||
|
)
|
||||||
|
group_list.append(cmd_name)
|
||||||
|
return group_list
|
||||||
|
return self.commands.keys()
|
||||||
|
@ -19,9 +19,25 @@ import logging
|
|||||||
import six
|
import six
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
|
from cliff import lister
|
||||||
from cliff import show
|
from cliff import show
|
||||||
|
|
||||||
|
|
||||||
|
class ListCommand(lister.Lister):
|
||||||
|
"""List recognized commands by group"""
|
||||||
|
|
||||||
|
auth_required = False
|
||||||
|
log = logging.getLogger(__name__ + '.ListCommand')
|
||||||
|
|
||||||
|
def take_action(self, parsed_args):
|
||||||
|
self.log.debug('take_action(%s)', parsed_args)
|
||||||
|
cm = self.app.command_manager
|
||||||
|
groups = cm.get_command_groups()
|
||||||
|
|
||||||
|
columns = ('Command Group', 'Commands')
|
||||||
|
return (columns, ((c, cm.get_command_names(group=c)) for c in groups))
|
||||||
|
|
||||||
|
|
||||||
class ListModule(show.ShowOne):
|
class ListModule(show.ShowOne):
|
||||||
"""List module versions"""
|
"""List module versions"""
|
||||||
|
|
||||||
|
@ -86,3 +86,20 @@ class TestCommandManager(utils.TestCase):
|
|||||||
|
|
||||||
gl = mgr.get_command_groups()
|
gl = mgr.get_command_groups()
|
||||||
self.assertEqual(['test', 'greek'], gl)
|
self.assertEqual(['test', 'greek'], gl)
|
||||||
|
|
||||||
|
def test_get_command_names(self):
|
||||||
|
mock_cmd_one = mock.Mock()
|
||||||
|
mock_cmd_one.name = 'one'
|
||||||
|
mock_cmd_two = mock.Mock()
|
||||||
|
mock_cmd_two.name = 'cmd two'
|
||||||
|
mock_pkg_resources = mock.Mock(
|
||||||
|
return_value=[mock_cmd_one, mock_cmd_two],
|
||||||
|
)
|
||||||
|
with mock.patch(
|
||||||
|
'pkg_resources.iter_entry_points',
|
||||||
|
mock_pkg_resources,
|
||||||
|
) as iter_entry_points:
|
||||||
|
mgr = commandmanager.CommandManager('test')
|
||||||
|
assert iter_entry_points.called_once_with('test')
|
||||||
|
cmds = mgr.get_command_names('test')
|
||||||
|
self.assertEqual(['one', 'cmd two'], cmds)
|
||||||
|
@ -42,6 +42,38 @@ MODULES = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
class TestCommandList(utils.TestCommand):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
super(TestCommandList, self).setUp()
|
||||||
|
|
||||||
|
self.app.command_manager = mock.Mock()
|
||||||
|
self.app.command_manager.get_command_groups.return_value = ['test']
|
||||||
|
self.app.command_manager.get_command_names.return_value = [
|
||||||
|
'one',
|
||||||
|
'cmd two',
|
||||||
|
]
|
||||||
|
|
||||||
|
# Get the command object to test
|
||||||
|
self.cmd = osc_module.ListCommand(self.app, None)
|
||||||
|
|
||||||
|
def test_command_list_no_options(self):
|
||||||
|
arglist = []
|
||||||
|
verifylist = []
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
|
columns, data = self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
|
collist = ('Command Group', 'Commands')
|
||||||
|
self.assertEqual(collist, columns)
|
||||||
|
datalist = ((
|
||||||
|
'test',
|
||||||
|
['one', 'cmd two'],
|
||||||
|
), )
|
||||||
|
self.assertEqual(datalist, tuple(data))
|
||||||
|
|
||||||
|
|
||||||
@mock.patch.dict(
|
@mock.patch.dict(
|
||||||
'openstackclient.common.module.sys.modules',
|
'openstackclient.common.module.sys.modules',
|
||||||
values=MODULES,
|
values=MODULES,
|
||||||
|
@ -28,6 +28,7 @@ console_scripts =
|
|||||||
openstack = openstackclient.shell:main
|
openstack = openstackclient.shell:main
|
||||||
|
|
||||||
openstack.cli =
|
openstack.cli =
|
||||||
|
command_list = openstackclient.common.module:ListCommand
|
||||||
module_list = openstackclient.common.module:ListModule
|
module_list = openstackclient.common.module:ListModule
|
||||||
|
|
||||||
openstack.cli.base =
|
openstack.cli.base =
|
||||||
|
Loading…
Reference in New Issue
Block a user