From: Yury Selivanov Date: Mon, 29 Jan 2018 03:43:46 +0000 (-0500) Subject: bpo-32650: Add an asyncgen pdb test (#5406) X-Git-Tag: v3.7.0b1~42 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=9ee1bf9ab5af8233ed8ec5c53d12a29dc1bd9c9d;p=python bpo-32650: Add an asyncgen pdb test (#5406) --- diff --git a/Lib/test/test_pdb.py b/Lib/test/test_pdb.py index 47a669f2ce..08d374ca83 100644 --- a/Lib/test/test_pdb.py +++ b/Lib/test/test_pdb.py @@ -782,6 +782,66 @@ def test_pdb_next_command_for_coroutine(): finished """ +def test_pdb_next_command_for_asyncgen(): + """Testing skip unwindng stack on yield for coroutines for "next" command + + >>> import asyncio + + >>> async def agen(): + ... yield 1 + ... await asyncio.sleep(0) + ... yield 2 + + >>> async def test_coro(): + ... async for x in agen(): + ... print(x) + + >>> async def test_main(): + ... import pdb; pdb.Pdb(nosigint=True, readrc=False).set_trace() + ... await test_coro() + + >>> def test_function(): + ... loop = asyncio.new_event_loop() + ... loop.run_until_complete(test_main()) + ... loop.close() + ... print("finished") + + >>> with PdbTestInput(['step', + ... 'step', + ... 'next', + ... 'next', + ... 'step', + ... 'next', + ... 'continue']): + ... test_function() + > (3)test_main() + -> await test_coro() + (Pdb) step + --Call-- + > (1)test_coro() + -> async def test_coro(): + (Pdb) step + > (2)test_coro() + -> async for x in agen(): + (Pdb) next + > (3)test_coro() + -> print(x) + (Pdb) next + 1 + > (2)test_coro() + -> async for x in agen(): + (Pdb) step + --Call-- + > (2)agen() + -> yield 1 + (Pdb) next + > (3)agen() + -> await asyncio.sleep(0) + (Pdb) continue + 2 + finished + """ + def test_pdb_return_command_for_generator(): """Testing no unwindng stack on yield for generators for "return" command