2019-11-13 21:08:22 +11:00
|
|
|
# Test fairness of cancelling a task
|
|
|
|
# That tasks which continuously cancel each other don't take over the scheduler
|
|
|
|
|
|
|
|
try:
|
2023-08-22 11:15:46 -04:00
|
|
|
import asyncio
|
2019-11-13 21:08:22 +11:00
|
|
|
except ImportError:
|
2023-08-22 11:15:46 -04:00
|
|
|
print("SKIP")
|
|
|
|
raise SystemExit
|
2019-11-13 21:08:22 +11:00
|
|
|
|
|
|
|
|
|
|
|
async def task(id, other):
|
|
|
|
for i in range(3):
|
|
|
|
try:
|
|
|
|
print("start", id)
|
|
|
|
await asyncio.sleep(0)
|
|
|
|
print("done", id)
|
|
|
|
except asyncio.CancelledError as er:
|
|
|
|
print("cancelled", id)
|
|
|
|
if other is not None:
|
|
|
|
print(id, "cancels", other)
|
|
|
|
tasks[other].cancel()
|
|
|
|
|
|
|
|
|
|
|
|
async def main():
|
|
|
|
global tasks
|
|
|
|
tasks = [
|
|
|
|
asyncio.create_task(task(0, 1)),
|
|
|
|
asyncio.create_task(task(1, 0)),
|
|
|
|
asyncio.create_task(task(2, None)),
|
|
|
|
]
|
|
|
|
await tasks[2]
|
|
|
|
|
|
|
|
|
|
|
|
asyncio.run(main())
|