Skip to content

Commit

Permalink
automatic: Enhance errors reporting
Browse files Browse the repository at this point in the history
Emitters must be initialized early to ensure they can report errors that
might occur in earlier stages of execution, before transaction
resolution. Also a broader range of exceptions must be caught to
ensure they are communicated to the user through the configured
emitters.
For example "No space left on the device" error is raised during the
fill_sack() call. This patch should report it via configured emitters.

Resolves: https://issues.redhat.com/browse/RHEL-61882
  • Loading branch information
m-blaha committed Dec 9, 2024
1 parent 69d1f64 commit 5db022b
Showing 1 changed file with 3 additions and 3 deletions.
6 changes: 3 additions & 3 deletions dnf/automatic/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -318,6 +318,7 @@ def main(args):
try:
conf = AutomaticConfig(opts.conf_path, opts.downloadupdates,
opts.installupdates)
emitters = build_emitters(conf)
with dnf.Base() as base:
cli = dnf.cli.Cli(base)
cli._read_conf_file()
Expand Down Expand Up @@ -351,7 +352,6 @@ def main(args):
return 0

lst = output.list_transaction(trans, total_width=80)
emitters = build_emitters(conf)
emitters.notify_available(lst)
if not conf.commands.download_updates:
emitters.commit()
Expand Down Expand Up @@ -380,8 +380,8 @@ def main(args):
exit_code = os.waitstatus_to_exitcode(os.system(conf.commands.reboot_command))
if exit_code != 0:
raise dnf.exceptions.Error('reboot command returned nonzero exit code: %d', exit_code)
except dnf.exceptions.Error as exc:
logger.error(_('Error: %s'), ucd(exc))
except Exception as exc:
logger.error(_('Error: %s'), ucd(exc), exc_info=True)
if conf is not None and conf.emitters.send_error_messages and emitters is not None:
emitters.notify_error(_('Error: %s') % str(exc))
emitters.commit()
Expand Down

0 comments on commit 5db022b

Please sign in to comment.