Enable JSON results output

This takes a lighter weight approach to allowing output to be formatted
as JSON than switching over to using cliff. This adds the --json flag
argument that will format the printed results in a much more compact
JSON format.

Change-Id: I54f3f347b0d7da4385ffcbfa5da61c83657f390c
Signed-off-by: Sean McGinnis <sean.mcginnis@gmail.com>
This commit is contained in:
Sean McGinnis 2019-05-24 10:26:29 -05:00
parent f2d44be232
commit 3a92c6e0b6
No known key found for this signature in database
GPG Key ID: CE7EE4BFAF8D70C8
3 changed files with 48 additions and 17 deletions

View File

@ -13,6 +13,7 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
import json
import sys import sys
import textwrap import textwrap
import traceback import traceback
@ -24,6 +25,8 @@ import six
from oslo_upgradecheck._i18n import _ from oslo_upgradecheck._i18n import _
CONF = None
class Code(enum.IntEnum): class Code(enum.IntEnum):
"""Status codes for the upgrade check command""" """Status codes for the upgrade check command"""
@ -92,6 +95,7 @@ class UpgradeCommands(object):
:returns: Code :returns: Code
""" """
global CONF
return_code = Code.SUCCESS return_code = Code.SUCCESS
# This is a list if 2-item tuples for the check name and it's results. # This is a list if 2-item tuples for the check name and it's results.
check_results = [] check_results = []
@ -121,6 +125,20 @@ class UpgradeCommands(object):
# NOTE(bnemec): We use six.text_type on the translated string to # NOTE(bnemec): We use six.text_type on the translated string to
# force immediate translation if lazy translation is in use. # force immediate translation if lazy translation is in use.
# See lp1801761 for details. # See lp1801761 for details.
# Since registering opts can be overridden by consuming code, we can't
# assume that our locally defined option exists.
if (hasattr(CONF, 'command') and hasattr(CONF.command, 'json') and
CONF.command.json):
output = {'name': six.text_type(self.display_title), 'checks': []}
for name, result in check_results:
output['checks'].append(
{'check': name,
'result': result.code,
'details': result.details}
)
print(json.dumps(output))
else:
t = prettytable.PrettyTable([six.text_type(self.display_title)], t = prettytable.PrettyTable([six.text_type(self.display_title)],
hrules=prettytable.ALL) hrules=prettytable.ALL)
t.align = 'l' t.align = 'l'
@ -154,6 +172,11 @@ def register_cli_options(conf, upgrade_command):
upgrade_action = subparsers.add_parser('upgrade') upgrade_action = subparsers.add_parser('upgrade')
upgrade_action.add_argument('check') upgrade_action.add_argument('check')
upgrade_action.set_defaults(action_fn=upgrade_command.check) upgrade_action.set_defaults(action_fn=upgrade_command.check)
upgrade_action.add_argument(
'--json',
action='store_true',
help='Output the results in JSON format. Default is to print '
'results in human readable table format.')
opt = cfg.SubCommandOpt('command', handler=add_parsers) opt = cfg.SubCommandOpt('command', handler=add_parsers)
conf.register_cli_opt(opt) conf.register_cli_opt(opt)
@ -194,6 +217,7 @@ def main(conf, project, upgrade_command,
the search behavior in oslo.config. the search behavior in oslo.config.
""" """
global CONF
register_cli_options(conf, upgrade_command) register_cli_options(conf, upgrade_command)
conf( conf(
@ -201,5 +225,5 @@ def main(conf, project, upgrade_command,
project=project, project=project,
default_config_files=default_config_files, default_config_files=default_config_files,
) )
CONF = conf
return run(conf) return run(conf)

View File

@ -0,0 +1,7 @@
---
features:
- |
oslo.upgradecheck now supports the command line flag ``--json`` to have
the upgrade check results output in a compact, machine readable JSON
format. The default output without this flag remains a human readable
table of the results.