mirror of
https://github.com/overleaf/overleaf.git
synced 2025-01-01 05:22:11 +00:00
175 lines
5.4 KiB
CoffeeScript
175 lines
5.4 KiB
CoffeeScript
sinon = require "sinon"
|
|
chai = require("chai")
|
|
chai.should()
|
|
async = require "async"
|
|
|
|
MockTrackChangesApi = require "./helpers/MockTrackChangesApi"
|
|
MockProjectHistoryApi = require "./helpers/MockProjectHistoryApi"
|
|
MockWebApi = require "./helpers/MockWebApi"
|
|
DocUpdaterClient = require "./helpers/DocUpdaterClient"
|
|
DocUpdaterApp = require "./helpers/DocUpdaterApp"
|
|
|
|
describe "Deleting a project", ->
|
|
before (done) ->
|
|
@project_id = DocUpdaterClient.randomId()
|
|
@docs = [{
|
|
id: doc_id0 = DocUpdaterClient.randomId()
|
|
lines: ["one", "two", "three"]
|
|
update:
|
|
doc: doc_id0
|
|
op: [{
|
|
i: "one and a half\n"
|
|
p: 4
|
|
}]
|
|
v: 0
|
|
updatedLines: ["one", "one and a half", "two", "three"]
|
|
}, {
|
|
id: doc_id1 = DocUpdaterClient.randomId()
|
|
lines: ["four", "five", "six"]
|
|
update:
|
|
doc: doc_id1
|
|
op: [{
|
|
i: "four and a half\n"
|
|
p: 5
|
|
}]
|
|
v: 0
|
|
updatedLines: ["four", "four and a half", "five", "six"]
|
|
}]
|
|
for doc in @docs
|
|
MockWebApi.insertDoc @project_id, doc.id, {
|
|
lines: doc.lines
|
|
version: doc.update.v
|
|
}
|
|
|
|
DocUpdaterApp.ensureRunning(done)
|
|
|
|
|
|
describe "with documents which have been updated", ->
|
|
before (done) ->
|
|
sinon.spy MockWebApi, "setDocument"
|
|
sinon.spy MockTrackChangesApi, "flushDoc"
|
|
sinon.spy MockProjectHistoryApi, "flushProject"
|
|
|
|
async.series @docs.map((doc) =>
|
|
(callback) =>
|
|
DocUpdaterClient.preloadDoc @project_id, doc.id, (error) =>
|
|
return callback(error) if error?
|
|
DocUpdaterClient.sendUpdate @project_id, doc.id, doc.update, (error) =>
|
|
callback(error)
|
|
), (error) =>
|
|
throw error if error?
|
|
setTimeout () =>
|
|
DocUpdaterClient.deleteProject @project_id, (error, res, body) =>
|
|
@statusCode = res.statusCode
|
|
done()
|
|
, 200
|
|
|
|
after ->
|
|
MockWebApi.setDocument.restore()
|
|
MockTrackChangesApi.flushDoc.restore()
|
|
MockProjectHistoryApi.flushProject.restore()
|
|
|
|
it "should return a 204 status code", ->
|
|
@statusCode.should.equal 204
|
|
|
|
it "should send each document to the web api", ->
|
|
for doc in @docs
|
|
MockWebApi.setDocument
|
|
.calledWith(@project_id, doc.id, doc.updatedLines)
|
|
.should.equal true
|
|
|
|
it "should need to reload the docs if read again", (done) ->
|
|
sinon.spy MockWebApi, "getDocument"
|
|
async.series @docs.map((doc) =>
|
|
(callback) =>
|
|
MockWebApi.getDocument.calledWith(@project_id, doc.id).should.equal false
|
|
DocUpdaterClient.getDoc @project_id, doc.id, (error, res, returnedDoc) =>
|
|
MockWebApi.getDocument.calledWith(@project_id, doc.id).should.equal true
|
|
callback()
|
|
), () ->
|
|
MockWebApi.getDocument.restore()
|
|
done()
|
|
|
|
it "should flush each doc in track changes", ->
|
|
for doc in @docs
|
|
MockTrackChangesApi.flushDoc.calledWith(doc.id).should.equal true
|
|
|
|
it "should flush each doc in project history", ->
|
|
MockProjectHistoryApi.flushProject.calledWith(@project_id).should.equal true
|
|
|
|
describe "with the background=true parameter from realtime and no request to flush the queue", ->
|
|
before (done) ->
|
|
sinon.spy MockWebApi, "setDocument"
|
|
sinon.spy MockTrackChangesApi, "flushDoc"
|
|
sinon.spy MockProjectHistoryApi, "flushProject"
|
|
|
|
async.series @docs.map((doc) =>
|
|
(callback) =>
|
|
DocUpdaterClient.preloadDoc @project_id, doc.id, callback
|
|
), (error) =>
|
|
throw error if error?
|
|
setTimeout () =>
|
|
DocUpdaterClient.deleteProjectOnShutdown @project_id, (error, res, body) =>
|
|
@statusCode = res.statusCode
|
|
done()
|
|
, 200
|
|
|
|
after ->
|
|
MockWebApi.setDocument.restore()
|
|
MockTrackChangesApi.flushDoc.restore()
|
|
MockProjectHistoryApi.flushProject.restore()
|
|
|
|
it "should return a 204 status code", ->
|
|
@statusCode.should.equal 204
|
|
|
|
it "should not send any documents to the web api", ->
|
|
MockWebApi.setDocument.called.should.equal false
|
|
|
|
it "should not flush any docs in track changes", ->
|
|
MockTrackChangesApi.flushDoc.called.should.equal false
|
|
|
|
it "should not flush to project history", ->
|
|
MockProjectHistoryApi.flushProject.called.should.equal false
|
|
|
|
describe "with the background=true parameter from realtime and a request to flush the queue", ->
|
|
before (done) ->
|
|
sinon.spy MockWebApi, "setDocument"
|
|
sinon.spy MockTrackChangesApi, "flushDoc"
|
|
sinon.spy MockProjectHistoryApi, "flushProject"
|
|
|
|
async.series @docs.map((doc) =>
|
|
(callback) =>
|
|
DocUpdaterClient.preloadDoc @project_id, doc.id, callback
|
|
), (error) =>
|
|
throw error if error?
|
|
setTimeout () =>
|
|
DocUpdaterClient.deleteProjectOnShutdown @project_id, (error, res, body) =>
|
|
@statusCode = res.statusCode
|
|
# after deleting the project and putting it in the queue, flush the queue
|
|
setTimeout () ->
|
|
DocUpdaterClient.flushOldProjects (error, res, body) =>
|
|
setTimeout done, 1000 # allow time for the flush to complete
|
|
, 100
|
|
, 200
|
|
|
|
after ->
|
|
MockWebApi.setDocument.restore()
|
|
MockTrackChangesApi.flushDoc.restore()
|
|
MockProjectHistoryApi.flushProject.restore()
|
|
|
|
it "should return a 204 status code", ->
|
|
@statusCode.should.equal 204
|
|
|
|
it "should send each document to the web api", ->
|
|
for doc in @docs
|
|
MockWebApi.setDocument
|
|
.calledWith(@project_id, doc.id, doc.updatedLines)
|
|
.should.equal true
|
|
|
|
it "should flush each doc in track changes", ->
|
|
for doc in @docs
|
|
MockTrackChangesApi.flushDoc.calledWith(doc.id).should.equal true
|
|
|
|
it "should not flush to project history", ->
|
|
MockProjectHistoryApi.flushProject.called.should.equal false
|
|
|