From fc5ac179ed113bf32d55c71eab9f79907d40a8fb Mon Sep 17 00:00:00 2001 From: Rick van Hattem Date: Wed, 13 Mar 2019 16:06:38 +0100 Subject: [PATCH] Fixed updates for non-timed progressbars. Fixes #185 --- progressbar/bar.py | 2 ++ tests/test_monitor_progress.py | 30 ++++++++++++++++++++++++++++++ 2 files changed, 32 insertions(+) diff --git a/progressbar/bar.py b/progressbar/bar.py index 31a34857..c76b9670 100644 --- a/progressbar/bar.py +++ b/progressbar/bar.py @@ -538,6 +538,8 @@ def _needs_update(self): divisor = self.max_value / self.term_width # float division if self.value // divisor == self.previous_value // divisor: return poll_status or self.end_time + else: + return True except Exception: # ignore any division errors pass diff --git a/tests/test_monitor_progress.py b/tests/test_monitor_progress.py index 73ce84bd..d0ec0f04 100644 --- a/tests/test_monitor_progress.py +++ b/tests/test_monitor_progress.py @@ -139,3 +139,33 @@ def test_context_wrapper(testdir): ' 80% (4 of 5) |##### | Elapsed Time: ?:00:04 ETA: ?:00:01', '100% (5 of 5) |#######| Elapsed Time: ?:00:05 Time: ?:00:05', ]) + + +def test_non_timed(testdir): + v = testdir.makepyfile(''' + import time + import timeit + import freezegun + import progressbar + + widgets = [progressbar.Percentage(), progressbar.Bar()] + + with freezegun.freeze_time() as fake_time: + timeit.default_timer = time.time + with progressbar.ProgressBar(widgets=widgets, term_width=60) as bar: + bar._MINIMUM_UPDATE_INTERVAL = 1e-9 + for _ in bar(list(range(5))): + fake_time.tick(1) + ''') + + result = testdir.runpython(v) + result.stderr.lines = [l for l in result.stderr.lines if l.strip()] + pprint.pprint(result.stderr.lines, width=70) + result.stderr.fnmatch_lines([ + 'N/A%| |', + ' 20%|########## |', + ' 40%|##################### |', + ' 60%|################################ |', + ' 80%|########################################### |', + '100%|######################################################|', + ])