|
|
29510e |
From f5cb86b83aedaa18fd784d06d8f1479b9127c6f5 Mon Sep 17 00:00:00 2001
|
|
|
29510e |
From: Marek Blaha <mblaha@redhat.com>
|
|
|
29510e |
Date: Wed, 6 Oct 2021 09:43:37 +0200
|
|
|
29510e |
Subject: [PATCH] Fix reporting irrecoverable errors on packages download
|
|
|
29510e |
|
|
|
29510e |
The original _irrecoverable property returns random dictionary - either
|
|
|
29510e |
packages irrecoverable errors, or global fatal error or even new empty
|
|
|
29510e |
dictionary. This makes it prone to programmer errors like:
|
|
|
29510e |
|
|
|
29510e |
errs._irrecoverable[pkg] = [err]
|
|
|
29510e |
|
|
|
29510e |
which may lead to setting the error into the newly created empty
|
|
|
29510e |
dictionary instead of packages errors dictionary as intended.
|
|
|
29510e |
|
|
|
29510e |
I turned the property to method which I consider more clear.
|
|
|
29510e |
---
|
|
|
29510e |
dnf/base.py | 8 ++++----
|
|
|
29510e |
dnf/repo.py | 9 ++++-----
|
|
|
29510e |
2 files changed, 8 insertions(+), 9 deletions(-)
|
|
|
29510e |
|
|
|
29510e |
diff --git a/dnf/base.py b/dnf/base.py
|
|
|
29510e |
index 0949ddf..b0a378c 100644
|
|
|
29510e |
--- a/dnf/base.py
|
|
|
29510e |
+++ b/dnf/base.py
|
|
|
29510e |
@@ -1165,8 +1165,8 @@ class Base(object):
|
|
|
29510e |
progress.start(len(payloads), est_remote_size)
|
|
|
29510e |
errors = dnf.repo._download_payloads(payloads, drpm)
|
|
|
29510e |
|
|
|
29510e |
- if errors._irrecoverable:
|
|
|
29510e |
- raise dnf.exceptions.DownloadError(errors._irrecoverable)
|
|
|
29510e |
+ if errors._irrecoverable():
|
|
|
29510e |
+ raise dnf.exceptions.DownloadError(errors._irrecoverable())
|
|
|
29510e |
|
|
|
29510e |
remote_size = sum(errors._bandwidth_used(pload)
|
|
|
29510e |
for pload in payloads)
|
|
|
29510e |
@@ -1191,8 +1191,8 @@ class Base(object):
|
|
|
29510e |
progress.start(len(payloads), est_remote_size)
|
|
|
29510e |
errors = dnf.repo._download_payloads(payloads, drpm)
|
|
|
29510e |
|
|
|
29510e |
- if errors._irrecoverable:
|
|
|
29510e |
- raise dnf.exceptions.DownloadError(errors._irrecoverable)
|
|
|
29510e |
+ if errors._irrecoverable():
|
|
|
29510e |
+ raise dnf.exceptions.DownloadError(errors._irrecoverable())
|
|
|
29510e |
|
|
|
29510e |
remote_size += \
|
|
|
29510e |
sum(errors._bandwidth_used(pload) for pload in payloads)
|
|
|
29510e |
diff --git a/dnf/repo.py b/dnf/repo.py
|
|
|
29510e |
index b5c9849..b454e98 100644
|
|
|
29510e |
--- a/dnf/repo.py
|
|
|
29510e |
+++ b/dnf/repo.py
|
|
|
29510e |
@@ -112,7 +112,7 @@ def _download_payloads(payloads, drpm):
|
|
|
29510e |
errs._skipped.add(pkg)
|
|
|
29510e |
continue
|
|
|
29510e |
pkg.repo._repo.expire()
|
|
|
29510e |
- errs._irrecoverable[pkg] = [err]
|
|
|
29510e |
+ errs._pkg_irrecoverable[pkg] = [err]
|
|
|
29510e |
|
|
|
29510e |
return errs
|
|
|
29510e |
|
|
|
29510e |
@@ -131,15 +131,14 @@ def _update_saving(saving, payloads, errs):
|
|
|
29510e |
|
|
|
29510e |
class _DownloadErrors(object):
|
|
|
29510e |
def __init__(self):
|
|
|
29510e |
- self._val_irrecoverable = {}
|
|
|
29510e |
+ self._pkg_irrecoverable = {}
|
|
|
29510e |
self._val_recoverable = {}
|
|
|
29510e |
self._fatal = None
|
|
|
29510e |
self._skipped = set()
|
|
|
29510e |
|
|
|
29510e |
- @property
|
|
|
29510e |
def _irrecoverable(self):
|
|
|
29510e |
- if self._val_irrecoverable:
|
|
|
29510e |
- return self._val_irrecoverable
|
|
|
29510e |
+ if self._pkg_irrecoverable:
|
|
|
29510e |
+ return self._pkg_irrecoverable
|
|
|
29510e |
if self._fatal:
|
|
|
29510e |
return {'': [self._fatal]}
|
|
|
29510e |
return {}
|
|
|
29510e |
--
|
|
|
29510e |
libgit2 1.0.1
|
|
|
29510e |
|