]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
bpo-44911: Fixed IsolatedAsyncioTestCase from throwing an exception on leaked tasks...
authorBar Harel <bar.harel@biocatch.com>
Mon, 16 Aug 2021 08:21:08 +0000 (11:21 +0300)
committerGitHub <noreply@github.com>
Mon, 16 Aug 2021 08:21:08 +0000 (10:21 +0200)
Lib/unittest/async_case.py
Lib/unittest/test/test_async_case.py
Misc/NEWS.d/next/Library/2021-08-14-00-55-16.bpo-44911.uk3hYk.rst [new file with mode: 0644]

index 520213c37275555f29d37bf361202fb72d1af4ec..86ed7046c499a374f953bf721f8c7eeeab2e4adc 100644 (file)
@@ -135,7 +135,7 @@ class IsolatedAsyncioTestCase(TestCase):
                 task.cancel()
 
             loop.run_until_complete(
-                asyncio.gather(*to_cancel, loop=loop, return_exceptions=True))
+                asyncio.gather(*to_cancel, return_exceptions=True))
 
             for task in to_cancel:
                 if task.cancelled():
index d01864b6936ca8d2ec5d47e2c2b6bd7fb1ab092f..6e48b9e4bfed367a1ceb0b2008fdfd5fe06b380e 100644 (file)
@@ -216,6 +216,26 @@ class TestAsyncCase(unittest.TestCase):
         output = test.run()
         self.assertFalse(output.wasSuccessful())
 
+    def test_cancellation_hanging_tasks(self):
+        cancelled = False
+        class Test(unittest.IsolatedAsyncioTestCase):
+            async def test_leaking_task(self):
+                async def coro():
+                    nonlocal cancelled
+                    try:
+                        await asyncio.sleep(1)
+                    except asyncio.CancelledError:
+                        cancelled = True
+                        raise
+
+                # Leave this running in the background
+                asyncio.create_task(coro())
+
+        test = Test("test_leaking_task")
+        output = test.run()
+        self.assertTrue(cancelled)
+
+
 
 
 if __name__ == "__main__":
diff --git a/Misc/NEWS.d/next/Library/2021-08-14-00-55-16.bpo-44911.uk3hYk.rst b/Misc/NEWS.d/next/Library/2021-08-14-00-55-16.bpo-44911.uk3hYk.rst
new file mode 100644 (file)
index 0000000..f8aed69
--- /dev/null
@@ -0,0 +1 @@
+:class:`~unittest.IsolatedAsyncioTestCase` will no longer throw an exception while cancelling leaked tasks. Patch by Bar Harel.
\ No newline at end of file