Add module list command
Lists versions of installed python modules (Origianlly proposed as 'version list') Change-Id: I76a51d3d6783f46ef2daa0a41626019a880a2a50
This commit is contained in:
parent
d45187a0c1
commit
a93cc3fae2
60
openstackclient/common/module.py
Normal file
60
openstackclient/common/module.py
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
# Copyright 2013 Nebula Inc.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
# not use this file except in compliance with the License. You may obtain
|
||||||
|
# a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
#
|
||||||
|
|
||||||
|
"""Module action implementation"""
|
||||||
|
|
||||||
|
import logging
|
||||||
|
import six
|
||||||
|
import sys
|
||||||
|
|
||||||
|
from cliff import show
|
||||||
|
|
||||||
|
|
||||||
|
class ListModule(show.ShowOne):
|
||||||
|
"""List module versions"""
|
||||||
|
|
||||||
|
auth_required = False
|
||||||
|
log = logging.getLogger(__name__ + '.ListModule')
|
||||||
|
|
||||||
|
def get_parser(self, prog_name):
|
||||||
|
parser = super(ListModule, self).get_parser(prog_name)
|
||||||
|
parser.add_argument(
|
||||||
|
'--all',
|
||||||
|
action='store_true',
|
||||||
|
default=False,
|
||||||
|
help='Show all modules that have version information',
|
||||||
|
)
|
||||||
|
return parser
|
||||||
|
|
||||||
|
def take_action(self, parsed_args):
|
||||||
|
self.log.debug('take_action(%s)' % parsed_args)
|
||||||
|
|
||||||
|
data = {}
|
||||||
|
# Get module versions
|
||||||
|
mods = sys.modules
|
||||||
|
for k in mods.keys():
|
||||||
|
k = k.split('.')[0]
|
||||||
|
# TODO(dtroyer): Need a better way to decide which modules to
|
||||||
|
# show for the default (not --all) invocation.
|
||||||
|
# It should be just the things we actually care
|
||||||
|
# about like client and plugin modules...
|
||||||
|
if (parsed_args.all or 'client' in k):
|
||||||
|
try:
|
||||||
|
data[k] = mods[k].__version__
|
||||||
|
except AttributeError:
|
||||||
|
# aw, just skip it
|
||||||
|
pass
|
||||||
|
|
||||||
|
return zip(*sorted(six.iteritems(data)))
|
88
openstackclient/tests/common/test_module.py
Normal file
88
openstackclient/tests/common/test_module.py
Normal file
@ -0,0 +1,88 @@
|
|||||||
|
# Copyright 2013 Nebula Inc.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
# not use this file except in compliance with the License. You may obtain
|
||||||
|
# a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
#
|
||||||
|
|
||||||
|
"""Test module module"""
|
||||||
|
|
||||||
|
import mock
|
||||||
|
|
||||||
|
from openstackclient.common import module as osc_module
|
||||||
|
from openstackclient.tests import fakes
|
||||||
|
from openstackclient.tests import utils
|
||||||
|
|
||||||
|
|
||||||
|
# NOTE(dtroyer): module_1 must match the version list filter (not --all)
|
||||||
|
# currently == '*client*'
|
||||||
|
module_name_1 = 'fakeclient'
|
||||||
|
module_version_1 = '0.1.2'
|
||||||
|
MODULE_1 = {
|
||||||
|
'__version__': module_version_1,
|
||||||
|
}
|
||||||
|
|
||||||
|
module_name_2 = 'zlib'
|
||||||
|
module_version_2 = '1.1'
|
||||||
|
MODULE_2 = {
|
||||||
|
'__version__': module_version_2,
|
||||||
|
}
|
||||||
|
|
||||||
|
MODULES = {
|
||||||
|
module_name_1: fakes.FakeModule(module_name_1, module_version_1),
|
||||||
|
module_name_2: fakes.FakeModule(module_name_2, module_version_2),
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@mock.patch.dict(
|
||||||
|
'openstackclient.common.module.sys.modules',
|
||||||
|
values=MODULES,
|
||||||
|
clear=True,
|
||||||
|
)
|
||||||
|
class TestModuleList(utils.TestCommand):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
super(TestModuleList, self).setUp()
|
||||||
|
|
||||||
|
# Get the command object to test
|
||||||
|
self.cmd = osc_module.ListModule(self.app, None)
|
||||||
|
|
||||||
|
def test_module_list_no_options(self):
|
||||||
|
arglist = []
|
||||||
|
verifylist = [
|
||||||
|
('all', False),
|
||||||
|
]
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
|
columns, data = self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
|
# Additional modules may be present, just check our additions
|
||||||
|
self.assertTrue(module_name_1 in columns)
|
||||||
|
self.assertTrue(module_version_1 in data)
|
||||||
|
|
||||||
|
def test_module_list_all(self):
|
||||||
|
arglist = [
|
||||||
|
'--all',
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('all', True),
|
||||||
|
]
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
|
columns, data = self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
|
# Additional modules may be present, just check our additions
|
||||||
|
self.assertTrue(module_name_1 in columns)
|
||||||
|
self.assertTrue(module_name_2 in columns)
|
||||||
|
self.assertTrue(module_version_1 in data)
|
||||||
|
self.assertTrue(module_version_2 in data)
|
@ -53,6 +53,12 @@ class FakeClientManager(object):
|
|||||||
self.auth_ref = None
|
self.auth_ref = None
|
||||||
|
|
||||||
|
|
||||||
|
class FakeModule(object):
|
||||||
|
def __init__(self, name, version):
|
||||||
|
self.name = name
|
||||||
|
self.__version__ = version
|
||||||
|
|
||||||
|
|
||||||
class FakeResource(object):
|
class FakeResource(object):
|
||||||
def __init__(self, manager, info, loaded=False):
|
def __init__(self, manager, info, loaded=False):
|
||||||
self.manager = manager
|
self.manager = manager
|
||||||
|
@ -26,6 +26,7 @@ console_scripts =
|
|||||||
openstack = openstackclient.shell:main
|
openstack = openstackclient.shell:main
|
||||||
|
|
||||||
openstack.cli =
|
openstack.cli =
|
||||||
|
module_list = openstackclient.common.module:ListModule
|
||||||
|
|
||||||
openstack.common =
|
openstack.common =
|
||||||
limits_show = openstackclient.common.limits:ShowLimits
|
limits_show = openstackclient.common.limits:ShowLimits
|
||||||
|
Loading…
Reference in New Issue
Block a user