Author Assaf Dayan
Recipients Assaf Dayan
Date 2019-03-14.16:59:52
SpamBayes Score -1.0
Marked as misclassified Yes
Message-id <1552582792.25.0.588312796028.issue36295@roundup.psfhosted.org>
In-reply-to
Content
In asyncio, 'await asyncio.sleep(0)' is used to relinquish control and check for finished awaitables before continuing. 
In my example, an awaitable returns but is only handled if 'await asyncio.sleep(0)' is called twice (adjacently) and only then the returned 'await' statements are handled correctly.

The attached script generates tasks which do the following: compute for 0.8 seconds; do an async op for 0.5 seconds; and compute some more for 0.2 seconds.
Before generating each new task, we relinquish control so that existing pending tasks will resume operation, if their 'await' statements returned.
We simulate a business-case in which we give precedence to already-processing tasks over new ones.

When running the attached script, Task 1 goes async at d=0.8 and should be ready by d=1.3 (asyncio.sleep(0.5)). Because Task 2 started at d=0.8 (when T1 went async) it will relinquish control at d=1.6. By relinquishing control at d=1.6, Task 1 should resume, but it doesn't, unless asyncio.sleep(0) is called once more.
If asyncio.sleep(0) is not called again (as a fix), Task 1 will only resume at d=2.4, which is after Task 3 relinquished control.
History
Date User Action Args
2019-03-14 16:59:52Assaf Dayansetrecipients: + Assaf Dayan
2019-03-14 16:59:52Assaf Dayansetmessageid: <1552582792.25.0.588312796028.issue36295@roundup.psfhosted.org>
2019-03-14 16:59:52Assaf Dayanlinkissue36295 messages
2019-03-14 16:59:52Assaf Dayancreate