diff options
author | Richard Kojedzinszky <rkojedzinszky@users.noreply.github.com> | 2020-12-18 18:26:04 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-12-18 09:26:04 -0800 |
commit | 17ef4319a34f5a2f95e7823dfb5f5b8cff11882d (patch) | |
tree | 769a121c883be857a22432fc1b5c57b80e60dd6a /Lib/test/test_asyncio/test_asyncio_waitfor.py | |
parent | 2179349d8cf45b1202775547df384b1fde31630a (diff) | |
download | cpython-17ef4319a34f5a2f95e7823dfb5f5b8cff11882d.tar.gz cpython-17ef4319a34f5a2f95e7823dfb5f5b8cff11882d.zip |
bpo-41891: ensure asyncio.wait_for waits for task completion (#22461)
Diffstat (limited to 'Lib/test/test_asyncio/test_asyncio_waitfor.py')
-rw-r--r-- | Lib/test/test_asyncio/test_asyncio_waitfor.py | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/Lib/test/test_asyncio/test_asyncio_waitfor.py b/Lib/test/test_asyncio/test_asyncio_waitfor.py new file mode 100644 index 00000000000..2ca64abbeb5 --- /dev/null +++ b/Lib/test/test_asyncio/test_asyncio_waitfor.py @@ -0,0 +1,61 @@ +import asyncio +import unittest +import time + +def tearDownModule(): + asyncio.set_event_loop_policy(None) + + +class SlowTask: + """ Task will run for this defined time, ignoring cancel requests """ + TASK_TIMEOUT = 0.2 + + def __init__(self): + self.exited = False + + async def run(self): + exitat = time.monotonic() + self.TASK_TIMEOUT + + while True: + tosleep = exitat - time.monotonic() + if tosleep <= 0: + break + + try: + await asyncio.sleep(tosleep) + except asyncio.CancelledError: + pass + + self.exited = True + +class AsyncioWaitForTest(unittest.TestCase): + + async def atest_asyncio_wait_for_cancelled(self): + t = SlowTask() + + waitfortask = asyncio.create_task(asyncio.wait_for(t.run(), t.TASK_TIMEOUT * 2)) + await asyncio.sleep(0) + waitfortask.cancel() + await asyncio.wait({waitfortask}) + + self.assertTrue(t.exited) + + def test_asyncio_wait_for_cancelled(self): + asyncio.run(self.atest_asyncio_wait_for_cancelled()) + + async def atest_asyncio_wait_for_timeout(self): + t = SlowTask() + + try: + await asyncio.wait_for(t.run(), t.TASK_TIMEOUT / 2) + except asyncio.TimeoutError: + pass + + self.assertTrue(t.exited) + + def test_asyncio_wait_for_timeout(self): + asyncio.run(self.atest_asyncio_wait_for_timeout()) + + +if __name__ == '__main__': + unittest.main() |