cea71f2799
This fixes the sporadic of tasks that would happen under certain circumstances. What happened was that a new worker notification would be sent to a callback while at the same time a task submission would come in and there would be a small race period where the task would insert itself into the requests cache while the callback was processing. So to work around this the whole concept of a requests cache was revamped and now the WBE executor just maintains its own local dictionary of ongoing requests and accesses it safely. During the on_wait function that is periodically called by kombu the previous expiry of work happens but now any requests that are pending are matched to any new workers that may have appeared. This avoids the race (and ensures that even if a new worker is found but a submission is in progress that the duration until that submission happens will only be until the next on_wait call happens). Related-Bug: #1431097 Change-Id: I98b0caeedc77ab2f7214847763ae1eb0433d4a78 |
||
---|---|---|
.. | ||
__init__.py | ||
test_creation.py | ||
test_dispatcher.py | ||
test_endpoint.py | ||
test_executor.py | ||
test_message_pump.py | ||
test_pipeline.py | ||
test_protocol.py | ||
test_proxy.py | ||
test_server.py | ||
test_types.py | ||
test_worker.py |