forked from pool/python-backoff
* Support changes required for pytest-asyncio 1.0. OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-backoff?expand=0&rev=15
94 lines
2.7 KiB
Diff
94 lines
2.7 KiB
Diff
From 0fc3d0342143e1579075a8873bbcba94d14a3fd3 Mon Sep 17 00:00:00 2001
|
|
From: Takuya Wakazono <pastalian46@gmail.com>
|
|
Date: Thu, 26 Jun 2025 00:40:53 +0900
|
|
Subject: [PATCH] Adapt test cases to pytest-asyncio 1.0 compatibility
|
|
|
|
- Remove deprecated event_loop fixture
|
|
https://pytest-asyncio.readthedocs.io/en/stable/reference/changelog.html#removed
|
|
- Drop *_without_event_loop tests
|
|
These incompatible tests (*1) are no longer needed since the
|
|
underlying code has already been removed (introduced in a460156,
|
|
removed in 5d714ccd).
|
|
|
|
*1: asyncio.get_event_loop() now raises a RuntimeError in Python 3.14
|
|
when no loop exists.
|
|
https://docs.python.org/3.14/whatsnew/3.14.html#id7
|
|
---
|
|
tests/test_backoff_async.py | 53 ++-----------------------------------
|
|
1 file changed, 2 insertions(+), 51 deletions(-)
|
|
|
|
diff --git a/tests/test_backoff_async.py b/tests/test_backoff_async.py
|
|
index 226ef08..dbdb0fb 100644
|
|
--- a/tests/test_backoff_async.py
|
|
+++ b/tests/test_backoff_async.py
|
|
@@ -665,7 +665,7 @@ async def exceptor():
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
-async def test_on_exception_coro_cancelling(event_loop):
|
|
+async def test_on_exception_coro_cancelling():
|
|
sleep_started_event = asyncio.Event()
|
|
|
|
@backoff.on_predicate(backoff.expo)
|
|
@@ -679,59 +679,10 @@ async def coro():
|
|
|
|
return False
|
|
|
|
- task = event_loop.create_task(coro())
|
|
+ task = asyncio.create_task(coro())
|
|
|
|
await sleep_started_event.wait()
|
|
|
|
task.cancel()
|
|
|
|
assert (await task)
|
|
-
|
|
-
|
|
-def test_on_predicate_on_regular_function_without_event_loop(monkeypatch):
|
|
- monkeypatch.setattr('time.sleep', lambda x: None)
|
|
-
|
|
- # Set default event loop to None.
|
|
- loop = asyncio.get_event_loop()
|
|
- asyncio.set_event_loop(None)
|
|
-
|
|
- try:
|
|
- @backoff.on_predicate(backoff.expo)
|
|
- def return_true(log, n):
|
|
- val = (len(log) == n - 1)
|
|
- log.append(val)
|
|
- return val
|
|
-
|
|
- log = []
|
|
- ret = return_true(log, 3)
|
|
- assert ret is True
|
|
- assert 3 == len(log)
|
|
-
|
|
- finally:
|
|
- # Restore event loop.
|
|
- asyncio.set_event_loop(loop)
|
|
-
|
|
-
|
|
-def test_on_exception_on_regular_function_without_event_loop(monkeypatch):
|
|
- monkeypatch.setattr('time.sleep', lambda x: None)
|
|
-
|
|
- # Set default event loop to None.
|
|
- loop = asyncio.get_event_loop()
|
|
- asyncio.set_event_loop(None)
|
|
-
|
|
- try:
|
|
- @backoff.on_exception(backoff.expo, KeyError)
|
|
- def keyerror_then_true(log, n):
|
|
- if len(log) == n:
|
|
- return True
|
|
- e = KeyError()
|
|
- log.append(e)
|
|
- raise e
|
|
-
|
|
- log = []
|
|
- assert keyerror_then_true(log, 3) is True
|
|
- assert 3 == len(log)
|
|
-
|
|
- finally:
|
|
- # Restore event loop.
|
|
- asyncio.set_event_loop(loop)
|