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:
parent
362cb18cb4
commit
6374ee04a3
@ -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'")
|
||||||
|
@ -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
|
||||||
|
@ -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.')
|
||||||
|
@ -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.')
|
||||||
|
Loading…
Reference in New Issue
Block a user