compute: Fix 'server group * -f yaml' output

Make use of 'FormattableColumn'-derived formatters, which provide better
output than what we were using before, particularly for the YAML output
format.

Change-Id: Id6d25a0a348596d5a0430ff7afbf87b049a76bc8
Signed-off-by: Stephen Finucane <sfinucan@redhat.com>
This commit is contained in:
Stephen Finucane 2020-11-05 11:29:54 +00:00
parent af5e9d16e8
commit e2a9a9607c
4 changed files with 51 additions and 40 deletions

View File

@ -18,6 +18,7 @@
import logging import logging
from novaclient import api_versions from novaclient import api_versions
from osc_lib.cli import format_columns
from osc_lib.command import command from osc_lib.command import command
from osc_lib import exceptions from osc_lib import exceptions
from osc_lib import utils from osc_lib import utils
@ -29,8 +30,8 @@ LOG = logging.getLogger(__name__)
_formatters = { _formatters = {
'policies': utils.format_list, 'policies': format_columns.ListColumn,
'members': utils.format_list, 'members': format_columns.ListColumn,
} }
@ -93,8 +94,8 @@ class CreateServerGroup(command.ShowOne):
info.update(server_group._info) info.update(server_group._info)
columns = _get_columns(info) columns = _get_columns(info)
data = utils.get_dict_properties(info, columns, data = utils.get_dict_properties(
formatters=_formatters) info, columns, formatters=_formatters)
return columns, data return columns, data
@ -176,14 +177,18 @@ class ListServerGroup(command.Lister):
policy_key, policy_key,
) )
return (column_headers, return (
(utils.get_item_properties( column_headers,
(
utils.get_item_properties(
s, columns, s, columns,
formatters={ formatters={
'Policies': utils.format_list, 'Policies': format_columns.ListColumn,
'Members': utils.format_list, 'Members': format_columns.ListColumn,
} }
) for s in data)) ) for s in data
),
)
class ShowServerGroup(command.ShowOne): class ShowServerGroup(command.ShowOne):
@ -205,6 +210,6 @@ class ShowServerGroup(command.ShowOne):
info = {} info = {}
info.update(group._info) info.update(group._info)
columns = _get_columns(info) columns = _get_columns(info)
data = utils.get_dict_properties(info, columns, data = utils.get_dict_properties(
formatters=_formatters) info, columns, formatters=_formatters)
return columns, data return columns, data

View File

@ -33,7 +33,7 @@ class ServerGroupTests(base.TestCase):
cmd_output['name'] cmd_output['name']
) )
self.assertEqual( self.assertEqual(
'affinity', ['affinity'],
cmd_output['policies'] cmd_output['policies']
) )
@ -47,7 +47,7 @@ class ServerGroupTests(base.TestCase):
cmd_output['name'] cmd_output['name']
) )
self.assertEqual( self.assertEqual(
'anti-affinity', ['anti-affinity'],
cmd_output['policies'] cmd_output['policies']
) )
@ -74,7 +74,7 @@ class ServerGroupTests(base.TestCase):
cmd_output['name'] cmd_output['name']
) )
self.assertEqual( self.assertEqual(
'affinity', ['affinity'],
cmd_output['policies'] cmd_output['policies']
) )
@ -91,7 +91,7 @@ class ServerGroupTests(base.TestCase):
cmd_output['name'] cmd_output['name']
) )
self.assertEqual( self.assertEqual(
'anti-affinity', ['anti-affinity'],
cmd_output['policies'] cmd_output['policies']
) )
@ -102,5 +102,5 @@ class ServerGroupTests(base.TestCase):
self.assertIn(name1, names) self.assertIn(name1, names)
self.assertIn(name2, names) self.assertIn(name2, names)
policies = [x["Policies"] for x in cmd_output] policies = [x["Policies"] for x in cmd_output]
self.assertIn('affinity', policies) self.assertIn(['affinity'], policies)
self.assertIn('anti-affinity', policies) self.assertIn(['anti-affinity'], policies)

View File

@ -16,6 +16,7 @@
from unittest import mock from unittest import mock
from novaclient import api_versions from novaclient import api_versions
from osc_lib.cli import format_columns
from osc_lib import exceptions from osc_lib import exceptions
from osc_lib import utils from osc_lib import utils
@ -39,9 +40,9 @@ class TestServerGroup(compute_fakes.TestComputev2):
data = ( data = (
fake_server_group.id, fake_server_group.id,
utils.format_list(fake_server_group.members), format_columns.ListColumn(fake_server_group.members),
fake_server_group.name, fake_server_group.name,
utils.format_list(fake_server_group.policies), format_columns.ListColumn(fake_server_group.policies),
fake_server_group.project_id, fake_server_group.project_id,
fake_server_group.user_id, fake_server_group.user_id,
) )
@ -70,7 +71,7 @@ class TestServerGroupV264(TestServerGroup):
data = ( data = (
fake_server_group.id, fake_server_group.id,
utils.format_list(fake_server_group.members), format_columns.ListColumn(fake_server_group.members),
fake_server_group.name, fake_server_group.name,
fake_server_group.policy, fake_server_group.policy,
fake_server_group.project_id, fake_server_group.project_id,
@ -105,8 +106,8 @@ class TestServerGroupCreate(TestServerGroup):
policies=[parsed_args.policy], policies=[parsed_args.policy],
) )
self.assertEqual(self.columns, columns) self.assertCountEqual(self.columns, columns)
self.assertEqual(self.data, data) self.assertCountEqual(self.data, data)
def test_server_group_create_with_soft_policies(self): def test_server_group_create_with_soft_policies(self):
self.app.client_manager.compute.api_version = api_versions.APIVersion( self.app.client_manager.compute.api_version = api_versions.APIVersion(
@ -127,8 +128,8 @@ class TestServerGroupCreate(TestServerGroup):
policies=[parsed_args.policy], policies=[parsed_args.policy],
) )
self.assertEqual(self.columns, columns) self.assertCountEqual(self.columns, columns)
self.assertEqual(self.data, data) self.assertCountEqual(self.data, data)
def test_server_group_create_with_soft_policies_pre_v215(self): def test_server_group_create_with_soft_policies_pre_v215(self):
self.app.client_manager.compute.api_version = api_versions.APIVersion( self.app.client_manager.compute.api_version = api_versions.APIVersion(
@ -170,8 +171,8 @@ class TestServerGroupCreate(TestServerGroup):
policy=parsed_args.policy, policy=parsed_args.policy,
) )
self.assertEqual(self.columns, columns) self.assertCountEqual(self.columns, columns)
self.assertEqual(self.data, data) self.assertCountEqual(self.data, data)
class TestServerGroupDelete(TestServerGroup): class TestServerGroupDelete(TestServerGroup):
@ -275,14 +276,14 @@ class TestServerGroupList(TestServerGroup):
list_data = (( list_data = ((
TestServerGroup.fake_server_group.id, TestServerGroup.fake_server_group.id,
TestServerGroup.fake_server_group.name, TestServerGroup.fake_server_group.name,
utils.format_list(TestServerGroup.fake_server_group.policies), format_columns.ListColumn(TestServerGroup.fake_server_group.policies),
),) ),)
list_data_long = (( list_data_long = ((
TestServerGroup.fake_server_group.id, TestServerGroup.fake_server_group.id,
TestServerGroup.fake_server_group.name, TestServerGroup.fake_server_group.name,
utils.format_list(TestServerGroup.fake_server_group.policies), format_columns.ListColumn(TestServerGroup.fake_server_group.policies),
utils.format_list(TestServerGroup.fake_server_group.members), format_columns.ListColumn(TestServerGroup.fake_server_group.members),
TestServerGroup.fake_server_group.project_id, TestServerGroup.fake_server_group.project_id,
TestServerGroup.fake_server_group.user_id, TestServerGroup.fake_server_group.user_id,
),) ),)
@ -303,8 +304,8 @@ class TestServerGroupList(TestServerGroup):
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.server_groups_mock.list.assert_called_once_with(False) self.server_groups_mock.list.assert_called_once_with(False)
self.assertEqual(self.list_columns, columns) self.assertCountEqual(self.list_columns, columns)
self.assertEqual(self.list_data, tuple(data)) self.assertCountEqual(self.list_data, tuple(data))
def test_server_group_list_with_all_projects_and_long(self): def test_server_group_list_with_all_projects_and_long(self):
arglist = [ arglist = [
@ -319,8 +320,8 @@ class TestServerGroupList(TestServerGroup):
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.server_groups_mock.list.assert_called_once_with(True) self.server_groups_mock.list.assert_called_once_with(True)
self.assertEqual(self.list_columns_long, columns) self.assertCountEqual(self.list_columns_long, columns)
self.assertEqual(self.list_data_long, tuple(data)) self.assertCountEqual(self.list_data_long, tuple(data))
class TestServerGroupListV264(TestServerGroupV264): class TestServerGroupListV264(TestServerGroupV264):
@ -350,7 +351,8 @@ class TestServerGroupListV264(TestServerGroupV264):
TestServerGroupV264.fake_server_group.id, TestServerGroupV264.fake_server_group.id,
TestServerGroupV264.fake_server_group.name, TestServerGroupV264.fake_server_group.name,
TestServerGroupV264.fake_server_group.policy, TestServerGroupV264.fake_server_group.policy,
utils.format_list(TestServerGroupV264.fake_server_group.members), format_columns.ListColumn(
TestServerGroupV264.fake_server_group.members),
TestServerGroupV264.fake_server_group.project_id, TestServerGroupV264.fake_server_group.project_id,
TestServerGroupV264.fake_server_group.user_id, TestServerGroupV264.fake_server_group.user_id,
),) ),)
@ -373,8 +375,8 @@ class TestServerGroupListV264(TestServerGroupV264):
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.server_groups_mock.list.assert_called_once_with(False) self.server_groups_mock.list.assert_called_once_with(False)
self.assertEqual(self.list_columns, columns) self.assertCountEqual(self.list_columns, columns)
self.assertEqual(self.list_data, tuple(data)) self.assertCountEqual(self.list_data, tuple(data))
def test_server_group_list_with_all_projects_and_long(self): def test_server_group_list_with_all_projects_and_long(self):
arglist = [ arglist = [
@ -389,8 +391,8 @@ class TestServerGroupListV264(TestServerGroupV264):
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.server_groups_mock.list.assert_called_once_with(True) self.server_groups_mock.list.assert_called_once_with(True)
self.assertEqual(self.list_columns_long, columns) self.assertCountEqual(self.list_columns_long, columns)
self.assertEqual(self.list_data_long, tuple(data)) self.assertCountEqual(self.list_data_long, tuple(data))
class TestServerGroupShow(TestServerGroup): class TestServerGroupShow(TestServerGroup):
@ -412,5 +414,5 @@ class TestServerGroupShow(TestServerGroup):
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.assertEqual(self.columns, columns) self.assertCountEqual(self.columns, columns)
self.assertEqual(self.data, data) self.assertCountEqual(self.data, data)

View File

@ -14,3 +14,7 @@ fixes:
formatter. In addition, the ``server_usages``, ``total_memory_mb_usage``, formatter. In addition, the ``server_usages``, ``total_memory_mb_usage``,
``total_vcpus_usage`` and ``total_local_gb_usage`` values will only be ``total_vcpus_usage`` and ``total_local_gb_usage`` values will only be
humanized when using the table formatter. humanized when using the table formatter.
- |
The ``policies`` (or ``policy``, on newer microversions) and ``members``
fields of the ``server group list`` and ``server group show`` commands
will now be rendered correctly as lists.