From 154e1c59e6a654dbd9660550e9a0c3c4d02a0ce8 Mon Sep 17 00:00:00 2001 From: Matej Matuska Date: Thu, 16 Mar 2023 11:49:40 +0100 Subject: [PATCH] Add reports summary to the output Previously only the paths to reports were printed and as a result the reports were easily missed. Leapp now prints a list of HIGH and MEDIUM priority reports along with a summary of number of reports with individual severities to make reports more visible. Also if there are any HIGH or MEDIUM severity reports, the block titles are yellow. The framework-version is bumped to 4.0, because the `report_info` funtion now takes a context_id parameter (to be able to fetch the reports), so the new API is incompatible. --- leapp/utils/output.py | 66 +++++++++++++++++++++++++++++++++++++++---- packaging/leapp.spec | 2 +- 2 files changed, 62 insertions(+), 6 deletions(-) diff --git a/leapp/utils/output.py b/leapp/utils/output.py index fc60442ca..ae24a1d99 100644 --- a/leapp/utils/output.py +++ b/leapp/utils/output.py @@ -61,6 +61,12 @@ def print_error(error): v=details[detail].rstrip().replace('\n', '\n' + ' ' * (6 + len(detail))))) +def _print_report_titles(reports): + width = 4 + len(str(len(reports))) + for position, report in enumerate(reports, start=1): + print('{idx:{width}}. {title}'.format(idx=position, width=width, title=report['title'])) + + def report_inhibitors(context_id): # The following imports are required to be here to avoid import loop problems from leapp.utils.report import fetch_upgrade_report_messages, is_inhibitor # noqa; pylint: disable=import-outside-toplevel @@ -70,8 +76,7 @@ def report_inhibitors(context_id): text = 'UPGRADE INHIBITED' with pretty_block(text=text, end_text=text, color=Color.red, target=sys.stdout): print('Upgrade has been inhibited due to the following problems:') - for position, report in enumerate(inhibitors, start=1): - print('{idx:5}. Inhibitor: {title}'.format(idx=position, title=report['title'])) + _print_report_titles(inhibitors) print('Consult the pre-upgrade report for details and possible remediation.') @@ -105,7 +110,33 @@ def report_errors(errors): print_error(error) -def report_info(report_paths, log_paths, answerfile=None, fail=False): +def _filter_reports(reports, severity=None, is_inhibitor=False): + # The following imports are required to be here to avoid import loop problems + from leapp.utils.report import is_inhibitor as isinhibitor # noqa; pylint: disable=import-outside-toplevel + if not severity: + return [report for report in reports if isinhibitor(report) == is_inhibitor] + return [report for report in reports if report['severity'] == severity and isinhibitor(report) == is_inhibitor] + + +def _print_reports_summary(reports): + # The following imports are required to be here to avoid import loop problems + from leapp.reporting import Severity # noqa; pylint: disable=import-outside-toplevel + + inhibitors = _filter_reports(reports, is_inhibitor=True) + high = _filter_reports(reports, Severity.HIGH) + medium = _filter_reports(reports, Severity.MEDIUM) + low = _filter_reports(reports, Severity.LOW) + info = _filter_reports(reports, Severity.INFO) + + print('Reports summary:') + print(' Inhibitors: {:5}'.format(len(inhibitors))) + print(' HIGH severity reports: {:5}'.format(len(high))) + print(' MEDIUM severity reports: {:5}'.format(len(medium))) + print(' LOW severity reports: {:5}'.format(len(low))) + print(' INFO severity reports: {:5}'.format(len(info))) + + +def report_info(context_id, report_paths, log_paths, answerfile=None, fail=False): report_paths = [report_paths] if not isinstance(report_paths, list) else report_paths log_paths = [log_paths] if not isinstance(log_paths, list) else log_paths @@ -115,9 +146,34 @@ def report_info(report_paths, log_paths, answerfile=None, fail=False): sys.stdout.write("Debug output written to {path}\n".format(path=log_path)) if report_paths: - with pretty_block("REPORT", target=sys.stdout, color=Color.bold if fail else Color.green): + # The following imports are required to be here to avoid import loop problems + from leapp.reporting import Severity # noqa; pylint: disable=import-outside-toplevel + from leapp.utils.report import fetch_upgrade_report_messages # noqa; pylint: disable=import-outside-toplevel + reports = fetch_upgrade_report_messages(context_id) + + high = _filter_reports(reports, Severity.HIGH) + medium = _filter_reports(reports, Severity.MEDIUM) + + color = Color.green + if medium or high: + color = Color.yellow + if fail: + color = Color.bold + + with pretty_block("REPORT", target=sys.stdout, color=color): + if high or medium: + print('HIGH and MEDIUM severity reports:') + _print_report_titles(high + medium) + + sys.stdout.write('\n') + _print_reports_summary(reports) + + print( + '\n{bold}Before continuing consult the full report:{reset}' + .format(bold=Color.bold, reset=Color.reset) + ) for report_path in report_paths: - sys.stdout.write("A report has been generated at {path}\n".format(path=report_path)) + sys.stdout.write(" A report has been generated at {path}\n".format(path=report_path)) if answerfile: sys.stdout.write("Answerfile has been generated at {}\n".format(answerfile)) diff --git a/packaging/leapp.spec b/packaging/leapp.spec index 4f88b0029..a5936e16d 100644 --- a/packaging/leapp.spec +++ b/packaging/leapp.spec @@ -13,7 +13,7 @@ # This is kind of help for more flexible development of leapp repository, # so people do not have to wait for new official release of leapp to ensure # it is installed/used the compatible one. -%global framework_version 3.1 +%global framework_version 4.0 # IMPORTANT: everytime the requirements are changed, increment number by one # - same for Provides in deps subpackage