From 11e93049c6a3e0153e9ecbdbbf17fbbf5bfbb137 Mon Sep 17 00:00:00 2001 From: Diamond Lewis Date: Wed, 10 Jul 2019 10:14:55 -0500 Subject: [PATCH] Handle LiveQuery create event with fields (#5790) Close: https://github.com/parse-community/parse-server/issues/5764 Fix logic handling null original object --- spec/ParseLiveQueryServer.spec.js | 56 +++++++++++++++++++++++++++++++ src/LiveQuery/Client.js | 2 +- 2 files changed, 57 insertions(+), 1 deletion(-) diff --git a/spec/ParseLiveQueryServer.spec.js b/spec/ParseLiveQueryServer.spec.js index f5b5469a23..3c4a2eec35 100644 --- a/spec/ParseLiveQueryServer.spec.js +++ b/spec/ParseLiveQueryServer.spec.js @@ -989,6 +989,62 @@ describe('ParseLiveQueryServer', function() { }, jasmine.ASYNC_TEST_WAIT_TIME); }); + it('can handle create command with fields', function(done) { + jasmine.restoreLibrary('../lib/LiveQuery/Client', 'Client'); + const Client = require('../lib/LiveQuery/Client').Client; + const parseLiveQueryServer = new ParseLiveQueryServer({}); + // Make mock request message + const message = generateMockMessage(); + + const clientId = 1; + const parseWebSocket = { + clientId, + send: jasmine.createSpy('send'), + }; + const client = new Client(clientId, parseWebSocket); + spyOn(client, 'pushCreate').and.callThrough(); + parseLiveQueryServer.clients.set(clientId, client); + + // Add mock subscription + const requestId = 2; + const query = { + className: testClassName, + where: { + key: 'value', + }, + fields: ['test'], + }; + addMockSubscription( + parseLiveQueryServer, + clientId, + requestId, + parseWebSocket, + query + ); + // Mock _matchesSubscription to return matching + parseLiveQueryServer._matchesSubscription = function(parseObject) { + if (!parseObject) { + return false; + } + return true; + }; + parseLiveQueryServer._matchesACL = function() { + return Promise.resolve(true); + }; + + parseLiveQueryServer._onAfterSave(message); + + // Make sure we send create command to client + setTimeout(function() { + expect(client.pushCreate).toHaveBeenCalled(); + const args = parseWebSocket.send.calls.mostRecent().args; + const toSend = JSON.parse(args[0]); + expect(toSend.object).toBeDefined(); + expect(toSend.original).toBeUndefined(); + done(); + }, jasmine.ASYNC_TEST_WAIT_TIME); + }); + it('can match subscription for null or undefined parse object', function() { const parseLiveQueryServer = new ParseLiveQueryServer({}); // Make mock subscription diff --git a/src/LiveQuery/Client.js b/src/LiveQuery/Client.js index c6ed8e4aa9..ffda8e4296 100644 --- a/src/LiveQuery/Client.js +++ b/src/LiveQuery/Client.js @@ -96,7 +96,7 @@ class Client { fields = this.subscriptionInfos.get(subscriptionId).fields; } response['object'] = this._toJSONWithFields(parseObjectJSON, fields); - if (typeof parseOriginalObjectJSON !== 'undefined') { + if (parseOriginalObjectJSON) { response['original'] = this._toJSONWithFields( parseOriginalObjectJSON, fields