Merge pull request #155 from overleaf/jpa-backport-receiveupdate-tests

[backport] 107 and 116: Improve ReceiveUpdate acceptance tests
This commit is contained in:
Jakob Ackermann 2020-06-10 11:28:25 +02:00 committed by GitHub
commit 06a8dc8ec1
2 changed files with 129 additions and 21 deletions

View file

@ -8,7 +8,7 @@ FixturesManager = require "./helpers/FixturesManager"
settings = require "settings-sharelatex" settings = require "settings-sharelatex"
redis = require "redis-sharelatex" redis = require "redis-sharelatex"
rclient = redis.createClient(settings.redis.websessions) rclient = redis.createClient(settings.redis.documentupdater)
redisSettings = settings.redis redisSettings = settings.redis

View file

@ -10,10 +10,10 @@ async = require "async"
settings = require "settings-sharelatex" settings = require "settings-sharelatex"
redis = require "redis-sharelatex" redis = require "redis-sharelatex"
rclient = redis.createClient(settings.redis.websessions) rclient = redis.createClient(settings.redis.pubsub)
describe "receiveUpdate", -> describe "receiveUpdate", ->
before (done) -> beforeEach (done) ->
@lines = ["test", "doc", "lines"] @lines = ["test", "doc", "lines"]
@version = 42 @version = 42
@ops = ["mock", "doc", "ops"] @ops = ["mock", "doc", "ops"]
@ -52,15 +52,52 @@ describe "receiveUpdate", ->
(cb) => (cb) =>
@clientB.emit "joinDoc", @doc_id, cb @clientB.emit "joinDoc", @doc_id, cb
(cb) =>
FixturesManager.setUpProject {
privilegeLevel: "owner"
project: {name: "Test Project"}
}, (error, {user_id: @user_id_second, project_id: @project_id_second}) => cb()
(cb) =>
FixturesManager.setUpDoc @project_id_second, {@lines, @version, @ops}, (e, {doc_id: @doc_id_second}) =>
cb(e)
(cb) =>
@clientC = RealTimeClient.connect()
@clientC.on "connectionAccepted", cb
(cb) =>
@clientC.emit "joinProject", {
project_id: @project_id_second
}, cb
(cb) =>
@clientC.emit "joinDoc", @doc_id_second, cb
(cb) =>
@clientAUpdates = []
@clientA.on "otUpdateApplied", (update) => @clientAUpdates.push(update)
@clientBUpdates = []
@clientB.on "otUpdateApplied", (update) => @clientBUpdates.push(update)
@clientCUpdates = []
@clientC.on "otUpdateApplied", (update) => @clientCUpdates.push(update)
@clientAErrors = []
@clientA.on "otUpdateError", (error) => @clientAErrors.push(error)
@clientBErrors = []
@clientB.on "otUpdateError", (error) => @clientBErrors.push(error)
@clientCErrors = []
@clientC.on "otUpdateError", (error) => @clientCErrors.push(error)
cb()
], done ], done
afterEach () ->
@clientA?.disconnect()
@clientB?.disconnect()
@clientC?.disconnect()
describe "with an update from clientA", -> describe "with an update from clientA", ->
before (done) -> beforeEach (done) ->
@clientAUpdates = []
@clientA.on "otUpdateApplied", (update) => @clientAUpdates.push(update)
@clientBUpdates = []
@clientB.on "otUpdateApplied", (update) => @clientBUpdates.push(update)
@update = { @update = {
doc_id: @doc_id doc_id: @doc_id
op: op:
@ -80,21 +117,92 @@ describe "receiveUpdate", ->
@clientAUpdates.should.deep.equal [{ @clientAUpdates.should.deep.equal [{
v: @version, doc: @doc_id v: @version, doc: @doc_id
}] }]
it "should send nothing to clientC", ->
@clientCUpdates.should.deep.equal []
describe "with an update from clientC", ->
beforeEach (done) ->
@update = {
doc_id: @doc_id_second
op:
meta:
source: @clientC.publicId
v: @version
doc: @doc_id_second
op: [{i: "update from clientC", p: 50}]
}
rclient.publish "applied-ops", JSON.stringify(@update)
setTimeout done, 200 # Give clients time to get message
it "should send nothing to clientA", ->
@clientAUpdates.should.deep.equal []
it "should send nothing to clientB", ->
@clientBUpdates.should.deep.equal []
it "should send an ack to clientC", ->
@clientCUpdates.should.deep.equal [{
v: @version, doc: @doc_id_second
}]
describe "with an update from a remote client for project 1", ->
beforeEach (done) ->
@update = {
doc_id: @doc_id
op:
meta:
source: 'this-is-a-remote-client-id'
v: @version
doc: @doc_id
op: [{i: "foo", p: 50}]
}
rclient.publish "applied-ops", JSON.stringify(@update)
setTimeout done, 200 # Give clients time to get message
it "should send the full op to clientA", ->
@clientAUpdates.should.deep.equal [@update.op]
describe "with an error", -> it "should send the full op to clientB", ->
before (done) -> @clientBUpdates.should.deep.equal [@update.op]
@clientAErrors = []
@clientA.on "otUpdateError", (error) => @clientAErrors.push(error) it "should send nothing to clientC", ->
@clientBErrors = [] @clientCUpdates.should.deep.equal []
@clientB.on "otUpdateError", (error) => @clientBErrors.push(error)
describe "with an error for the first project", ->
beforeEach (done) ->
rclient.publish "applied-ops", JSON.stringify({doc_id: @doc_id, error: @error = "something went wrong"}) rclient.publish "applied-ops", JSON.stringify({doc_id: @doc_id, error: @error = "something went wrong"})
setTimeout done, 200 # Give clients time to get message setTimeout done, 200 # Give clients time to get message
it "should send the error to both clients", -> it "should send the error to the clients in the first project", ->
@clientAErrors.should.deep.equal [@error] @clientAErrors.should.deep.equal [@error]
@clientBErrors.should.deep.equal [@error] @clientBErrors.should.deep.equal [@error]
it "should disconnect the clients", -> it "should not send any errors to the client in the second project", ->
@clientCErrors.should.deep.equal []
it "should disconnect the clients of the first project", ->
@clientA.socket.connected.should.equal false @clientA.socket.connected.should.equal false
@clientB.socket.connected.should.equal false @clientB.socket.connected.should.equal false
it "should not disconnect the client in the second project", ->
@clientC.socket.connected.should.equal true
describe "with an error for the second project", ->
beforeEach (done) ->
rclient.publish "applied-ops", JSON.stringify({doc_id: @doc_id_second, error: @error = "something went wrong"})
setTimeout done, 200 # Give clients time to get message
it "should not send any errors to the clients in the first project", ->
@clientAErrors.should.deep.equal []
@clientBErrors.should.deep.equal []
it "should send the error to the client in the second project", ->
@clientCErrors.should.deep.equal [@error]
it "should not disconnect the clients of the first project", ->
@clientA.socket.connected.should.equal true
@clientB.socket.connected.should.equal true
it "should disconnect the client in the second project", ->
@clientC.socket.connected.should.equal false