From f361f44dedb5420cb9010d99e0422d505421e66b Mon Sep 17 00:00:00 2001 From: Houkime <> Date: Mon, 3 Jul 2023 20:53:21 +0000 Subject: [PATCH] feature(backups): check restore exit code --- selfprivacy_api/backup/backuppers/restic_backupper.py | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/selfprivacy_api/backup/backuppers/restic_backupper.py b/selfprivacy_api/backup/backuppers/restic_backupper.py index 14a8be8..ae86efc 100644 --- a/selfprivacy_api/backup/backuppers/restic_backupper.py +++ b/selfprivacy_api/backup/backuppers/restic_backupper.py @@ -219,7 +219,7 @@ class ResticBackupper(AbstractBackupper): raise ValueError("cannot restore without knowing where to!") with tempfile.TemporaryDirectory() as dir: - self.do_restore(snapshot_id, target=dir) + self.do_restore(snapshot_id, target=dir, verify=verify) for folder in folders: src = join(dir, folder.strip("/")) if not exists(src): @@ -249,6 +249,14 @@ class ResticBackupper(AbstractBackupper): if "restoring" not in output: raise ValueError("cannot restore a snapshot: " + output) + assert ( + handle.returncode is not None + ) # none should be impossible after communicate + if handle.returncode != 0: + raise ValueError( + "restore exited with errorcode", returncode, ":", output + ) + def _load_snapshots(self) -> object: """ Load list of snapshots from repository