overleaf/services/real-time/test/acceptance/coffee/ClientTrackingTests.coffee

147 lines
3.6 KiB
CoffeeScript
Raw Normal View History

chai = require("chai")
expect = chai.expect
chai.should()
RealTimeClient = require "./helpers/RealTimeClient"
MockWebServer = require "./helpers/MockWebServer"
FixturesManager = require "./helpers/FixturesManager"
async = require "async"
describe "clientTracking", ->
describe "when a client updates its cursor location", ->
before (done) ->
2014-11-21 11:48:59 +00:00
async.series [
(cb) =>
FixturesManager.setUpProject {
privilegeLevel: "owner"
2016-12-08 11:12:07 +00:00
project: { name: "Test Project" }
2014-11-21 11:48:59 +00:00
}, (error, {@user_id, @project_id}) => cb()
2016-12-08 11:12:07 +00:00
(cb) =>
FixturesManager.setUpDoc @project_id, {@lines, @version, @ops}, (e, {@doc_id}) =>
cb(e)
2014-11-21 11:48:59 +00:00
(cb) =>
@clientA = RealTimeClient.connect()
2016-12-08 11:12:07 +00:00
@clientA.on "connectionAccepted", cb
2014-11-21 11:48:59 +00:00
(cb) =>
@clientB = RealTimeClient.connect()
2016-12-08 11:12:07 +00:00
@clientB.on "connectionAccepted", cb
2014-11-21 11:48:59 +00:00
(cb) =>
@clientA.emit "joinProject", {
project_id: @project_id
}, cb
2016-12-08 11:12:07 +00:00
(cb) =>
@clientA.emit "joinDoc", @doc_id, cb
2014-11-21 11:48:59 +00:00
(cb) =>
@clientB.emit "joinProject", {
project_id: @project_id
}, cb
(cb) =>
@updates = []
@clientB.on "clientTracking.clientUpdated", (data) =>
@updates.push data
@clientA.emit "clientTracking.updatePosition", {
row: @row = 42
column: @column = 36
2016-12-08 11:12:07 +00:00
doc_id: @doc_id
2014-11-21 11:48:59 +00:00
}, (error) ->
throw error if error?
setTimeout cb, 300 # Give the message a chance to reach client B.
], done
it "should tell other clients about the update", ->
@updates.should.deep.equal [
{
row: @row
column: @column
doc_id: @doc_id
id: @clientA.socket.sessionid
user_id: @user_id
name: "Joe Bloggs"
}
]
it "should record the update in getConnectedUsers", (done) ->
@clientB.emit "clientTracking.getConnectedUsers", (error, users) =>
for user in users
if user.client_id == @clientA.socket.sessionid
expect(user.cursorData).to.deep.equal({
row: @row
column: @column
doc_id: @doc_id
})
return done()
throw new Error("user was never found")
2014-11-21 11:48:59 +00:00
describe "when an anonymous client updates its cursor location", ->
before (done) ->
async.series [
(cb) =>
FixturesManager.setUpProject {
privilegeLevel: "owner"
project: { name: "Test Project" }
publicAccess: "readAndWrite"
}, (error, {@user_id, @project_id}) => cb()
2016-12-08 11:12:07 +00:00
(cb) =>
FixturesManager.setUpDoc @project_id, {@lines, @version, @ops}, (e, {@doc_id}) =>
cb(e)
2014-11-21 11:48:59 +00:00
(cb) =>
@clientA = RealTimeClient.connect()
2016-12-08 11:12:07 +00:00
@clientA.on "connectionAccepted", cb
2014-11-21 11:48:59 +00:00
(cb) =>
@clientA.emit "joinProject", {
project_id: @project_id
}, cb
(cb) =>
RealTimeClient.setSession({}, cb)
(cb) =>
@anonymous = RealTimeClient.connect()
2016-12-08 11:12:07 +00:00
@anonymous.on "connectionAccepted", cb
2014-11-21 11:48:59 +00:00
(cb) =>
@anonymous.emit "joinProject", {
project_id: @project_id
}, cb
2016-12-08 11:12:07 +00:00
(cb) =>
@anonymous.emit "joinDoc", @doc_id, cb
2014-11-21 11:48:59 +00:00
(cb) =>
@updates = []
@clientA.on "clientTracking.clientUpdated", (data) =>
@updates.push data
@anonymous.emit "clientTracking.updatePosition", {
row: @row = 42
column: @column = 36
2016-12-08 11:12:07 +00:00
doc_id: @doc_id
2014-11-21 11:48:59 +00:00
}, (error) ->
throw error if error?
setTimeout cb, 300 # Give the message a chance to reach client B.
], done
it "should tell other clients about the update", ->
@updates.should.deep.equal [
{
row: @row
column: @column
doc_id: @doc_id
id: @anonymous.socket.sessionid
user_id: "anonymous-user"
name: "Anonymous"
}
]