summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJoshua Harlow <harlowja@yahoo-inc.com>2015-06-23 18:22:53 -0700
committerJoshua Harlow <harlowja@yahoo-inc.com>2015-06-23 18:22:53 -0700
commit2a84101c9a84e3006624ba14d7779c99fb0ef354 (patch)
treecd49468b4522455eb938bdc9ba4ff6261dff88df
parentda33537e0850f997aea75c4dec010e2b5594071f (diff)
downloadretrying-2a84101c9a84e3006624ba14d7779c99fb0ef354.tar.gz
Add a upper bound on incrementing wait
-rw-r--r--retrying.py4
1 files changed, 4 insertions, 0 deletions
diff --git a/retrying.py b/retrying.py
index 3ed312d..74c3294 100644
--- a/retrying.py
+++ b/retrying.py
@@ -62,6 +62,7 @@ class Retrying(object):
wait_fixed=None,
wait_random_min=None, wait_random_max=None,
wait_incrementing_start=None, wait_incrementing_increment=None,
+ wait_incrementing_max=None,
wait_exponential_multiplier=None, wait_exponential_max=None,
retry_on_exception=None,
retry_on_result=None,
@@ -79,6 +80,7 @@ class Retrying(object):
self._wait_incrementing_increment = 100 if wait_incrementing_increment is None else wait_incrementing_increment
self._wait_exponential_multiplier = 1 if wait_exponential_multiplier is None else wait_exponential_multiplier
self._wait_exponential_max = MAX_WAIT if wait_exponential_max is None else wait_exponential_max
+ self._wait_incrementing_max = MAX_WAIT if wait_incrementing_max is None else wait_incrementing_max
self._wait_jitter_max = 0 if wait_jitter_max is None else wait_jitter_max
# TODO add chaining of stop behaviors
@@ -164,6 +166,8 @@ class Retrying(object):
wait_incrementing_start and incrementing by wait_incrementing_increment
"""
result = self._wait_incrementing_start + (self._wait_incrementing_increment * (previous_attempt_number - 1))
+ if result > self._wait_incrementing_max:
+ result = self._wait_incrementing_max
if result < 0:
result = 0
return result