diff options
author | Joshua Harlow <harlowja@yahoo-inc.com> | 2015-06-23 18:22:53 -0700 |
---|---|---|
committer | Joshua Harlow <harlowja@yahoo-inc.com> | 2015-06-23 18:22:53 -0700 |
commit | 2a84101c9a84e3006624ba14d7779c99fb0ef354 (patch) | |
tree | cd49468b4522455eb938bdc9ba4ff6261dff88df | |
parent | da33537e0850f997aea75c4dec010e2b5594071f (diff) | |
download | retrying-2a84101c9a84e3006624ba14d7779c99fb0ef354.tar.gz |
Add a upper bound on incrementing wait
-rw-r--r-- | retrying.py | 4 |
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 |