mirror of
https://github.com/status-im/codimd.git
synced 2025-01-11 23:44:26 +00:00
2135cfcd18
Signed-off-by: BoHong Li <raccoon@hackmd.io>
71 lines
2.1 KiB
JavaScript
71 lines
2.1 KiB
JavaScript
/* eslint-env node, mocha */
|
|
'use strict'
|
|
|
|
const assert = require('assert')
|
|
const mock = require('mock-require')
|
|
const sinon = require('sinon')
|
|
const { removeModuleFromRequireCache, removeLibModuleCache } = require('./utils')
|
|
|
|
describe('save revision job', function () {
|
|
let clock
|
|
let mockModels
|
|
let realtime
|
|
beforeEach(() => {
|
|
removeLibModuleCache()
|
|
mockModels = {
|
|
Revision: {
|
|
saveAllNotesRevision: sinon.stub()
|
|
}
|
|
}
|
|
clock = sinon.useFakeTimers()
|
|
mock('../../lib/processQueue', require('../testDoubles/ProcessQueueFake'))
|
|
mock('../../lib/logger', {
|
|
error: () => {},
|
|
info: () => {}
|
|
})
|
|
mock('../../lib/history', {})
|
|
mock('../../lib/models', mockModels)
|
|
mock('../../lib/config', {
|
|
debug: true
|
|
})
|
|
mock('../../lib/realtimeUpdateDirtyNoteJob', require('../testDoubles/realtimeJobStub'))
|
|
mock('../../lib/realtimeCleanDanglingUserJob', require('../testDoubles/realtimeJobStub'))
|
|
})
|
|
|
|
afterEach(() => {
|
|
clock.restore()
|
|
removeModuleFromRequireCache('../../lib/realtime/realtime')
|
|
removeModuleFromRequireCache('../../lib/realtime/realtimeSaveRevisionJob')
|
|
mock.stopAll()
|
|
sinon.restore()
|
|
})
|
|
|
|
it('should execute save revision job every 5 min', (done) => {
|
|
mockModels.Revision.saveAllNotesRevision.callsFake((callback) => {
|
|
callback(null, [])
|
|
})
|
|
realtime = require('../../lib/realtime/realtime')
|
|
clock.tick(5 * 60 * 1000)
|
|
clock.restore()
|
|
setTimeout(() => {
|
|
assert(mockModels.Revision.saveAllNotesRevision.called)
|
|
assert(realtime.saveRevisionJob.getSaverSleep() === true)
|
|
done()
|
|
}, 50)
|
|
})
|
|
|
|
it('should not set saverSleep when more than 1 note save revision', (done) => {
|
|
mockModels.Revision.saveAllNotesRevision.callsFake((callback) => {
|
|
callback(null, [1])
|
|
})
|
|
realtime = require('../../lib/realtime/realtime')
|
|
clock.tick(5 * 60 * 1000)
|
|
clock.restore()
|
|
setTimeout(() => {
|
|
assert(mockModels.Revision.saveAllNotesRevision.called)
|
|
assert(realtime.saveRevisionJob.getSaverSleep() === false)
|
|
done()
|
|
}, 50)
|
|
})
|
|
})
|