]> granicus.if.org Git - python/commitdiff
Issue #21163: Fix "destroy pending task" warning in test_wait_errors()
authorVictor Stinner <victor.stinner@gmail.com>
Wed, 16 Jul 2014 16:50:39 +0000 (18:50 +0200)
committerVictor Stinner <victor.stinner@gmail.com>
Wed, 16 Jul 2014 16:50:39 +0000 (18:50 +0200)
Lib/asyncio/tasks.py
Lib/test/test_asyncio/test_tasks.py

index a741bd338e37c94de2f24ce959dd2e272c54edaf..07952c9a64f6f9ae896a01081064f5b76866db66 100644 (file)
@@ -330,14 +330,14 @@ def wait(fs, *, loop=None, timeout=None, return_when=ALL_COMPLETED):
         raise TypeError("expect a list of futures, not %s" % type(fs).__name__)
     if not fs:
         raise ValueError('Set of coroutines/Futures is empty.')
+    if return_when not in (FIRST_COMPLETED, FIRST_EXCEPTION, ALL_COMPLETED):
+        raise ValueError('Invalid return_when value: {}'.format(return_when))
 
     if loop is None:
         loop = events.get_event_loop()
 
     fs = {async(f, loop=loop) for f in set(fs)}
 
-    if return_when not in (FIRST_COMPLETED, FIRST_EXCEPTION, ALL_COMPLETED):
-        raise ValueError('Invalid return_when value: {}'.format(return_when))
     return (yield from _wait(fs, timeout, return_when, loop))
 
 
index ca770f909e610f9c001c57518162dc8353c96e45..e199c5a48f0e3899942f5c7a6fe2c7c1eeacddf1 100644 (file)
@@ -623,10 +623,13 @@ class TaskTests(test_utils.TestCase):
             ValueError, self.loop.run_until_complete,
             asyncio.wait(set(), loop=self.loop))
 
-        self.assertRaises(
-            ValueError, self.loop.run_until_complete,
-            asyncio.wait([asyncio.sleep(10.0, loop=self.loop)],
-                         return_when=-1, loop=self.loop))
+        # -1 is an invalid return_when value
+        sleep_coro = asyncio.sleep(10.0, loop=self.loop)
+        wait_coro = asyncio.wait([sleep_coro], return_when=-1, loop=self.loop)
+        self.assertRaises(ValueError,
+                          self.loop.run_until_complete, wait_coro)
+
+        sleep_coro.close()
 
     def test_wait_first_completed(self):