mirror of
https://github.com/overleaf/overleaf.git
synced 2025-02-03 22:01:12 +00:00
Merge pull request #155 from overleaf/jpa-backport-receiveupdate-tests
[backport] 107 and 116: Improve ReceiveUpdate acceptance tests
This commit is contained in:
commit
06a8dc8ec1
2 changed files with 129 additions and 21 deletions
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue