diff options
author | John Griffith <john.griffith8@gmail.com> | 2017-06-22 20:35:24 +0000 |
---|---|---|
committer | John Griffith <john.griffith8@gmail.com> | 2017-07-03 18:06:38 +0000 |
commit | 0ea7b2e0cf1dfd31ee8f12ceae5193c4a68c60b3 (patch) | |
tree | 583e498323ea051e023f2fe24dc650199261f995 | |
parent | 44e650a4ed183af9fa977af192355450afd4f1b7 (diff) | |
download | python-cinderclient-0ea7b2e0cf1dfd31ee8f12ceae5193c4a68c60b3.tar.gz |
cinder show with attachments is a mess
The show command currently just dumps the entire attachments
dictionary into the output which is a real mess and completely
screws up the displayed output (shell command).
There's really no reason to do this, we can just give the
attachment ID's and then when you're on the newer versions
you can do an attachment-show for all the crazy details if
you want. Keep in mind that the list command already shows
the server-id we're attached too, but that might also be
nice from the show command rather than jumping through
multiple commands. To try and accomodate various use cases
we'll also add an "attached_servers" field to the show command,
but you'll have to coorelate manually from there.
Change-Id: I45ac49d8d9a185c52727c5bc24a6a1323be83689
Closes-Bug: #1494941
-rw-r--r-- | cinderclient/tests/functional/test_cli.py | 3 | ||||
-rw-r--r-- | cinderclient/tests/unit/v2/fakes.py | 3 | ||||
-rw-r--r-- | cinderclient/v2/shell.py | 16 |
3 files changed, 19 insertions, 3 deletions
diff --git a/cinderclient/tests/functional/test_cli.py b/cinderclient/tests/functional/test_cli.py index 01083c4..8047459 100644 --- a/cinderclient/tests/functional/test_cli.py +++ b/cinderclient/tests/functional/test_cli.py @@ -17,7 +17,8 @@ from cinderclient.tests.functional import base class CinderVolumeTests(base.ClientTestBase): """Check of base cinder volume commands.""" - VOLUME_PROPERTY = ('attachments', 'availability_zone', 'bootable', + VOLUME_PROPERTY = ('attachment_ids', 'attached_servers', + 'availability_zone', 'bootable', 'created_at', 'description', 'encrypted', 'id', 'metadata', 'name', 'size', 'status', 'user_id', 'volume_type') diff --git a/cinderclient/tests/unit/v2/fakes.py b/cinderclient/tests/unit/v2/fakes.py index 6978a62..9adcaee 100644 --- a/cinderclient/tests/unit/v2/fakes.py +++ b/cinderclient/tests/unit/v2/fakes.py @@ -28,7 +28,8 @@ REQUEST_ID = 'req-test-request-id' def _stub_volume(*args, **kwargs): volume = { "migration_status": None, - "attachments": [{u'server_id': u'1234'}], + "attachments": [{u'server_id': u'1234', u'id': + u'3f88836f-adde-4296-9f6b-2c59a0bcda9a'}], "links": [ { "href": "http://localhost/v2/fake/volumes/1234", diff --git a/cinderclient/v2/shell.py b/cinderclient/v2/shell.py index 7186fe8..9777378 100644 --- a/cinderclient/v2/shell.py +++ b/cinderclient/v2/shell.py @@ -32,6 +32,18 @@ from cinderclient import utils from cinderclient.v2 import availability_zones +def _translate_attachments(info): + attachments = [] + attached_servers = [] + for attachment in info['attachments']: + attachments.append(attachment['id']) + attached_servers.append(attachment['server_id']) + info.pop('attachments', None) + info['attachment_ids'] = attachments + info['attached_servers'] = attached_servers + return info + + @utils.arg('--all-tenants', dest='all_tenants', metavar='<0|1>', @@ -188,9 +200,10 @@ def do_show(cs, args): info['readonly'] = info['metadata']['readonly'] info.pop('links', None) + info = _translate_attachments(info) utils.print_dict(info, formatters=['metadata', 'volume_image_metadata', - 'attachments']) + 'attachment_ids', 'attached_servers']) class CheckSizeArgForCreate(argparse.Action): @@ -340,6 +353,7 @@ def do_create(cs, args): info['readonly'] = info['metadata']['readonly'] info.pop('links', None) + info = _translate_attachments(info) utils.print_dict(info) |