Merge "Add support for 'keypairs list --user' parameter"

This commit is contained in:
Zuul 2020-11-02 12:06:41 +00:00 committed by Gerrit Code Review
commit 7fdbc6b8af
3 changed files with 104 additions and 3 deletions

View File

@ -26,6 +26,7 @@ from osc_lib import exceptions
from osc_lib import utils from osc_lib import utils
from openstackclient.i18n import _ from openstackclient.i18n import _
from openstackclient.identity import common as identity_common
LOG = logging.getLogger(__name__) LOG = logging.getLogger(__name__)
@ -163,13 +164,45 @@ class DeleteKeypair(command.Command):
class ListKeypair(command.Lister): class ListKeypair(command.Lister):
_description = _("List key fingerprints") _description = _("List key fingerprints")
def get_parser(self, prog_name):
parser = super().get_parser(prog_name)
parser.add_argument(
'--user',
metavar='<user>',
help=_(
'Show keypairs for another user (admin only) (name or ID). '
'Requires ``--os-compute-api-version`` 2.10 or greater.'
),
)
identity_common.add_user_domain_option_to_parser(parser)
return parser
def take_action(self, parsed_args): def take_action(self, parsed_args):
compute_client = self.app.client_manager.compute compute_client = self.app.client_manager.compute
identity_client = self.app.client_manager.identity
kwargs = {}
if parsed_args.user:
if compute_client.api_version < api_versions.APIVersion('2.10'):
msg = _(
'--os-compute-api-version 2.10 or greater is required to '
'support the --user option'
)
raise exceptions.CommandError(msg)
kwargs['user_id'] = identity_common.find_user(
identity_client,
parsed_args.user,
parsed_args.user_domain,
).id
data = compute_client.keypairs.list(**kwargs)
columns = ( columns = (
"Name", "Name",
"Fingerprint" "Fingerprint"
) )
data = compute_client.keypairs.list()
if compute_client.api_version >= api_versions.APIVersion('2.2'): if compute_client.api_version >= api_versions.APIVersion('2.2'):
columns += ("Type", ) columns += ("Type", )

View File

@ -13,6 +13,7 @@
# under the License. # under the License.
# #
import copy
from unittest import mock from unittest import mock
from unittest.mock import call from unittest.mock import call
import uuid import uuid
@ -23,6 +24,8 @@ from osc_lib import utils
from openstackclient.compute.v2 import keypair from openstackclient.compute.v2 import keypair
from openstackclient.tests.unit.compute.v2 import fakes as compute_fakes from openstackclient.tests.unit.compute.v2 import fakes as compute_fakes
from openstackclient.tests.unit import fakes
from openstackclient.tests.unit.identity.v2_0 import fakes as identity_fakes
from openstackclient.tests.unit import utils as tests_utils from openstackclient.tests.unit import utils as tests_utils
@ -307,6 +310,14 @@ class TestKeypairList(TestKeypair):
def setUp(self): def setUp(self):
super(TestKeypairList, self).setUp() super(TestKeypairList, self).setUp()
self.users_mock = self.app.client_manager.identity.users
self.users_mock.reset_mock()
self.users_mock.get.return_value = fakes.FakeResource(
None,
copy.deepcopy(identity_fakes.USER),
loaded=True,
)
self.keypairs_mock.list.return_value = self.keypairs self.keypairs_mock.list.return_value = self.keypairs
# Get the command object to test # Get the command object to test
@ -334,8 +345,8 @@ class TestKeypairList(TestKeypair):
) )
def test_keypair_list_v22(self): def test_keypair_list_v22(self):
self.app.client_manager.compute.api_version = api_versions.APIVersion( self.app.client_manager.compute.api_version = \
'2.2') api_versions.APIVersion('2.2')
arglist = [] arglist = []
verifylist = [] verifylist = []
@ -361,6 +372,57 @@ class TestKeypairList(TestKeypair):
tuple(data) tuple(data)
) )
def test_keypair_list_with_user(self):
# Filtering by user is support for nova api 2.10 or above
self.app.client_manager.compute.api_version = \
api_versions.APIVersion('2.10')
arglist = [
'--user', identity_fakes.user_name,
]
verifylist = [
('user', identity_fakes.user_name),
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
columns, data = self.cmd.take_action(parsed_args)
self.users_mock.get.assert_called_with(identity_fakes.user_name)
self.keypairs_mock.list.assert_called_with(
user_id=identity_fakes.user_id,
)
self.assertEqual(('Name', 'Fingerprint', 'Type'), columns)
self.assertEqual(
((
self.keypairs[0].name,
self.keypairs[0].fingerprint,
self.keypairs[0].type,
), ),
tuple(data)
)
def test_keypair_list_with_user_pre_v210(self):
self.app.client_manager.compute.api_version = \
api_versions.APIVersion('2.9')
arglist = [
'--user', identity_fakes.user_name,
]
verifylist = [
('user', identity_fakes.user_name),
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
ex = self.assertRaises(
exceptions.CommandError,
self.cmd.take_action,
parsed_args)
self.assertIn(
'--os-compute-api-version 2.10 or greater is required', str(ex))
class TestKeypairShow(TestKeypair): class TestKeypairShow(TestKeypair):

View File

@ -0,0 +1,6 @@
---
features:
- |
It is now possible to list the keypairs for a specific user using the
``--user`` parameter. This is an admin-only action by default and requires
Compute API microversion 2.10 or later.