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
|
||||
|
||||
|
||||
class FakeModule(object):
|
||||
def __init__(self, name, version):
|
||||
self.name = name
|
||||
self.__version__ = version
|
||||
|
||||
|
||||
class FakeResource(object):
|
||||
def __init__(self, manager, info, loaded=False):
|
||||
self.manager = manager
|
||||
|
Loading…
Reference in New Issue
Block a user