2019-11-13 05:08:22 -05:00
|
|
|
# Test fairness of cancelling a task
|
|
|
|
# That tasks which keeps being cancelled by multiple other tasks gets a chance to run
|
|
|
|
|
|
|
|
try:
|
2023-06-08 02:01:38 -04:00
|
|
|
import asyncio
|
2019-11-13 05:08:22 -05:00
|
|
|
except ImportError:
|
2023-06-08 02:01:38 -04:00
|
|
|
print("SKIP")
|
|
|
|
raise SystemExit
|
2019-11-13 05:08:22 -05:00
|
|
|
|
|
|
|
|
|
|
|
async def task_a():
|
|
|
|
try:
|
|
|
|
while True:
|
|
|
|
print("sleep a")
|
|
|
|
await asyncio.sleep(0)
|
|
|
|
except asyncio.CancelledError:
|
|
|
|
print("cancelled a")
|
|
|
|
|
|
|
|
|
|
|
|
async def task_b(id, other):
|
|
|
|
while other.cancel():
|
|
|
|
print("sleep b", id)
|
|
|
|
await asyncio.sleep(0)
|
|
|
|
print("done b", id)
|
|
|
|
|
|
|
|
|
|
|
|
async def main():
|
|
|
|
t = asyncio.create_task(task_a())
|
|
|
|
for i in range(3):
|
|
|
|
asyncio.create_task(task_b(i, t))
|
|
|
|
await t
|
|
|
|
|
|
|
|
|
|
|
|
asyncio.run(main())
|