summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorYury Selivanov <yselivanov@sprymix.com>2015-11-18 17:40:26 (GMT)
committerYury Selivanov <yselivanov@sprymix.com>2015-11-18 17:40:26 (GMT)
commit576fe71c12502349aab70f0b2b0c84ca72b47165 (patch)
treeddc84fa1098168edd6471b70382dfd394a997728 /Lib
parent1535311edcc8d5cdc4a4615abeb6d5ea6a606c5e (diff)
parentb3dd6d70c7cde5e2bdb04da388e5a56f2af5ee91 (diff)
downloadcpython-576fe71c12502349aab70f0b2b0c84ca72b47165.zip
cpython-576fe71c12502349aab70f0b2b0c84ca72b47165.tar.gz
cpython-576fe71c12502349aab70f0b2b0c84ca72b47165.tar.bz2
asyncio: Error if awaiting in parallel on the same coroutine
See https://github.com/python/asyncio/pull/293 for details.
Diffstat (limited to 'Lib')
-rw-r--r--Lib/asyncio/coroutines.py8
-rw-r--r--Lib/test/test_asyncio/test_pep492.py20
2 files changed, 27 insertions, 1 deletions
diff --git a/Lib/asyncio/coroutines.py b/Lib/asyncio/coroutines.py
index e11b21b..3a92c7d 100644
--- a/Lib/asyncio/coroutines.py
+++ b/Lib/asyncio/coroutines.py
@@ -140,7 +140,13 @@ class CoroWrapper:
if compat.PY35:
- __await__ = __iter__ # make compatible with 'await' expression
+ def __await__(self):
+ cr_await = getattr(self.gen, 'cr_await', None)
+ if cr_await is not None:
+ raise RuntimeError(
+ "Cannot await on coroutine {!r} while it's "
+ "awaiting for {!r}".format(self.gen, cr_await))
+ return self
@property
def gi_yieldfrom(self):
diff --git a/Lib/test/test_asyncio/test_pep492.py b/Lib/test/test_asyncio/test_pep492.py
index 41e1b8a..404a748 100644
--- a/Lib/test/test_asyncio/test_pep492.py
+++ b/Lib/test/test_asyncio/test_pep492.py
@@ -203,6 +203,26 @@ class CoroutineTests(BaseTest):
self.loop.run_until_complete(runner())
+ def test_double_await(self):
+ async def afunc():
+ await asyncio.sleep(0.1, loop=self.loop)
+
+ async def runner():
+ coro = afunc()
+ t = asyncio.Task(coro, loop=self.loop)
+ try:
+ await asyncio.sleep(0, loop=self.loop)
+ await coro
+ finally:
+ t.cancel()
+
+ self.loop.set_debug(True)
+ with self.assertRaisesRegex(
+ RuntimeError,
+ r'Cannot await.*test_double_await.*\bafunc\b.*while.*\bsleep\b'):
+
+ self.loop.run_until_complete(runner())
+
if __name__ == '__main__':
unittest.main()