Title: Occasional incorrect chaining of CancelledError when calling 'cancel' on result of 'asyncio.gather' · Issue #97907 · python/cpython · GitHub
Open Graph Title: Occasional incorrect chaining of CancelledError when calling 'cancel' on result of 'asyncio.gather' · Issue #97907 · python/cpython
X Title: Occasional incorrect chaining of CancelledError when calling 'cancel' on result of 'asyncio.gather' · Issue #97907 · python/cpython
Description: import asyncio async def f1(): await asyncio.sleep(1) async def f2(): return 42 async def main(): # case 1 gfut = asyncio.gather(f1(), f2(), return_exceptions=True) # case 2 #gfut = asyncio.gather(f2(), f1(), return_exceptions=True) awai...
Open Graph Description: import asyncio async def f1(): await asyncio.sleep(1) async def f2(): return 42 async def main(): # case 1 gfut = asyncio.gather(f1(), f2(), return_exceptions=True) # case 2 #gfut = asyncio.gather(...
X Description: import asyncio async def f1(): await asyncio.sleep(1) async def f2(): return 42 async def main(): # case 1 gfut = asyncio.gather(f1(), f2(), return_exceptions=True) # case 2 #gfut = asyncio.gather(...
Opengraph URL: https://github.com/python/cpython/issues/97907
X: @github
Domain: github.com
{"@context":"https://schema.org","@type":"DiscussionForumPosting","headline":"Occasional incorrect chaining of CancelledError when calling 'cancel' on result of 'asyncio.gather'","articleBody":"```python\r\nimport asyncio\r\n\r\nasync def f1():\r\n await asyncio.sleep(1)\r\n\r\nasync def f2():\r\n return 42\r\n\r\nasync def main():\r\n # case 1\r\n gfut = asyncio.gather(f1(), f2(), return_exceptions=True)\r\n # case 2\r\n #gfut = asyncio.gather(f2(), f1(), return_exceptions=True)\r\n await asyncio.sleep(0.1)\r\n gfut.cancel(\"my message\")\r\n await gfut\r\n\r\nasyncio.run(main())\r\n\r\n# case 1\r\n\r\n#Traceback (most recent call last):\r\n# File \"/Users/vladima/Sources/gather.py\", line 14, in main\r\n# print(await gfut)\r\n#asyncio.exceptions.CancelledError\r\n#\r\n#During handling of the above exception, another exception occurred:\r\n#\r\n#Traceback (most recent call last):\r\n# File \"/Users/vladima/Sources/gather.py\", line 16, in \u003cmodule\u003e\r\n# asyncio.run(main())\r\n# File \"/Library/Frameworks/Python.framework/Versions/3.10/lib/python3.10/asyncio/runners.py\", line 44, in run\r\n# return loop.run_until_complete(main)\r\n# File \"/Library/Frameworks/Python.framework/Versions/3.10/lib/python3.10/asyncio/base_events.py\", line 646, in run_until_complete\r\n# return future.result()\r\n#asyncio.exceptions.CancelledError\r\n\r\n# case 2\r\n#Traceback (most recent call last):\r\n# File \"/Library/Frameworks/Python.framework/Versions/3.10/lib/python3.10/asyncio/tasks.py\", line 605, in sleep\r\n# return await future\r\n#asyncio.exceptions.CancelledError: my message\r\n\r\n#During handling of the above exception, another exception occurred:\r\n\r\n#Traceback (most recent call last):\r\n# File \"/Users/vladima/Sources/gather.py\", line 14, in main\r\n# print(await gfut)\r\n#asyncio.exceptions.CancelledError\r\n#\r\n#During handling of the above exception, another exception occurred:\r\n#\r\n#Traceback (most recent call last):\r\n# File \"/Users/vladima/Sources/gather.py\", line 16, in \u003cmodule\u003e\r\n# asyncio.run(main())\r\n# File \"/Library/Frameworks/Python.framework/Versions/3.10/lib/python3.10/asyncio/runners.py\", line 44, in run\r\n# return loop.run_until_complete(main)\r\n# File \"/Library/Frameworks/Python.framework/Versions/3.10/lib/python3.10/asyncio/base_events.py\", line 646, in run_until_complete\r\n# return future.result()\r\n#asyncio.exceptions.CancelledError\r\n```\r\n\r\nCurrently traceback and description parts of `CancelledError` depend upon the order of arguments that were passed into `asyncio.gather`. The reason I believe is [this](https://github.com/python/cpython/blob/main/Lib/asyncio/tasks.py#L812): here `fut` would be bound to the last item in `children` which might or might not correspond to the cancelled task and instead it should probably be one of tasks that were actually cancelled (which is still not ideal since there might be many of them but I guess with `gather` it is as good as it can be).\n\n\u003c!-- gh-linked-prs --\u003e\n### Linked PRs\n* gh-133243\n\u003c!-- /gh-linked-prs --\u003e\n","author":{"url":"https://github.com/vladima","@type":"Person","name":"vladima"},"datePublished":"2022-10-05T14:53:55.000Z","interactionStatistic":{"@type":"InteractionCounter","interactionType":"https://schema.org/CommentAction","userInteractionCount":5},"url":"https://github.com/97907/cpython/issues/97907"}
| route-pattern | /_view_fragments/issues/show/:user_id/:repository/:id/issue_layout(.:format) |
| route-controller | voltron_issues_fragments |
| route-action | issue_layout |
| fetch-nonce | v2:9bc7bc22-64c6-c751-9678-d7e0418b81ad |
| current-catalog-service-hash | 81bb79d38c15960b92d99bca9288a9108c7a47b18f2423d0f6438c5b7bcd2114 |
| request-id | 857A:20D38B:AF7359:F75D6C:696A570C |
| html-safe-nonce | 092f022d3fe8d30c5988c46372f9c37c2c9226506704558ca64963674e89515a |
| visitor-payload | eyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiI4NTdBOjIwRDM4QjpBRjczNTk6Rjc1RDZDOjY5NkE1NzBDIiwidmlzaXRvcl9pZCI6Ijc5OTIyNTA5NDc3NjY3MzY2NTIiLCJyZWdpb25fZWRnZSI6ImlhZCIsInJlZ2lvbl9yZW5kZXIiOiJpYWQifQ== |
| visitor-hmac | 8eae9577d7d1e85d12e8c4c72af16f942e229bbd5ec6e2b65714397217ae3abc |
| hovercard-subject-tag | issue:1397933665 |
| github-keyboard-shortcuts | repository,issues,copilot |
| google-site-verification | Apib7-x98H0j5cPqHWwSMm6dNU4GmODRoqxLiDzdx9I |
| octolytics-url | https://collector.github.com/github/collect |
| analytics-location | / |
| fb:app_id | 1401488693436528 |
| apple-itunes-app | app-id=1477376905, app-argument=https://github.com/_view_fragments/issues/show/python/cpython/97907/issue_layout |
| twitter:image | https://opengraph.githubassets.com/567f78ad57a2b8ae26f03c30ba16885b05ca99bcb31764d32c9680317e81c659/python/cpython/issues/97907 |
| twitter:card | summary_large_image |
| og:image | https://opengraph.githubassets.com/567f78ad57a2b8ae26f03c30ba16885b05ca99bcb31764d32c9680317e81c659/python/cpython/issues/97907 |
| og:image:alt | import asyncio async def f1(): await asyncio.sleep(1) async def f2(): return 42 async def main(): # case 1 gfut = asyncio.gather(f1(), f2(), return_exceptions=True) # case 2 #gfut = asyncio.gather(... |
| og:image:width | 1200 |
| og:image:height | 600 |
| og:site_name | GitHub |
| og:type | object |
| og:author:username | vladima |
| hostname | github.com |
| expected-hostname | github.com |
| None | 3f871c8e07f0ae1886fa8dac284166d28b09ad5bada6476fc10b674e489788ef |
| turbo-cache-control | no-preview |
| go-import | github.com/python/cpython git https://github.com/python/cpython.git |
| octolytics-dimension-user_id | 1525981 |
| octolytics-dimension-user_login | python |
| octolytics-dimension-repository_id | 81598961 |
| octolytics-dimension-repository_nwo | python/cpython |
| octolytics-dimension-repository_public | true |
| octolytics-dimension-repository_is_fork | false |
| octolytics-dimension-repository_network_root_id | 81598961 |
| octolytics-dimension-repository_network_root_nwo | python/cpython |
| turbo-body-classes | logged-out env-production page-responsive |
| disable-turbo | false |
| browser-stats-url | https://api.github.com/_private/browser/stats |
| browser-errors-url | https://api.github.com/_private/browser/errors |
| release | 63c426b30d262aba269ef14c40e3c817b384cd61 |
| ui-target | full |
| theme-color | #1e2327 |
| color-scheme | light dark |
Links:
Viewport: width=device-width