To display image size in human friendly format

Include option '--human-readable' to 'image show' command.
This option displays image size in human readable format
(such as K, M, G, T,..)

Related Commit: I0ef74c2ec978483fe49156c88acf5c369a8fa5c2
Closes-Bug: #1640086
Change-Id: I28cd5702925d51303d0607ed8dccf12c56434682
This commit is contained in:
Badhmapriya Boopalan 2016-11-15 19:55:46 +00:00 committed by Steve Martinelli
parent 5bf5de6f45
commit 6962cc963e
7 changed files with 83 additions and 4 deletions

View File

@ -706,6 +706,12 @@ class ShowImage(command.ShowOne):
def get_parser(self, prog_name): def get_parser(self, prog_name):
parser = super(ShowImage, self).get_parser(prog_name) parser = super(ShowImage, self).get_parser(prog_name)
parser.add_argument(
"--human-readable",
default=False,
action='store_true',
help=_("Print image size in a human-friendly format."),
)
parser.add_argument( parser.add_argument(
"image", "image",
metavar="<image>", metavar="<image>",
@ -722,5 +728,8 @@ class ShowImage(command.ShowOne):
info = {} info = {}
info.update(image._info) info.update(image._info)
if parsed_args.human_readable:
if 'size' in info:
info['size'] = utils.format_size(info['size'])
info['properties'] = utils.format_dict(info.get('properties', {})) info['properties'] = utils.format_dict(info.get('properties', {}))
return zip(*sorted(six.iteritems(info))) return zip(*sorted(six.iteritems(info)))

View File

@ -848,6 +848,12 @@ class ShowImage(command.ShowOne):
def get_parser(self, prog_name): def get_parser(self, prog_name):
parser = super(ShowImage, self).get_parser(prog_name) parser = super(ShowImage, self).get_parser(prog_name)
parser.add_argument(
"--human-readable",
default=False,
action='store_true',
help=_("Print image size in a human-friendly format."),
)
parser.add_argument( parser.add_argument(
"image", "image",
metavar="<image>", metavar="<image>",
@ -861,6 +867,8 @@ class ShowImage(command.ShowOne):
image_client.images, image_client.images,
parsed_args.image, parsed_args.image,
) )
if parsed_args.human_readable:
image['size'] = utils.format_size(image['size'])
info = _format_image(image) info = _format_image(image)
return zip(*sorted(six.iteritems(info))) return zip(*sorted(six.iteritems(info)))

View File

@ -34,6 +34,7 @@ image_properties = {
} }
image_properties_str = "Alpha='a', Beta='b', Gamma='g'" image_properties_str = "Alpha='a', Beta='b', Gamma='g'"
image_data = 'line 1\nline 2\n' image_data = 'line 1\nline 2\n'
image_size = 0
IMAGE = { IMAGE = {
'id': image_id, 'id': image_id,
@ -46,6 +47,7 @@ IMAGE = {
'is_public': image_public, 'is_public': image_public,
'protected': image_protected, 'protected': image_protected,
'properties': image_properties, 'properties': image_properties,
'size': image_size,
} }
IMAGE_columns = tuple(sorted(IMAGE)) IMAGE_columns = tuple(sorted(IMAGE))

View File

@ -692,7 +692,8 @@ class TestImageSet(TestImage):
class TestImageShow(TestImage): class TestImageShow(TestImage):
_image = image_fakes.FakeImage.create_one_image() _image = image_fakes.FakeImage.create_one_image(
attrs={'size': 2000})
columns = ( columns = (
'container_format', 'container_format',
'disk_format', 'disk_format',
@ -704,6 +705,7 @@ class TestImageShow(TestImage):
'owner', 'owner',
'properties', 'properties',
'protected', 'protected',
'size',
) )
data = ( data = (
_image.container_format, _image.container_format,
@ -716,6 +718,7 @@ class TestImageShow(TestImage):
_image.owner, _image.owner,
utils.format_dict(_image.properties), utils.format_dict(_image.properties),
_image.protected, _image.protected,
_image.size,
) )
def setUp(self): def setUp(self):
@ -745,3 +748,25 @@ class TestImageShow(TestImage):
self.assertEqual(self.columns, columns) self.assertEqual(self.columns, columns)
self.assertEqual(self.data, data) self.assertEqual(self.data, data)
def test_image_show_human_readable(self):
arglist = [
'--human-readable',
self._image.id,
]
verifylist = [
('human_readable', True),
('image', self._image.id),
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
# In base command class ShowOne in cliff, abstract method take_action()
# returns a two-part tuple with a tuple of column names and a tuple of
# data to be shown.
columns, data = self.cmd.take_action(parsed_args)
self.images_mock.get.assert_called_with(
self._image.id,
)
size_index = columns.index('size')
self.assertEqual(data[size_index], '2K')

View File

@ -32,6 +32,7 @@ image_owner = 'baal'
image_protected = False image_protected = False
image_visibility = 'public' image_visibility = 'public'
image_tags = [] image_tags = []
image_size = 0
IMAGE = { IMAGE = {
'id': image_id, 'id': image_id,
@ -39,7 +40,8 @@ IMAGE = {
'owner': image_owner, 'owner': image_owner,
'protected': image_protected, 'protected': image_protected,
'visibility': image_visibility, 'visibility': image_visibility,
'tags': image_tags 'tags': image_tags,
'size': image_size
} }
IMAGE_columns = tuple(sorted(IMAGE)) IMAGE_columns = tuple(sorted(IMAGE))
@ -106,7 +108,8 @@ IMAGE_schema = {
"size": { "size": {
"type": [ "type": [
"null", "null",
"integer" "integer",
"string"
], ],
"description": "Size of image file in bytes (READ-ONLY)" "description": "Size of image file in bytes (READ-ONLY)"
}, },
@ -185,7 +188,7 @@ class FakeImage(object):
A dictionary with all attrbutes of image A dictionary with all attrbutes of image
:return: :return:
A FakeResource object with id, name, owner, protected, A FakeResource object with id, name, owner, protected,
visibility and tags attrs visibility, tags and size attrs
""" """
attrs = attrs or {} attrs = attrs or {}

View File

@ -1177,6 +1177,9 @@ class TestImageSet(TestImage):
class TestImageShow(TestImage): class TestImageShow(TestImage):
new_image = image_fakes.FakeImage.create_one_image(
attrs={'size': 1000})
def setUp(self): def setUp(self):
super(TestImageShow, self).setUp() super(TestImageShow, self).setUp()
@ -1211,6 +1214,29 @@ class TestImageShow(TestImage):
self.assertEqual(image_fakes.IMAGE_columns, columns) self.assertEqual(image_fakes.IMAGE_columns, columns)
self.assertEqual(image_fakes.IMAGE_SHOW_data, data) self.assertEqual(image_fakes.IMAGE_SHOW_data, data)
def test_image_show_human_readable(self):
self.images_mock.get.return_value = self.new_image
arglist = [
'--human-readable',
self.new_image.id,
]
verifylist = [
('human_readable', True),
('image', self.new_image.id),
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
# In base command class ShowOne in cliff, abstract method take_action()
# returns a two-part tuple with a tuple of column names and a tuple of
# data to be shown.
columns, data = self.cmd.take_action(parsed_args)
self.images_mock.get.assert_called_with(
self.new_image.id,
)
size_index = columns.index('size')
self.assertEqual(data[size_index], '1K')
class TestImageUnset(TestImage): class TestImageUnset(TestImage):

View File

@ -0,0 +1,6 @@
---
features:
- |
Add ``--human-readable`` option to ``image show`` to display
image size in human readable format (such as K, M, G, T,..)
[Bug `1640086 <https://bugs.launchpad.net/bugs/1640086>`_]