Browse Source
AsyncPubSubManager does not await for can_disconnect (#488)
pull/494/head
Andrei Neagu
5 years ago
committed by
GitHub
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with
2 additions and
2 deletions
-
socketio/asyncio_pubsub_manager.py
-
tests/asyncio/test_asyncio_pubsub_manager.py
|
|
@ -72,7 +72,7 @@ class AsyncPubSubManager(AsyncManager): |
|
|
|
async def can_disconnect(self, sid, namespace): |
|
|
|
if self.is_connected(sid, namespace): |
|
|
|
# client is in this server, so we can disconnect directly |
|
|
|
return super().can_disconnect(sid, namespace) |
|
|
|
return await super().can_disconnect(sid, namespace) |
|
|
|
else: |
|
|
|
# client is in another server, so we post request to the queue |
|
|
|
await self._publish({'method': 'disconnect', 'sid': sid, |
|
|
|
|
|
@ -118,7 +118,7 @@ class TestAsyncPubSubManager(unittest.TestCase): |
|
|
|
|
|
|
|
def test_can_disconnect(self): |
|
|
|
self.pm.connect('123', '/') |
|
|
|
self.assertTrue(_run(self.pm.can_disconnect('123', '/'))) |
|
|
|
self.assertTrue(_run(self.pm.can_disconnect('123', '/')) is True) |
|
|
|
_run(self.pm.can_disconnect('123', '/foo')) |
|
|
|
self.pm._publish.mock.assert_called_once_with( |
|
|
|
{'method': 'disconnect', 'sid': '123', 'namespace': '/foo'}) |
|
|
|