commit c36518cb39c965733d7734c328597260d30f255d Author: juga0 juga@riseup.net Date: Wed Feb 19 17:00:14 2020 +0000
fix: tests: Test maximum retry delta in destination --- tests/unit/lib/test_destination.py | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+)
diff --git a/tests/unit/lib/test_destination.py b/tests/unit/lib/test_destination.py index ca2ff21..b5a766f 100644 --- a/tests/unit/lib/test_destination.py +++ b/tests/unit/lib/test_destination.py @@ -1,6 +1,7 @@ """Unit tests for sbws.lib.destination.""" from datetime import datetime, timedelta
+from sbws.globals import MAX_SECONDS_RETRY_DESTINATION from sbws.lib import destination
@@ -8,6 +9,12 @@ def test_destination_is_functional(): eleven_mins_ago = datetime.utcnow() - timedelta(minutes=11) six_mins_ago = datetime.utcnow() - timedelta(minutes=6) four_mins_ago = datetime.utcnow() - timedelta(minutes=4) + # Make last time tried a bit bigger than the half of the maximum, so that + # it's bigger than the delta time to retry, and when delta time to retry + # is muliplied by a factor (2) it reaches the maximum. + long_ago = datetime.utcnow() - timedelta( + (MAX_SECONDS_RETRY_DESTINATION / 2) + 2 + )
d = destination.Destination('unexistenturl', 0, False) assert d.is_functional() @@ -52,3 +59,16 @@ def test_destination_is_functional(): assert d.is_functional() # And the delta to try is resetted assert not d._is_last_try_old_enough() + + # When the delta time to retry a destination increase too much, + # set it to a maximum, and try the destination again + d.add_failure() + d.add_failure() + d.add_failure(long_ago) + # Pretend the delta seconds was already set to a bit more than + # half the maximum. + d._delta_seconds_retry = (MAX_SECONDS_RETRY_DESTINATION / 2) + 1 + assert d._are_last_attempts_failures() + assert d._is_last_try_old_enough() + assert d.is_functional() + assert d._delta_seconds_retry == MAX_SECONDS_RETRY_DESTINATION