overleaf/services/web/test/UnitTests/coffee/ThirdPartyDataStore/TpdsControllerTests.coffee

123 lines
3.6 KiB
CoffeeScript
Raw Normal View History

2014-02-12 10:23:40 +00:00
SandboxedModule = require('sandboxed-module')
sinon = require('sinon')
require('chai').should()
modulePath = require('path').join __dirname, '../../../../app/js/Features/ThirdPartyDataStore/TpdsController.js'
describe 'TpdsController', ->
2014-02-12 10:23:40 +00:00
beforeEach ->
@TpdsUpdateHandler = {}
@TpdsController = SandboxedModule.require modulePath, requires:
'./TpdsUpdateHandler':@TpdsUpdateHandler
'./UpdateMerger': @UpdateMerger = {}
2014-02-12 10:23:40 +00:00
'logger-sharelatex':
log:->
err:->
@user_id = "dsad29jlkjas"
describe 'getting an update', ->
it 'should process the update with the update reciver', (done)->
path = "/projectName/here.txt"
req =
pause:->
params:{0:path, "user_id":@user_id}
session:
destroy:->
@TpdsUpdateHandler.newUpdate = sinon.stub().callsArg(5)
2014-02-12 10:23:40 +00:00
res = send: =>
@TpdsUpdateHandler.newUpdate.calledWith(@user_id, "projectName","/here.txt", req).should.equal true
2014-02-12 10:23:40 +00:00
done()
@TpdsController.mergeUpdate req, res
2014-02-12 10:23:40 +00:00
describe 'getting a delete update', ->
it 'should process the delete with the update reciver', (done)->
path = "/projectName/here.txt"
req =
params:{0:path, "user_id":@user_id}
session:
destroy:->
@TpdsUpdateHandler.deleteUpdate = sinon.stub().callsArg(4)
2014-02-12 10:23:40 +00:00
res = send: =>
@TpdsUpdateHandler.deleteUpdate.calledWith(@user_id, "projectName", "/here.txt").should.equal true
2014-02-12 10:23:40 +00:00
done()
@TpdsController.deleteUpdate req, res
2014-02-12 10:23:40 +00:00
describe 'parseParams', ->
it 'should take the project name off the start and replace with slash', ->
path = "noSlashHere"
req = params:{0:path, user_id:@user_id}
result = @TpdsController.parseParams(req)
2014-02-12 10:23:40 +00:00
result.user_id.should.equal @user_id
result.filePath.should.equal "/"
result.projectName.should.equal path
it 'should take the project name off the start and return it with no slashes in', ->
path = "/project/file.tex"
req = params:{0:path, user_id:@user_id}
result = @TpdsController.parseParams(req)
2014-02-12 10:23:40 +00:00
result.user_id.should.equal @user_id
result.filePath.should.equal "/file.tex"
result.projectName.should.equal "project"
it 'should take the project name of and return a slash for the file path', ->
path = "/project_name"
req = params:{0:path, user_id:@user_id}
result = @TpdsController.parseParams(req)
2014-02-12 10:23:40 +00:00
result.projectName.should.equal "project_name"
result.filePath.should.equal "/"
describe 'updateProjectContents', ->
beforeEach ->
@UpdateMerger.mergeUpdate = sinon.stub().callsArg(3)
@req =
params:
0: @path = "chapters/main.tex"
project_id: @project_id = "project-id-123"
session:
destroy: sinon.stub()
@res =
send: sinon.stub()
@TpdsController.updateProjectContents @req, @res
it "should merge the update", ->
@UpdateMerger.mergeUpdate
.calledWith(@project_id, "/" + @path, @req)
.should.equal true
it "should return a success", ->
@res.send.calledWith(200).should.equal true
it "should clear the session", ->
@req.session.destroy.called.should.equal true
describe 'deleteProjectContents', ->
beforeEach ->
@UpdateMerger.deleteUpdate = sinon.stub().callsArg(2)
@req =
params:
0: @path = "chapters/main.tex"
project_id: @project_id = "project-id-123"
session:
destroy: sinon.stub()
@res =
send: sinon.stub()
@TpdsController.deleteProjectContents @req, @res
it "should delete the file", ->
@UpdateMerger.deleteUpdate
.calledWith(@project_id, "/" + @path)
.should.equal true
it "should return a success", ->
@res.send.calledWith(200).should.equal true
2014-02-12 10:23:40 +00:00
it "should clear the session", ->
@req.session.destroy.called.should.equal true
2014-02-12 10:23:40 +00:00