overleaf/services/document-updater/test/unit/js/LockManager/ReleasingTheLock.js

95 lines
2.7 KiB
JavaScript
Raw Normal View History

/* 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 assert = require('node:assert')
const path = require('node:path')
const modulePath = path.join(__dirname, '../../../../app/js/LockManager.js')
const projectId = 1234
const docId = 5678
const SandboxedModule = require('sandboxed-module')
2014-02-12 05:40:42 -05:00
describe('LockManager - releasing the lock', function () {
beforeEach(function () {
let Profiler
this.client = {
auth() {},
2021-07-13 07:04:42 -04:00
eval: sinon.stub(),
}
const mocks = {
'@overleaf/redis-wrapper': {
2021-07-13 07:04:42 -04:00
createClient: () => this.client,
},
'@overleaf/settings': {
redis: {
lock: {
key_schema: {
blockingKey({ doc_id: docId }) {
return `Blocking:${docId}`
2021-07-13 07:04:42 -04:00
},
},
},
},
},
'@overleaf/metrics': { inc() {} },
'./Profiler': (Profiler = (function () {
Profiler = class Profiler {
static initClass() {
this.prototype.log = sinon.stub().returns({ end: sinon.stub() })
this.prototype.end = sinon.stub()
}
}
Profiler.initClass()
return Profiler
2021-07-13 07:04:42 -04:00
})()),
}
this.LockManager = SandboxedModule.require(modulePath, { requires: mocks })
this.lockValue = 'lock-value-stub'
return (this.callback = sinon.stub())
})
2014-02-12 05:40:42 -05:00
describe('when the lock is current', function () {
beforeEach(function () {
this.client.eval = sinon.stub().yields(null, 1)
return this.LockManager.releaseLock(docId, this.lockValue, this.callback)
})
2014-02-12 05:40:42 -05:00
it('should clear the data from redis', function () {
return this.client.eval
.calledWith(
this.LockManager.unlockScript,
1,
`Blocking:${docId}`,
this.lockValue
)
.should.equal(true)
})
2014-02-12 05:40:42 -05:00
return it('should call the callback', function () {
return this.callback.called.should.equal(true)
})
})
2017-03-30 10:31:34 -04:00
return describe('when the lock has expired', function () {
beforeEach(function () {
this.client.eval = sinon.stub().yields(null, 0)
return this.LockManager.releaseLock(docId, this.lockValue, this.callback)
})
2017-03-30 10:31:34 -04:00
return it('should return an error if the lock has expired', function () {
return this.callback
2020-05-15 14:29:49 -04:00
.calledWith(sinon.match.instanceOf(Error))
.should.equal(true)
})
})
})