overleaf/services/document-updater/test/unit/coffee/ProjectHistoryRedisManager/ProjectHistoryRedisManagerTests.coffee

122 lines
3.3 KiB
CoffeeScript
Raw Normal View History

2018-03-09 14:14:14 +00:00
sinon = require('sinon')
chai = require('chai')
should = chai.should()
modulePath = "../../../../app/js/ProjectHistoryRedisManager.js"
SandboxedModule = require('sandboxed-module')
tk = require "timekeeper"
describe "ProjectHistoryRedisManager", ->
beforeEach ->
@project_id = "project-id-123"
@projectHistoryId = "history-id-123"
2018-03-09 14:14:14 +00:00
@user_id = "user-id-123"
@callback = sinon.stub()
@rclient = {}
tk.freeze(new Date())
@ProjectHistoryRedisManager = SandboxedModule.require modulePath,
requires:
"settings-sharelatex": @settings = {
redis:
project_history:
key_schema:
projectHistoryOps: ({project_id}) -> "ProjectHistory:Ops:#{project_id}"
projectHistoryFirstOpTimestamp: ({project_id}) -> "ProjectHistory:FirstOpTimestamp:#{project_id}"
2018-03-09 14:14:14 +00:00
}
"redis-sharelatex":
createClient: () => @rclient
"logger-sharelatex":
log:->
2018-03-09 14:14:14 +00:00
globals:
JSON: @JSON = JSON
afterEach ->
tk.reset()
2018-03-09 14:14:14 +00:00
describe "queueOps", ->
beforeEach ->
@ops = ["mock-op-1", "mock-op-2"]
@multi = exec: sinon.stub()
@multi.rpush = sinon.stub()
@multi.setnx = sinon.stub()
@rclient.multi = () => @multi
# @rclient = multi: () => @multi
2018-03-09 14:14:14 +00:00
@ProjectHistoryRedisManager.queueOps @project_id, @ops..., @callback
it "should queue an update", ->
@multi.rpush
2018-03-09 14:14:14 +00:00
.calledWithExactly(
"ProjectHistory:Ops:#{@project_id}"
@ops[0]
@ops[1]
).should.equal true
it "should set the queue timestamp if not present", ->
@multi.setnx
.calledWithExactly(
"ProjectHistory:FirstOpTimestamp:#{@project_id}"
Date.now()
2018-03-09 14:14:14 +00:00
).should.equal true
describe "queueRenameEntity", ->
beforeEach () ->
@file_id = 1234
@rawUpdate =
pathname: @pathname = '/old'
newPathname: @newPathname = '/new'
version: @version = 2
2018-03-09 14:14:14 +00:00
@ProjectHistoryRedisManager.queueOps = sinon.stub()
@ProjectHistoryRedisManager.queueRenameEntity @project_id, @projectHistoryId, 'file', @file_id, @user_id, @rawUpdate, @callback
2018-03-09 14:14:14 +00:00
it "should queue an update", ->
update =
pathname: @pathname
new_pathname: @newPathname
meta:
user_id: @user_id
ts: new Date()
version: @version
projectHistoryId: @projectHistoryId
2018-03-09 14:14:14 +00:00
file: @file_id
@ProjectHistoryRedisManager.queueOps
.calledWithExactly(@project_id, @JSON.stringify(update), @callback)
.should.equal true
describe "queueAddEntity", ->
beforeEach () ->
@rclient.rpush = sinon.stub().yields()
@doc_id = 1234
@rawUpdate =
pathname: @pathname = '/old'
docLines: @docLines = 'a\nb'
version: @version = 2
2018-03-09 14:14:14 +00:00
url: @url = 'filestore.example.com'
@ProjectHistoryRedisManager.queueOps = sinon.stub()
@ProjectHistoryRedisManager.queueAddEntity @project_id, @projectHistoryId, 'doc', @doc_id, @user_id, @rawUpdate, @callback
2018-03-09 14:14:14 +00:00
it "should queue an update", ->
update =
pathname: @pathname
docLines: @docLines
url: @url
meta:
user_id: @user_id
ts: new Date()
version: @version
projectHistoryId: @projectHistoryId
2018-03-09 14:14:14 +00:00
doc: @doc_id
@ProjectHistoryRedisManager.queueOps
.calledWithExactly(@project_id, @JSON.stringify(update), @callback)
.should.equal true
describe "queueResyncProjectStructure", ->
it "should queue an update", ->
describe "queueResyncDocContent", ->
it "should queue an update", ->