mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-07 20:31:06 -05:00
167 lines
6.4 KiB
JavaScript
167 lines
6.4 KiB
JavaScript
/* eslint-disable
|
|
no-return-assign,
|
|
no-unused-vars,
|
|
*/
|
|
// TODO: This file was created by bulk-decaffeinate.
|
|
// Fix any style issues and re-enable lint.
|
|
/*
|
|
* decaffeinate suggestions:
|
|
* DS102: Remove unnecessary code created because of implicit returns
|
|
* DS206: Consider reworking classes to avoid initClass
|
|
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
|
|
*/
|
|
const sinon = require('sinon');
|
|
const chai = require('chai');
|
|
const should = chai.should();
|
|
const modulePath = "../../../../app/js/ProjectManager.js";
|
|
const SandboxedModule = require('sandboxed-module');
|
|
const Errors = require("../../../../app/js/Errors.js");
|
|
|
|
describe("ProjectManager - getProjectDocsAndFlushIfOld", function() {
|
|
beforeEach(function() {
|
|
let Timer;
|
|
this.ProjectManager = SandboxedModule.require(modulePath, { requires: {
|
|
"./RedisManager": (this.RedisManager = {}),
|
|
"./ProjectHistoryRedisManager": (this.ProjectHistoryRedisManager = {}),
|
|
"./DocumentManager": (this.DocumentManager = {}),
|
|
"logger-sharelatex": (this.logger = { log: sinon.stub(), error: sinon.stub() }),
|
|
"./HistoryManager": (this.HistoryManager = {}),
|
|
"./Metrics": (this.Metrics = {
|
|
Timer: (Timer = (function() {
|
|
Timer = class Timer {
|
|
static initClass() {
|
|
this.prototype.done = sinon.stub();
|
|
}
|
|
};
|
|
Timer.initClass();
|
|
return Timer;
|
|
})())
|
|
})
|
|
}
|
|
}
|
|
);
|
|
this.project_id = "project-id-123";
|
|
this.callback = sinon.stub();
|
|
return this.doc_versions = [111, 222, 333];});
|
|
|
|
describe("successfully", function() {
|
|
beforeEach(function(done) {
|
|
this.doc_ids = ["doc-id-1", "doc-id-2", "doc-id-3"];
|
|
this.doc_lines = [["aaa","aaa"],["bbb","bbb"],["ccc","ccc"]];
|
|
this.docs = [
|
|
{_id: this.doc_ids[0], lines: this.doc_lines[0], v: this.doc_versions[0]},
|
|
{_id: this.doc_ids[1], lines: this.doc_lines[1], v: this.doc_versions[1]},
|
|
{_id: this.doc_ids[2], lines: this.doc_lines[2], v: this.doc_versions[2]}
|
|
];
|
|
this.RedisManager.checkOrSetProjectState = sinon.stub().callsArgWith(2, null);
|
|
this.RedisManager.getDocIdsInProject = sinon.stub().callsArgWith(1, null, this.doc_ids);
|
|
this.DocumentManager.getDocAndFlushIfOldWithLock = sinon.stub();
|
|
this.DocumentManager.getDocAndFlushIfOldWithLock.withArgs(this.project_id, this.doc_ids[0])
|
|
.callsArgWith(2, null, this.doc_lines[0], this.doc_versions[0]);
|
|
this.DocumentManager.getDocAndFlushIfOldWithLock.withArgs(this.project_id, this.doc_ids[1])
|
|
.callsArgWith(2, null, this.doc_lines[1], this.doc_versions[1]);
|
|
this.DocumentManager.getDocAndFlushIfOldWithLock.withArgs(this.project_id, this.doc_ids[2])
|
|
.callsArgWith(2, null, this.doc_lines[2], this.doc_versions[2]);
|
|
return this.ProjectManager.getProjectDocsAndFlushIfOld(this.project_id, this.projectStateHash, this.excludeVersions, (error, docs) => {
|
|
this.callback(error, docs);
|
|
return done();
|
|
});
|
|
});
|
|
|
|
it("should check the project state", function() {
|
|
return this.RedisManager.checkOrSetProjectState
|
|
.calledWith(this.project_id, this.projectStateHash)
|
|
.should.equal(true);
|
|
});
|
|
|
|
it("should get the doc ids in the project", function() {
|
|
return this.RedisManager.getDocIdsInProject
|
|
.calledWith(this.project_id)
|
|
.should.equal(true);
|
|
});
|
|
|
|
it("should call the callback without error", function() {
|
|
return this.callback.calledWith(null, this.docs).should.equal(true);
|
|
});
|
|
|
|
return it("should time the execution", function() {
|
|
return this.Metrics.Timer.prototype.done.called.should.equal(true);
|
|
});
|
|
});
|
|
|
|
describe("when the state does not match", function() {
|
|
beforeEach(function(done) {
|
|
this.doc_ids = ["doc-id-1", "doc-id-2", "doc-id-3"];
|
|
this.RedisManager.checkOrSetProjectState = sinon.stub().callsArgWith(2, null, true);
|
|
return this.ProjectManager.getProjectDocsAndFlushIfOld(this.project_id, this.projectStateHash, this.excludeVersions, (error, docs) => {
|
|
this.callback(error, docs);
|
|
return done();
|
|
});
|
|
});
|
|
|
|
it("should check the project state", function() {
|
|
return this.RedisManager.checkOrSetProjectState
|
|
.calledWith(this.project_id, this.projectStateHash)
|
|
.should.equal(true);
|
|
});
|
|
|
|
it("should call the callback with an error", function() {
|
|
return this.callback.calledWith(new Errors.ProjectStateChangedError("project state changed")).should.equal(true);
|
|
});
|
|
|
|
return it("should time the execution", function() {
|
|
return this.Metrics.Timer.prototype.done.called.should.equal(true);
|
|
});
|
|
});
|
|
|
|
describe("when a doc errors", function() {
|
|
beforeEach(function(done) {
|
|
this.doc_ids = ["doc-id-1", "doc-id-2", "doc-id-3"];
|
|
this.RedisManager.checkOrSetProjectState = sinon.stub().callsArgWith(2, null);
|
|
this.RedisManager.getDocIdsInProject = sinon.stub().callsArgWith(1, null, this.doc_ids);
|
|
this.DocumentManager.getDocAndFlushIfOldWithLock = sinon.stub();
|
|
this.DocumentManager.getDocAndFlushIfOldWithLock.withArgs(this.project_id, "doc-id-1")
|
|
.callsArgWith(2, null, ["test doc content"], this.doc_versions[1]);
|
|
this.DocumentManager.getDocAndFlushIfOldWithLock.withArgs(this.project_id, "doc-id-2")
|
|
.callsArgWith(2, (this.error = new Error("oops"))); // trigger an error
|
|
return this.ProjectManager.getProjectDocsAndFlushIfOld(this.project_id, this.projectStateHash, this.excludeVersions, (error, docs) => {
|
|
this.callback(error);
|
|
return done();
|
|
});
|
|
});
|
|
|
|
it("should record the error", function() {
|
|
return this.logger.error
|
|
.calledWith({err: this.error, project_id: this.project_id, doc_id: "doc-id-2"}, "error getting project doc lines in getProjectDocsAndFlushIfOld")
|
|
.should.equal(true);
|
|
});
|
|
|
|
it("should call the callback with an error", function() {
|
|
return this.callback.calledWith(new Error("oops")).should.equal(true);
|
|
});
|
|
|
|
return it("should time the execution", function() {
|
|
return this.Metrics.Timer.prototype.done.called.should.equal(true);
|
|
});
|
|
});
|
|
|
|
return describe("clearing the project state with clearProjectState", function() {
|
|
beforeEach(function(done) {
|
|
this.RedisManager.clearProjectState = sinon.stub().callsArg(1);
|
|
return this.ProjectManager.clearProjectState(this.project_id, error => {
|
|
this.callback(error);
|
|
return done();
|
|
});
|
|
});
|
|
|
|
it("should clear the project state", function() {
|
|
return this.RedisManager.clearProjectState
|
|
.calledWith(this.project_id)
|
|
.should.equal(true);
|
|
});
|
|
|
|
return it("should call the callback", function() {
|
|
return this.callback.called.should.equal(true);
|
|
});
|
|
});
|
|
});
|