-
-
Notifications
You must be signed in to change notification settings - Fork 719
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Mock process memory readings in test_worker.py (v2) #5878
Conversation
This reverts commit ef0e44b.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think these tests are much more readable and easier to maintain, thank you!
while not a.data.disk or len(a.data.disk) > prev_n: | ||
prev_n = len(a.data.disk) | ||
await asyncio.sleep(0) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is a bit fragile. As soon as the while loop in the memory monitor changes anything about how it awaits, e.g. another async call to evict data, this condition will break since we rely on skipping exactly one loop iteration with sleep(0)
.
I can't come up with a nicer way other than sleeping for a longer time so this is fine for me. I just wanted to raise this in case somebody else thinks of something
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Another ugly thing we can do but I think I dislike this even more is to wait for _memory_monitoring
to toggle since then we know for sure the memory_monitor
is done. I think I prefer sticking with sleep(0) and deal with a test failure/test rewrite if that ever happens
In scope
test_spill_hysteresis
flaky on ubuntu #5848Out of scope
test_scheduler.py::test_memory
test_active_memory_manager.py
, which should be carried out by adding a switch to use managed memoryrebalance()
: postponed indefinitely due to the whole function to be reimplemented on top of the Active Memory Manager