Nova aggregate-details should be more human friendly

'nova aggregate-details' shows Hosts, Availability Zone
and Metadata in the python unicode notation.

Change-Id: If0028347146439994265c60c429af05dd67912f9
Closes-Bug: #1132961
This commit is contained in:
Sahid Orentino Ferdjaoui 2013-10-08 15:29:41 +00:00
parent 362cb18cb4
commit 6374ee04a3
4 changed files with 46 additions and 2 deletions

View File

@ -163,3 +163,23 @@ class PrintResultTestCase(test_utils.TestCase):
'| k3 | 3 |\n' '| k3 | 3 |\n'
'| k2 | 2 |\n' '| k2 | 2 |\n'
'+------+-------+\n') '+------+-------+\n')
def test_pretty_choice_list(self):
l = []
r = utils.pretty_choice_list(l)
self.assertEqual(r, "")
l = ["v1", "v2", "v3"]
r = utils.pretty_choice_list(l)
self.assertEqual(r, "'v1', 'v2', 'v3'")
def test_pretty_choice_dict(self):
d = {}
r = utils.pretty_choice_dict(d)
self.assertEqual(r, "")
d = {"k1": "v1",
"k2": "v2",
"k3": "v3"}
r = utils.pretty_choice_dict(d)
self.assertEqual(r, "'k1=v1', 'k2=v2', 'k3=v3'")

View File

@ -143,6 +143,11 @@ def pretty_choice_list(l):
return ', '.join("'%s'" % i for i in l) return ', '.join("'%s'" % i for i in l)
def pretty_choice_dict(d):
"""Returns a formatted dict as 'key=value'."""
return pretty_choice_list(['%s=%s' % (k, d[k]) for k in sorted(d.keys())])
def print_list(objs, fields, formatters={}, sortby_index=None): def print_list(objs, fields, formatters={}, sortby_index=None):
if sortby_index is None: if sortby_index is None:
sortby = None sortby = None

View File

@ -2687,7 +2687,17 @@ def do_aggregate_details(cs, args):
def _print_aggregate_details(aggregate): def _print_aggregate_details(aggregate):
columns = ['Id', 'Name', 'Availability Zone', 'Hosts', 'Metadata'] columns = ['Id', 'Name', 'Availability Zone', 'Hosts', 'Metadata']
utils.print_list([aggregate], columns)
parser_metadata = lambda o: utils.pretty_choice_dict(
getattr(o, 'metadata', {}) or {})
parser_hosts = lambda o: utils.pretty_choice_list(
getattr(o, 'hosts', []))
formatters = {
'Metadata': parser_metadata,
'Hosts': parser_hosts,
}
utils.print_list([aggregate], columns, formatters=formatters)
@utils.arg('server', metavar='<server>', help='Name or ID of server.') @utils.arg('server', metavar='<server>', help='Name or ID of server.')

View File

@ -2517,7 +2517,16 @@ def do_aggregate_details(cs, args):
def _print_aggregate_details(aggregate): def _print_aggregate_details(aggregate):
columns = ['Id', 'Name', 'Availability Zone', 'Hosts', 'Metadata'] columns = ['Id', 'Name', 'Availability Zone', 'Hosts', 'Metadata']
utils.print_list([aggregate], columns) parser_metadata = lambda o: utils.pretty_choice_dict(
getattr(o, 'metadata', {}) or {})
parser_hosts = lambda o: utils.pretty_choice_list(
getattr(o, 'hosts', []))
formatters = {
'Metadata': parser_metadata,
'Hosts': parser_hosts,
}
utils.print_list([aggregate], columns, formatters=formatters)
@utils.arg('server', metavar='<server>', help='Name or ID of server.') @utils.arg('server', metavar='<server>', help='Name or ID of server.')