add progress indicator for archive check

Depending on the number of archives in a repository, the archive check part
of the check operation can take some time, so it should have a progress
indicator as well.
This commit is contained in:
Elmar Hoffmann 2021-05-14 18:17:04 +02:00
parent 7a872bbcdd
commit 938e7f295c
1 changed files with 4 additions and 0 deletions

View File

@ -1877,8 +1877,11 @@ class ArchiveChecker:
return
num_archives = len(archive_infos)
pi = ProgressIndicatorPercent(total=num_archives, msg='Checking archives %3.1f%%', step=0.1,
msgid='check.rebuild_refcounts')
with cache_if_remote(self.repository) as repository:
for i, info in enumerate(archive_infos):
pi.show(i)
logger.info('Analyzing archive {} ({}/{})'.format(info.name, i + 1, num_archives))
archive_id = info.id
if archive_id not in self.chunks:
@ -1908,6 +1911,7 @@ class ArchiveChecker:
cdata = self.key.encrypt(data)
add_reference(new_archive_id, len(data), len(cdata), cdata)
self.manifest.archives[info.name] = (new_archive_id, info.ts)
pi.finish()
def orphan_chunks_check(self):
if self.check_all: