2020-02-17 12:35:39 -05:00
|
|
|
/*
|
|
|
|
* decaffeinate suggestions:
|
|
|
|
* DS102: Remove unnecessary code created because of implicit returns
|
|
|
|
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
|
|
|
|
*/
|
|
|
|
const sinon = require("sinon");
|
|
|
|
const chai = require("chai");
|
|
|
|
chai.should();
|
|
|
|
const { expect } = chai;
|
|
|
|
const mongojs = require("../../../app/js/mongojs");
|
|
|
|
const { ObjectId } = mongojs;
|
|
|
|
const Settings = require("settings-sharelatex");
|
|
|
|
const LockManager = require("../../../app/js/LockManager");
|
|
|
|
const rclient = require("redis").createClient(Settings.redis.history); // Only works locally for now
|
|
|
|
const TrackChangesApp = require("./helpers/TrackChangesApp");
|
2015-10-08 09:20:36 -04:00
|
|
|
|
2020-02-17 12:35:39 -05:00
|
|
|
describe("Locking document", function() {
|
2018-05-24 07:02:27 -04:00
|
|
|
|
2020-02-17 12:35:39 -05:00
|
|
|
before(function(done){
|
|
|
|
TrackChangesApp.ensureRunning(done);
|
|
|
|
return null;
|
|
|
|
});
|
2018-05-24 07:02:27 -04:00
|
|
|
|
2020-02-17 12:35:39 -05:00
|
|
|
return describe("when the lock has expired in redis", function() {
|
|
|
|
before(function(done) {
|
|
|
|
LockManager.LOCK_TTL = 1; // second
|
|
|
|
LockManager.runWithLock("doc123", releaseA => {
|
|
|
|
// we create a lock A and allow it to expire in redis
|
|
|
|
return setTimeout(() =>
|
|
|
|
// now we create a new lock B and try to release A
|
|
|
|
LockManager.runWithLock("doc123", releaseB => {
|
|
|
|
return releaseA();
|
|
|
|
} // try to release lock A to see if it wipes out lock B
|
|
|
|
, function(error) {})
|
|
|
|
|
|
|
|
// we never release lock B so nothing should happen here
|
|
|
|
, 1500);
|
|
|
|
} // enough time to wait until the lock has expired
|
|
|
|
, error =>
|
|
|
|
// we get here after trying to release lock A
|
2015-10-08 09:20:36 -04:00
|
|
|
done()
|
2020-02-17 12:35:39 -05:00
|
|
|
);
|
|
|
|
return null;
|
|
|
|
});
|
2015-10-08 09:20:36 -04:00
|
|
|
|
2020-02-17 12:35:39 -05:00
|
|
|
return it("the new lock should not be removed by the expired locker", function(done) {
|
|
|
|
LockManager.checkLock("doc123", function(err, isFree) {
|
|
|
|
expect(isFree).to.equal(false);
|
|
|
|
return done();
|
|
|
|
});
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|