mirror of
https://github.com/yu-i-i/overleaf-cep.git
synced 2026-06-03 22:29:01 +02:00
5e773ce950
Migrate from `settings-sharelatex` to `@overleaf/settings` GitOrigin-RevId: 9a298ba26382180c1351683c5fddc9004418c1e6
82 lines
2.4 KiB
JavaScript
82 lines
2.4 KiB
JavaScript
/* eslint-disable
|
|
max-len,
|
|
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
|
|
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
|
|
*/
|
|
const sinon = require('sinon')
|
|
const path = require('path')
|
|
const modulePath = path.join(
|
|
__dirname,
|
|
'../../../../../app/src/infrastructure/LockManager.js'
|
|
)
|
|
const SandboxedModule = require('sandboxed-module')
|
|
|
|
describe('LockManager - trying the lock', function () {
|
|
beforeEach(function () {
|
|
this.LockManager = SandboxedModule.require(modulePath, {
|
|
requires: {
|
|
'./RedisWrapper': {
|
|
client: () => {
|
|
return {
|
|
auth() {},
|
|
set: (this.set = sinon.stub()),
|
|
}
|
|
},
|
|
},
|
|
'@overleaf/settings': {
|
|
redis: {},
|
|
lockManager: {
|
|
lockTestInterval: 50,
|
|
maxTestInterval: 1000,
|
|
maxLockWaitTime: 10000,
|
|
redisLockExpiry: 30,
|
|
slowExecutionThreshold: 5000,
|
|
},
|
|
},
|
|
'@overleaf/metrics': {
|
|
inc() {},
|
|
},
|
|
},
|
|
})
|
|
this.callback = sinon.stub()
|
|
this.key = 'lock:web:lockName:project-id}'
|
|
return (this.namespace = 'lockName')
|
|
})
|
|
|
|
describe('when the lock is not set', function () {
|
|
beforeEach(function () {
|
|
this.set.callsArgWith(5, null, 'OK')
|
|
this.LockManager.randomLock = sinon.stub().returns('random-lock-value')
|
|
return this.LockManager._tryLock(this.key, this.namespace, this.callback)
|
|
})
|
|
|
|
it('should set the lock key with an expiry if it is not set', function () {
|
|
return this.set
|
|
.calledWith(this.key, 'random-lock-value', 'EX', 30, 'NX')
|
|
.should.equal(true)
|
|
})
|
|
|
|
it('should return the callback with true', function () {
|
|
return this.callback.calledWith(null, true).should.equal(true)
|
|
})
|
|
})
|
|
|
|
describe('when the lock is already set', function () {
|
|
beforeEach(function () {
|
|
this.set.callsArgWith(5, null, null)
|
|
return this.LockManager._tryLock(this.key, this.namespace, this.callback)
|
|
})
|
|
|
|
it('should return the callback with false', function () {
|
|
return this.callback.calledWith(null, false).should.equal(true)
|
|
})
|
|
})
|
|
})
|