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

87 lines
2.6 KiB
CoffeeScript
Raw Normal View History

2014-11-13 06:54:10 -05:00
chai = require("chai")
expect = chai.expect
chai.should()
2019-07-26 03:07:49 -04:00
sinon = require("sinon")
2014-11-13 06:54:10 -05:00
RealTimeClient = require "./helpers/RealTimeClient"
MockDocUpdaterServer = require "./helpers/MockDocUpdaterServer"
FixturesManager = require "./helpers/FixturesManager"
2019-07-26 03:07:49 -04:00
logger = require("logger-sharelatex")
2014-11-13 06:54:10 -05:00
async = require "async"
2014-11-13 06:54:10 -05:00
describe "leaveDoc", ->
before ->
@lines = ["test", "doc", "lines"]
@version = 42
@ops = ["mock", "doc", "ops"]
2019-07-26 03:07:49 -04:00
sinon.spy(logger, "error")
sinon.spy(logger, "warn")
sinon.spy(logger, "log")
@other_doc_id = FixturesManager.getRandomId()
2019-07-26 03:07:49 -04:00
after ->
logger.error.restore() # remove the spy
logger.warn.restore()
logger.log.restore()
2014-11-13 06:54:10 -05:00
describe "when joined to a doc", ->
2019-07-26 03:07:49 -04:00
beforeEach (done) ->
async.series [
(cb) =>
FixturesManager.setUpProject {
privilegeLevel: "readAndWrite"
}, (e, {@project_id, @user_id}) =>
cb(e)
(cb) =>
FixturesManager.setUpDoc @project_id, {@lines, @version, @ops}, (e, {@doc_id}) =>
cb(e)
(cb) =>
2014-11-13 06:54:10 -05:00
@client = RealTimeClient.connect()
@client.on "connectionAccepted", cb
(cb) =>
@client.emit "joinProject", project_id: @project_id, cb
(cb) =>
@client.emit "joinDoc", @doc_id, (error, @returnedArgs...) => cb(error)
], done
2014-11-13 06:54:10 -05:00
describe "then leaving the doc", ->
2019-07-26 03:07:49 -04:00
beforeEach (done) ->
2014-11-13 06:54:10 -05:00
@client.emit "leaveDoc", @doc_id, (error) ->
throw error if error?
done()
it "should have left the doc room", (done) ->
RealTimeClient.getConnectedClient @client.socket.sessionid, (error, client) =>
expect(@doc_id in client.rooms).to.equal false
done()
2019-07-26 03:07:49 -04:00
describe "when sending a leaveDoc request before the previous joinDoc request has completed", ->
beforeEach (done) ->
@client.emit "leaveDoc", @doc_id, () ->
@client.emit "joinDoc", @doc_id, () ->
@client.emit "leaveDoc", @doc_id, (error) ->
throw error if error?
done()
it "should not trigger an error", ->
sinon.assert.neverCalledWith(logger.error, sinon.match.any, "not subscribed - shouldn't happen")
it "should have left the doc room", (done) ->
RealTimeClient.getConnectedClient @client.socket.sessionid, (error, client) =>
expect(@doc_id in client.rooms).to.equal false
done()
describe "when sending a leaveDoc for a room the client has not joined ", ->
beforeEach (done) ->
@client.emit "leaveDoc", @other_doc_id, (error) ->
throw error if error?
done()
it "should trigger a low level message only", ->
sinon.assert.calledWith(logger.log, sinon.match.any, "ignoring request from client to leave room it is not in")