X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/5a80356ddc3798f6530e306901d7ea5e19cfe3f9..90209af8fa35bc99c9821db0c815404d1234ef31:/sdk/python/tests/test_retry.py diff --git a/sdk/python/tests/test_retry.py b/sdk/python/tests/test_retry.py index ed0a406e85..cc12f39a35 100644 --- a/sdk/python/tests/test_retry.py +++ b/sdk/python/tests/test_retry.py @@ -7,8 +7,6 @@ import arvados.errors as arv_error import arvados.retry as arv_retry import mock -from arvados_testutil import fake_httplib2_response - class RetryLoopTestMixin(object): @staticmethod def loop_success(result): @@ -143,15 +141,14 @@ class RetryLoopBackoffTestCase(unittest.TestCase, RetryLoopTestMixin): def test_backoff_multiplier(self, sleep_mock, time_mock): self.run_loop(5, 500, 501, 502, 503, 504, 505, - backoff_start=5, backoff_growth=10) + backoff_start=5, backoff_growth=10, max_wait=1000000000) self.check_backoff(sleep_mock, 5, 9) class CheckHTTPResponseSuccessTestCase(unittest.TestCase): def results_map(self, *codes): for code in codes: - response = (fake_httplib2_response(code), None) - yield code, arv_retry.check_http_response_success(response) + yield code, arv_retry.check_http_response_success(code) def check(assert_name): def check_method(self, expected, *codes): @@ -194,5 +191,34 @@ class CheckHTTPResponseSuccessTestCase(unittest.TestCase): self.check_is(None, 0, 99, 600, -200) +class RetryMethodTestCase(unittest.TestCase): + class Tester(object): + def __init__(self): + self.num_retries = 1 + + @arv_retry.retry_method + def check(self, a, num_retries=None, z=0): + return (a, num_retries, z) + + + def test_positional_arg_raises(self): + # unsupported use -- make sure we raise rather than ignore + with self.assertRaises(TypeError): + self.assertEqual((3, 2, 0), self.Tester().check(3, 2)) + + def test_keyword_arg_passed(self): + self.assertEqual((4, 3, 0), self.Tester().check(num_retries=3, a=4)) + + def test_not_specified(self): + self.assertEqual((0, 1, 0), self.Tester().check(0)) + + def test_not_specified_with_other_kwargs(self): + self.assertEqual((1, 1, 1), self.Tester().check(1, z=1)) + + def test_bad_call(self): + with self.assertRaises(TypeError): + self.Tester().check(num_retries=2) + + if __name__ == '__main__': unittest.main()