diff options
author | John Snow <jsnow@redhat.com> | 2022-01-10 18:28:46 -0500 |
---|---|---|
committer | John Snow <jsnow@redhat.com> | 2022-01-21 16:01:31 -0500 |
commit | 3b5bf136f5798a4ea2c66875d6337ca3d6b79434 (patch) | |
tree | f50b83a4bd78a02e59a485c81cd531a970e65f7f | |
parent | 3bc72e3aed76e0326703db81964b13f1da075cbf (diff) | |
download | qemu-3b5bf136f5798a4ea2c66875d6337ca3d6b79434.zip qemu-3b5bf136f5798a4ea2c66875d6337ca3d6b79434.tar.gz qemu-3b5bf136f5798a4ea2c66875d6337ca3d6b79434.tar.bz2 |
python/aqmp: handle asyncio.TimeoutError on execute()
This exception can be injected into any await statement. If we are
canceled via timeout, we want to clear the pending execution record on
our way out.
Signed-off-by: John Snow <jsnow@redhat.com>
Reviewed-by: Beraldo Leal <bleal@redhat.com>
Reviewed-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>
-rw-r--r-- | python/qemu/aqmp/qmp_client.py | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/python/qemu/aqmp/qmp_client.py b/python/qemu/aqmp/qmp_client.py index 8105e29..6a985ff 100644 --- a/python/qemu/aqmp/qmp_client.py +++ b/python/qemu/aqmp/qmp_client.py @@ -435,7 +435,11 @@ class QMPClient(AsyncProtocol[Message], Events): msg_id = msg['id'] self._pending[msg_id] = asyncio.Queue(maxsize=1) - await self._outgoing.put(msg) + try: + await self._outgoing.put(msg) + except: + del self._pending[msg_id] + raise return msg_id @@ -452,9 +456,9 @@ class QMPClient(AsyncProtocol[Message], Events): was lost, or some other problem. """ queue = self._pending[msg_id] - result = await queue.get() try: + result = await queue.get() if isinstance(result, ExecInterruptedError): raise result return result |