Browse Source

Added "ignore_queue" option to bypass message queue in emits

pull/62/merge
Miguel Grinberg 8 years ago
parent
commit
3eac53261b
  1. 2
      socketio/base_manager.py
  2. 6
      socketio/pubsub_manager.py
  3. 24
      socketio/server.py
  4. 8
      tests/test_pubsub_manager.py

2
socketio/base_manager.py

@ -113,7 +113,7 @@ class BaseManager(object):
return r return r
def emit(self, event, data, namespace, room=None, skip_sid=None, def emit(self, event, data, namespace, room=None, skip_sid=None,
callback=None): callback=None, **kwargs):
"""Emit a message to a single client, a room, or all the clients """Emit a message to a single client, a room, or all the clients
connected to the namespace.""" connected to the namespace."""
if namespace not in self.rooms or room not in self.rooms[namespace]: if namespace not in self.rooms or room not in self.rooms[namespace]:

6
socketio/pubsub_manager.py

@ -37,7 +37,7 @@ class PubSubManager(BaseManager):
self.server.logger.info(self.name + ' backend initialized.') self.server.logger.info(self.name + ' backend initialized.')
def emit(self, event, data, namespace=None, room=None, skip_sid=None, def emit(self, event, data, namespace=None, room=None, skip_sid=None,
callback=None): callback=None, **kwargs):
"""Emit a message to a single client, a room, or all the clients """Emit a message to a single client, a room, or all the clients
connected to the namespace. connected to the namespace.
@ -46,6 +46,10 @@ class PubSubManager(BaseManager):
The parameters are the same as in :meth:`.Server.emit`. The parameters are the same as in :meth:`.Server.emit`.
""" """
if kwargs.get('ignore_queue'):
return super(PubSubManager, self).emit(
event, data, namespace=namespace, room=room, skip_sid=skip_sid,
callback=callback)
namespace = namespace or '/' namespace = namespace or '/'
if callback is not None: if callback is not None:
if self.server is None: if self.server is None:

24
socketio/server.py

@ -177,7 +177,7 @@ class Server(object):
namespace_handler namespace_handler
def emit(self, event, data=None, room=None, skip_sid=None, namespace=None, def emit(self, event, data=None, room=None, skip_sid=None, namespace=None,
callback=None): callback=None, **kwargs):
"""Emit a custom event to one or more connected clients. """Emit a custom event to one or more connected clients.
:param event: The event name. It can be any string. The event names :param event: The event name. It can be any string. The event names
@ -202,14 +202,22 @@ class Server(object):
that will be passed to the function are those provided that will be passed to the function are those provided
by the client. Callback functions can only be used by the client. Callback functions can only be used
when addressing an individual client. when addressing an individual client.
:param ignore_queue: Only used when a message queue is configured. If
set to ``True``, the event is emitted to the
clients directly, without going through the queue.
This is more efficient, but only works when a
single server process is used. It is recommended
to always leave this parameter with its default
value of ``False``.
""" """
namespace = namespace or '/' namespace = namespace or '/'
self.logger.info('emitting event "%s" to %s [%s]', event, self.logger.info('emitting event "%s" to %s [%s]', event,
room or 'all', namespace) room or 'all', namespace)
self.manager.emit(event, data, namespace, room, skip_sid, callback) self.manager.emit(event, data, namespace, room, skip_sid, callback,
**kwargs)
def send(self, data, room=None, skip_sid=None, namespace=None, def send(self, data, room=None, skip_sid=None, namespace=None,
callback=None): callback=None, **kwargs):
"""Send a message to one or more connected clients. """Send a message to one or more connected clients.
This function emits an event with the name ``'message'``. Use This function emits an event with the name ``'message'``. Use
@ -234,8 +242,16 @@ class Server(object):
that will be passed to the function are those provided that will be passed to the function are those provided
by the client. Callback functions can only be used by the client. Callback functions can only be used
when addressing an individual client. when addressing an individual client.
:param ignore_queue: Only used when a message queue is configured. If
set to ``True``, the event is emitted to the
clients directly, without going through the queue.
This is more efficient, but only works when a
single server process is used. It is recommended
to always leave this parameter with its default
value of ``False``.
""" """
self.emit('message', data, room, skip_sid, namespace, callback) self.emit('message', data, room, skip_sid, namespace, callback,
**kwargs)
def enter_room(self, sid, room, namespace=None): def enter_room(self, sid, room, namespace=None):
"""Enter a room. """Enter a room.

8
tests/test_pubsub_manager.py

@ -85,6 +85,14 @@ class TestBaseManager(unittest.TestCase):
self.assertRaises(ValueError, self.pm.emit, 'foo', 'bar', self.assertRaises(ValueError, self.pm.emit, 'foo', 'bar',
callback='cb') callback='cb')
def test_emit_with_ignore_queue(self):
self.pm.connect('123', '/')
self.pm.emit('foo', 'bar', room='123', namespace='/',
ignore_queue=True)
self.pm._publish.assert_not_called()
self.pm.server._emit_internal.assert_called_once_with('123', 'foo',
'bar', '/', None)
def test_close_room(self): def test_close_room(self):
self.pm.close_room('foo') self.pm.close_room('foo')
self.pm._publish.assert_called_once_with( self.pm._publish.assert_called_once_with(

Loading…
Cancel
Save