2014-11-13 15:27:18 +00:00
|
|
|
chai = require("chai")
|
|
|
|
expect = chai.expect
|
|
|
|
chai.should()
|
|
|
|
|
|
|
|
RealTimeClient = require "./helpers/RealTimeClient"
|
|
|
|
MockWebServer = require "./helpers/MockWebServer"
|
|
|
|
FixturesManager = require "./helpers/FixturesManager"
|
|
|
|
|
2014-11-14 10:21:54 +00:00
|
|
|
async = require "async"
|
|
|
|
|
2014-11-13 15:27:18 +00:00
|
|
|
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"
|
|
|
|
project: { name: "Test Project" }
|
|
|
|
}, (error, {@user_id, @project_id}) => cb()
|
2014-11-13 15:27:18 +00:00
|
|
|
|
2014-11-21 11:48:59 +00:00
|
|
|
(cb) =>
|
|
|
|
@clientA = RealTimeClient.connect()
|
|
|
|
@clientA.on "connect", cb
|
|
|
|
|
|
|
|
(cb) =>
|
|
|
|
@clientB = RealTimeClient.connect()
|
|
|
|
|
|
|
|
@clientB.on "connect", cb
|
|
|
|
|
|
|
|
(cb) =>
|
|
|
|
@clientA.emit "joinProject", {
|
|
|
|
project_id: @project_id
|
|
|
|
}, cb
|
|
|
|
|
|
|
|
(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
|
|
|
|
doc_id: @doc_id = "mock-doc-id"
|
|
|
|
}, (error) ->
|
|
|
|
throw error if error?
|
|
|
|
setTimeout cb, 300 # Give the message a chance to reach client B.
|
|
|
|
], done
|
2014-11-13 15:27:18 +00:00
|
|
|
|
2014-11-13 16:03:37 +00:00
|
|
|
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"
|
|
|
|
}
|
|
|
|
]
|
2014-11-13 15:27:18 +00:00
|
|
|
|
|
|
|
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()
|
2014-11-13 15:27:18 +00:00
|
|
|
|
2014-11-21 11:48:59 +00:00
|
|
|
(cb) =>
|
|
|
|
@clientA = RealTimeClient.connect()
|
|
|
|
@clientA.on "connect", cb
|
|
|
|
(cb) =>
|
|
|
|
@clientA.emit "joinProject", {
|
|
|
|
project_id: @project_id
|
|
|
|
}, cb
|
|
|
|
|
|
|
|
(cb) =>
|
|
|
|
RealTimeClient.setSession({}, cb)
|
|
|
|
|
|
|
|
(cb) =>
|
|
|
|
@anonymous = RealTimeClient.connect()
|
|
|
|
@anonymous.on "connect", cb
|
|
|
|
|
|
|
|
(cb) =>
|
|
|
|
@anonymous.emit "joinProject", {
|
|
|
|
project_id: @project_id
|
|
|
|
}, cb
|
|
|
|
|
|
|
|
(cb) =>
|
|
|
|
@updates = []
|
|
|
|
@clientA.on "clientTracking.clientUpdated", (data) =>
|
|
|
|
@updates.push data
|
|
|
|
|
|
|
|
@anonymous.emit "clientTracking.updatePosition", {
|
|
|
|
row: @row = 42
|
|
|
|
column: @column = 36
|
|
|
|
doc_id: @doc_id = "mock-doc-id"
|
|
|
|
}, (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"
|
|
|
|
}
|
|
|
|
]
|