2014-08-07 10:45:19 +00:00
|
|
|
sinon = require('sinon')
|
|
|
|
chai = require('chai')
|
|
|
|
should = chai.should()
|
2014-08-11 13:16:05 +00:00
|
|
|
modulePath = "../../../../app/js/DispatchManager.js"
|
2014-08-07 10:45:19 +00:00
|
|
|
SandboxedModule = require('sandboxed-module')
|
|
|
|
|
2014-08-11 13:16:05 +00:00
|
|
|
describe "DispatchManager", ->
|
2014-08-07 10:45:19 +00:00
|
|
|
beforeEach ->
|
2014-08-11 13:16:05 +00:00
|
|
|
@DispatchManager = SandboxedModule.require modulePath, requires:
|
2014-08-07 10:45:19 +00:00
|
|
|
"./UpdateManager" : @UpdateManager = {}
|
|
|
|
"logger-sharelatex": @logger = { log: sinon.stub() }
|
|
|
|
"settings-sharelatex": @settings =
|
|
|
|
redis:
|
|
|
|
web: {}
|
|
|
|
"redis": @redis = {}
|
|
|
|
@callback = sinon.stub()
|
|
|
|
|
|
|
|
describe "each worker", ->
|
|
|
|
beforeEach ->
|
|
|
|
@client =
|
|
|
|
auth: sinon.stub()
|
|
|
|
@redis.createClient = sinon.stub().returns @client
|
|
|
|
|
2014-08-11 13:16:05 +00:00
|
|
|
@worker = @DispatchManager.createDispatcher()
|
2014-08-07 10:45:19 +00:00
|
|
|
|
|
|
|
it "should create a new redis client", ->
|
|
|
|
@redis.createClient.called.should.equal true
|
|
|
|
|
2014-08-11 13:16:05 +00:00
|
|
|
describe "_waitForUpdateThenDispatchWorker", ->
|
2014-08-07 10:45:19 +00:00
|
|
|
beforeEach ->
|
|
|
|
@project_id = "project-id-123"
|
|
|
|
@doc_id = "doc-id-123"
|
|
|
|
@doc_key = "#{@project_id}:#{@doc_id}"
|
|
|
|
@client.blpop = sinon.stub().callsArgWith(2, null, ["pending-updates-list", @doc_key])
|
|
|
|
@UpdateManager.processOutstandingUpdatesWithLock = sinon.stub().callsArg(2)
|
|
|
|
|
2014-08-11 13:16:05 +00:00
|
|
|
@worker._waitForUpdateThenDispatchWorker @callback
|
2014-08-07 10:45:19 +00:00
|
|
|
|
|
|
|
it "should call redis with BLPOP", ->
|
|
|
|
@client.blpop
|
|
|
|
.calledWith("pending-updates-list", 0)
|
|
|
|
.should.equal true
|
|
|
|
|
|
|
|
it "should call processOutstandingUpdatesWithLock", ->
|
|
|
|
@UpdateManager.processOutstandingUpdatesWithLock
|
|
|
|
.calledWith(@project_id, @doc_id)
|
|
|
|
.should.equal true
|
|
|
|
|
|
|
|
it "should call the callback", ->
|
|
|
|
@callback.called.should.equal true
|
|
|
|
|
|
|
|
describe "run", ->
|
2014-08-11 13:16:05 +00:00
|
|
|
it "should call _waitForUpdateThenDispatchWorker until shutting down", (done) ->
|
2014-08-07 10:45:19 +00:00
|
|
|
callCount = 0
|
2014-08-11 13:16:05 +00:00
|
|
|
@worker._waitForUpdateThenDispatchWorker = (callback = (error) ->) =>
|
2014-08-07 10:45:19 +00:00
|
|
|
callCount++
|
|
|
|
if callCount == 3
|
|
|
|
@settings.shuttingDown = true
|
|
|
|
setTimeout () ->
|
|
|
|
callback()
|
|
|
|
, 10
|
2014-08-11 13:16:05 +00:00
|
|
|
sinon.spy @worker, "_waitForUpdateThenDispatchWorker"
|
2014-08-07 10:45:19 +00:00
|
|
|
|
|
|
|
|
|
|
|
@worker.run()
|
|
|
|
|
|
|
|
setTimeout () =>
|
2014-08-11 13:16:05 +00:00
|
|
|
@worker._waitForUpdateThenDispatchWorker.callCount.should.equal 3
|
2014-08-07 10:45:19 +00:00
|
|
|
done()
|
|
|
|
, 100
|
|
|
|
|
|
|
|
|
|
|
|
|