diff --git a/lib/agent.js b/lib/agent.js index 5c74dab2f..f11670a0a 100644 --- a/lib/agent.js +++ b/lib/agent.js @@ -769,11 +769,7 @@ Agent.prototype._src = function() { Agent.prototype._broadcastPresence = function(presence, callback) { var agent = this; var backend = this.backend; - var requests = this.presenceRequests[presence.ch] || (this.presenceRequests[presence.ch] = {}); - var previousRequest = requests[presence.id]; - if (!previousRequest || previousRequest.pv < presence.pv) { - this.presenceRequests[presence.ch][presence.id] = presence; - } + var presenceRequests = this.presenceRequests; var context = { presence: presence, collection: presence.c @@ -781,6 +777,11 @@ Agent.prototype._broadcastPresence = function(presence, callback) { var start = Date.now(); backend.trigger(backend.MIDDLEWARE_ACTIONS.receivePresence, this, context, function(error) { if (error) return callback(error); + var requests = presenceRequests[presence.ch] || (presenceRequests[presence.ch] = {}); + var previousRequest = requests[presence.id]; + if (!previousRequest || previousRequest.pv < presence.pv) { + presenceRequests[presence.ch][presence.id] = presence; + } backend.transformPresenceToLatestVersion(agent, presence, function(error, presence) { if (error) return callback(error); var channel = agent._getPresenceChannel(presence.ch); diff --git a/test/client/presence/presence.js b/test/client/presence/presence.js index 40d4f4847..2f6a52a37 100644 --- a/test/client/presence/presence.js +++ b/test/client/presence/presence.js @@ -659,6 +659,7 @@ describe('Presence', function() { function(next) { presence2.on('receive', function(id, value) { expect(value).to.eql({index: 6}); + expect(connection1.agent.presenceRequests['test-channel']['presence-1'].p).to.eql({index: 6}); next(); }); localPresence1.submit({index: 5}, errorHandler(done)); @@ -681,6 +682,7 @@ describe('Presence', function() { }); localPresence1.submit({index: 5}, function(error) { expect(error.message).to.contain('bad!'); + expect(connection1.agent.presenceRequests['test-channel']).not.to.be.ok; next(); }); }