2023-08-22 11:15:46 -04:00
|
|
|
# test that basic scheduling of tasks, and asyncio.sleep_ms, does not use the heap
|
2019-11-13 05:08:22 -05:00
|
|
|
|
|
|
|
import micropython
|
|
|
|
|
|
|
|
# strict stackless builds can't call functions without allocating a frame on the heap
|
|
|
|
try:
|
|
|
|
f = lambda: 0
|
|
|
|
micropython.heap_lock()
|
|
|
|
f()
|
|
|
|
micropython.heap_unlock()
|
|
|
|
except RuntimeError:
|
|
|
|
print("SKIP")
|
|
|
|
raise SystemExit
|
|
|
|
|
|
|
|
try:
|
2023-08-22 11:15:46 -04:00
|
|
|
import asyncio
|
2019-11-13 05:08:22 -05:00
|
|
|
except ImportError:
|
2023-08-22 11:15:46 -04:00
|
|
|
print("SKIP")
|
|
|
|
raise SystemExit
|
2019-11-13 05:08:22 -05:00
|
|
|
|
|
|
|
|
|
|
|
async def task(id, n, t):
|
|
|
|
for i in range(n):
|
|
|
|
print(id, i)
|
|
|
|
await asyncio.sleep_ms(t)
|
|
|
|
|
|
|
|
|
|
|
|
async def main():
|
2022-05-03 08:39:58 -04:00
|
|
|
t1 = asyncio.create_task(task(1, 4, 100))
|
|
|
|
t2 = asyncio.create_task(task(2, 2, 250))
|
2019-11-13 05:08:22 -05:00
|
|
|
|
|
|
|
micropython.heap_lock()
|
|
|
|
|
|
|
|
print("start")
|
2022-05-03 08:39:58 -04:00
|
|
|
await asyncio.sleep_ms(5)
|
2019-11-13 05:08:22 -05:00
|
|
|
print("sleep")
|
2022-05-03 08:39:58 -04:00
|
|
|
await asyncio.sleep_ms(350)
|
2019-11-13 05:08:22 -05:00
|
|
|
print("finish")
|
|
|
|
|
|
|
|
micropython.heap_unlock()
|
|
|
|
|
|
|
|
|
|
|
|
asyncio.run(main())
|