diff --git a/swh/storage/tests/test_retry.py b/swh/storage/tests/test_retry.py --- a/swh/storage/tests/test_retry.py +++ b/swh/storage/tests/test_retry.py @@ -25,6 +25,24 @@ from .storage_data import date_visit1 +@pytest.fixture +def monkeypatch_sleep(monkeypatch, swh_storage): + """In test context, we don't want to wait, make test faster + + """ + from swh.storage.retry import RetryingProxyStorage + + methods = [ + m for m in RetryingProxyStorage.__dict__.keys() if "_add" in m or "_update" in m + ] + + for retry_method in methods: + method = getattr(RetryingProxyStorage, retry_method) + monkeypatch.setattr(method.retry, "sleep", lambda x: None) + + yield monkeypatch + + @pytest.fixture def fake_hash_collision(sample_data): return HashCollision("sha1", "38762cf7f55934b34d179ae6a4c80cadccbb7f0a", []) @@ -59,7 +77,7 @@ def test_retrying_proxy_storage_content_add_with_retry( - swh_storage, sample_data, mocker, fake_hash_collision + monkeypatch_sleep, swh_storage, sample_data, mocker, fake_hash_collision, ): """Multiple retries for hash collision and psycopg2 error but finally ok @@ -73,9 +91,6 @@ # ok then! {"content:add": 1}, ] - mock_sleep = mocker.patch( - "swh.storage.retry.RetryingProxyStorage" ".content_add.retry.sleep" - ) sample_content = sample_data["content"][0] @@ -92,7 +107,6 @@ call([Content.from_dict(sample_content)]), ] ) - assert mock_sleep.call_count == 2 def test_retrying_proxy_swh_storage_content_add_failure( @@ -136,7 +150,7 @@ def test_retrying_proxy_storage_content_add_metadata_with_retry( - swh_storage, sample_data, mocker, fake_hash_collision + monkeypatch_sleep, swh_storage, sample_data, mocker, fake_hash_collision ): """Multiple retries for hash collision and psycopg2 error but finally ok @@ -152,9 +166,6 @@ # ok then! {"content:add": 1}, ] - mock_sleep = mocker.patch( - "swh.storage.retry.RetryingProxyStorage" ".content_add_metadata.retry.sleep" - ) sample_content = sample_data["content_metadata"][0] @@ -168,7 +179,6 @@ call([Content.from_dict(sample_content)]), ] ) - assert mock_sleep.call_count == 2 def test_retrying_proxy_swh_storage_content_add_metadata_failure( @@ -215,7 +225,7 @@ def test_retrying_proxy_storage_skipped_content_add_with_retry( - swh_storage, sample_data, mocker, fake_hash_collision + monkeypatch_sleep, swh_storage, sample_data, mocker, fake_hash_collision ): """Multiple retries for hash collision and psycopg2 error but finally ok @@ -230,9 +240,6 @@ # ok then! {"skipped_content:add": 1}, ] - mock_sleep = mocker.patch( - "swh.storage.retry.RetryingProxyStorage" ".skipped_content_add.retry.sleep" - ) sample_content = sample_data["skipped_content"][0] @@ -246,7 +253,6 @@ call([SkippedContent.from_dict(sample_content)]), ] ) - assert mock_sleep.call_count == 2 def test_retrying_proxy_swh_storage_skipped_content_add_failure( @@ -293,7 +299,7 @@ def test_retrying_proxy_swh_storage_origin_add_one_retry( - swh_storage, sample_data, mocker, fake_hash_collision + monkeypatch_sleep, swh_storage, sample_data, mocker, fake_hash_collision ): """Multiple retries for hash collision and psycopg2 error but finally ok @@ -308,9 +314,6 @@ # ok then! sample_origin["url"], ] - mock_sleep = mocker.patch( - "swh.storage.retry.RetryingProxyStorage" ".origin_add_one.retry.sleep" - ) origin = swh_storage.origin_get(sample_origin) assert not origin @@ -325,7 +328,6 @@ call(Origin.from_dict(sample_origin)), ] ) - assert mock_sleep.call_count == 2 def test_retrying_proxy_swh_storage_origin_add_one_failure( @@ -368,7 +370,7 @@ def test_retrying_proxy_swh_storage_origin_visit_add_retry( - swh_storage, sample_data, mocker, fake_hash_collision + monkeypatch_sleep, swh_storage, sample_data, mocker, fake_hash_collision ): """Multiple retries for hash collision and psycopg2 error but finally ok @@ -385,9 +387,6 @@ # ok then! {"origin": origin_url, "visit": 1}, ] - mock_sleep = mocker.patch( - "swh.storage.retry.RetryingProxyStorage" ".origin_visit_add.retry.sleep" - ) origin = list(swh_storage.origin_visit_get(origin_url)) assert not origin @@ -402,7 +401,6 @@ call(origin_url, date_visit1, "git"), ] ) - assert mock_sleep.call_count == 2 def test_retrying_proxy_swh_storage_origin_visit_add_failure( @@ -448,7 +446,7 @@ def test_retrying_proxy_storage_tool_add_with_retry( - swh_storage, sample_data, mocker, fake_hash_collision + monkeypatch_sleep, swh_storage, sample_data, mocker, fake_hash_collision ): """Multiple retries for hash collision and psycopg2 error but finally ok @@ -463,9 +461,6 @@ # ok then! [sample_tool], ] - mock_sleep = mocker.patch( - "swh.storage.retry.RetryingProxyStorage" ".tool_add.retry.sleep" - ) tool = swh_storage.tool_get(sample_tool) assert not tool @@ -476,7 +471,6 @@ mock_memory.assert_has_calls( [call([sample_tool]), call([sample_tool]), call([sample_tool]),] ) - assert mock_sleep.call_count == 2 def test_retrying_proxy_swh_storage_tool_add_failure(swh_storage, sample_data, mocker): @@ -527,7 +521,7 @@ def test_retrying_proxy_storage_metadata_provider_add_with_retry( - swh_storage, sample_data, mocker, fake_hash_collision + monkeypatch_sleep, swh_storage, sample_data, mocker, fake_hash_collision ): """Multiple retries for hash collision and psycopg2 error but finally ok @@ -546,9 +540,6 @@ # ok then! "provider_id", ] - mock_sleep = mocker.patch( - "swh.storage.retry.RetryingProxyStorage" ".metadata_provider_add.retry.sleep" - ) provider = swh_storage.metadata_provider_get_by(provider_get) assert not provider @@ -561,7 +552,6 @@ mock_memory.assert_has_calls( [call(*provider_args), call(*provider_args), call(*provider_args),] ) - assert mock_sleep.call_count == 2 def test_retrying_proxy_swh_storage_metadata_provider_add_failure( @@ -615,7 +605,7 @@ def test_retrying_proxy_storage_origin_metadata_add_with_retry( - swh_storage, sample_data, mocker, fake_hash_collision + monkeypatch_sleep, swh_storage, sample_data, mocker, fake_hash_collision ): """Multiple retries for hash collision and psycopg2 error but finally ok @@ -638,10 +628,6 @@ None, ] - mock_sleep = mocker.patch( - "swh.storage.retry.RetryingProxyStorage" ".origin_metadata_add.retry.sleep" - ) - url = origin["url"] ts = ori_meta["discovery_date"] tool_id = ori_meta["tool"] @@ -657,7 +643,6 @@ call(url, ts, provider_id, tool_id, metadata), ] ) - assert mock_sleep.call_count == 2 def test_retrying_proxy_swh_storage_origin_metadata_add_failure( @@ -713,7 +698,7 @@ def test_retrying_proxy_swh_storage_origin_visit_update_retry( - swh_storage, sample_data, mocker, fake_hash_collision + monkeypatch_sleep, swh_storage, sample_data, mocker, fake_hash_collision ): """Multiple retries for hash collision and psycopg2 error but finally ok @@ -733,10 +718,6 @@ {"origin": origin_url, "visit": 1}, ] - mock_sleep = mocker.patch( - "swh.storage.retry.RetryingProxyStorage" ".origin_visit_update.retry.sleep" - ) - visit_id = 1 swh_storage.origin_visit_update(origin_url, visit_id, status="full") @@ -747,7 +728,6 @@ call(origin_url, visit_id, metadata=None, snapshot=None, status="full"), ] ) - assert mock_sleep.call_count == 2 def test_retrying_proxy_swh_storage_origin_visit_update_failure( @@ -788,7 +768,7 @@ def test_retrying_proxy_storage_directory_add_with_retry( - swh_storage, sample_data, mocker, fake_hash_collision + monkeypatch_sleep, swh_storage, sample_data, mocker, fake_hash_collision ): """Multiple retries for hash collision and psycopg2 error but finally ok @@ -802,9 +782,6 @@ # ok then! {"directory:add": 1}, ] - mock_sleep = mocker.patch( - "swh.storage.retry.RetryingProxyStorage" ".directory_add.retry.sleep" - ) sample_dir = sample_data["directory"][1] @@ -823,7 +800,6 @@ call([Directory.from_dict(sample_dir)]), ] ) - assert mock_sleep.call_count == 2 def test_retrying_proxy_swh_storage_directory_add_failure( @@ -867,7 +843,7 @@ def test_retrying_proxy_storage_revision_add_with_retry( - swh_storage, sample_data, mocker, fake_hash_collision + monkeypatch_sleep, swh_storage, sample_data, mocker, fake_hash_collision ): """Multiple retries for hash collision and psycopg2 error but finally ok @@ -882,10 +858,6 @@ {"revision:add": 1}, ] - mock_sleep = mocker.patch( - "swh.storage.retry.RetryingProxyStorage" ".revision_add.retry.sleep" - ) - sample_rev = sample_data["revision"][0] revision = next(swh_storage.revision_get([sample_rev["id"]])) @@ -903,7 +875,6 @@ call([Revision.from_dict(sample_rev)]), ] ) - assert mock_sleep.call_count == 2 def test_retrying_proxy_swh_storage_revision_add_failure( @@ -945,7 +916,7 @@ def test_retrying_proxy_storage_release_add_with_retry( - swh_storage, sample_data, mocker, fake_hash_collision + monkeypatch_sleep, swh_storage, sample_data, mocker, fake_hash_collision ): """Multiple retries for hash collision and psycopg2 error but finally ok @@ -960,10 +931,6 @@ {"release:add": 1}, ] - mock_sleep = mocker.patch( - "swh.storage.retry.RetryingProxyStorage" ".release_add.retry.sleep" - ) - sample_rel = sample_data["release"][0] release = next(swh_storage.release_get([sample_rel["id"]])) @@ -981,7 +948,6 @@ call([Release.from_dict(sample_rel)]), ] ) - assert mock_sleep.call_count == 2 def test_retrying_proxy_swh_storage_release_add_failure( @@ -1023,7 +989,7 @@ def test_retrying_proxy_storage_snapshot_add_with_retry( - swh_storage, sample_data, mocker, fake_hash_collision + monkeypatch_sleep, swh_storage, sample_data, mocker, fake_hash_collision ): """Multiple retries for hash collision and psycopg2 error but finally ok @@ -1038,10 +1004,6 @@ {"snapshot:add": 1}, ] - mock_sleep = mocker.patch( - "swh.storage.retry.RetryingProxyStorage" ".snapshot_add.retry.sleep" - ) - sample_snap = sample_data["snapshot"][0] snapshot = swh_storage.snapshot_get(sample_snap["id"]) @@ -1059,7 +1021,6 @@ call([Snapshot.from_dict(sample_snap)]), ] ) - assert mock_sleep.call_count == 2 def test_retrying_proxy_swh_storage_snapshot_add_failure(