-
Notifications
You must be signed in to change notification settings - Fork 666
Description
I am using the asyncio support in Notifier which works well on reception of messages. However there is no async variant of BusABC.send(). It has a timeout which by default is set to None that may block forever according to spec. Not all interfaces seems to be using the timeout parameter and I haven't had any problem using it as-is from async tasks. But it is a potential block which may halt the async event loop if called from an async task. There are other functions in the BusABC API that has similar timeouts, like recv().
I guess the first question would be if an async variant of BusABC.send() is really needed or not. If the timeout is for all practical purposes not used and sends are immediate, then IMHO there is nothing wrong with this blocking call.
What would be a good approach for async? Make a new AsyncBus as wrapper for BusABC in the same manner as ThreadSafeBus is? I believe due to the nature of async tasks, the send() function would need to put the message on a queue and await a signal. A separate (non async) tx thread would be responsible for sending the message using the regular send() including traditional timeouts and then signal back to the sleeping async task.