diff options
| author | Serhiy Storchaka <storchaka@gmail.com> | 2016-11-06 18:47:03 +0200 | 
|---|---|---|
| committer | Serhiy Storchaka <storchaka@gmail.com> | 2016-11-06 18:47:03 +0200 | 
| commit | 60e49aa7560ca70bc5de461abc68eb72d8739e17 (patch) | |
| tree | cecbf64f1c2c52048c04d337132af485aeffd87a /Lib/test/test_asyncgen.py | |
| parent | f66f03bd358c3c481292f2624b8c947f4f77c370 (diff) | |
| parent | 24411f8a8daace4ebf8abd41091b681160b4fb89 (diff) | |
| download | cpython-git-60e49aa7560ca70bc5de461abc68eb72d8739e17.tar.gz | |
Issue #23996: Added _PyGen_SetStopIterationValue for safe raising
StopIteration with value. More safely handle non-normalized exceptions
in -_PyGen_FetchStopIterationValue.
Diffstat (limited to 'Lib/test/test_asyncgen.py')
| -rw-r--r-- | Lib/test/test_asyncgen.py | 79 | 
1 files changed, 79 insertions, 0 deletions
| diff --git a/Lib/test/test_asyncgen.py b/Lib/test/test_asyncgen.py index c24fbea5b0..68d202956f 100644 --- a/Lib/test/test_asyncgen.py +++ b/Lib/test/test_asyncgen.py @@ -450,6 +450,48 @@ class AsyncGenAsyncioTest(unittest.TestCase):          self.loop.run_until_complete(run()) +    def test_async_gen_asyncio_anext_tuple(self): +        async def foo(): +            try: +                yield (1,) +            except ZeroDivisionError: +                yield (2,) + +        async def run(): +            it = foo().__aiter__() + +            self.assertEqual(await it.__anext__(), (1,)) +            with self.assertRaises(StopIteration) as cm: +                it.__anext__().throw(ZeroDivisionError) +            self.assertEqual(cm.exception.args[0], (2,)) +            with self.assertRaises(StopAsyncIteration): +                await it.__anext__() + +        self.loop.run_until_complete(run()) + +    def test_async_gen_asyncio_anext_stopiteration(self): +        async def foo(): +            try: +                yield StopIteration(1) +            except ZeroDivisionError: +                yield StopIteration(3) + +        async def run(): +            it = foo().__aiter__() + +            v = await it.__anext__() +            self.assertIsInstance(v, StopIteration) +            self.assertEqual(v.value, 1) +            with self.assertRaises(StopIteration) as cm: +                it.__anext__().throw(ZeroDivisionError) +            v = cm.exception.args[0] +            self.assertIsInstance(v, StopIteration) +            self.assertEqual(v.value, 3) +            with self.assertRaises(StopAsyncIteration): +                await it.__anext__() + +        self.loop.run_until_complete(run()) +      def test_async_gen_asyncio_aclose_06(self):          async def foo():              try: @@ -759,6 +801,43 @@ class AsyncGenAsyncioTest(unittest.TestCase):              self.loop.run_until_complete(run())          self.assertEqual(DONE, 1) +    def test_async_gen_asyncio_athrow_tuple(self): +        async def gen(): +            try: +                yield 1 +            except ZeroDivisionError: +                yield (2,) + +        async def run(): +            g = gen() +            v = await g.asend(None) +            self.assertEqual(v, 1) +            v = await g.athrow(ZeroDivisionError) +            self.assertEqual(v, (2,)) +            with self.assertRaises(StopAsyncIteration): +                await g.asend(None) + +        self.loop.run_until_complete(run()) + +    def test_async_gen_asyncio_athrow_stopiteration(self): +        async def gen(): +            try: +                yield 1 +            except ZeroDivisionError: +                yield StopIteration(2) + +        async def run(): +            g = gen() +            v = await g.asend(None) +            self.assertEqual(v, 1) +            v = await g.athrow(ZeroDivisionError) +            self.assertIsInstance(v, StopIteration) +            self.assertEqual(v.value, 2) +            with self.assertRaises(StopAsyncIteration): +                await g.asend(None) + +        self.loop.run_until_complete(run()) +      def test_async_gen_asyncio_shutdown_01(self):          finalized = 0 | 
