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:
parent
af5e9d16e8
commit
e2a9a9607c
@ -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
|
||||||
|
@ -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)
|
||||||
|
@ -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)
|
||||||
|
@ -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.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user