overleaf/services/clsi/test/unit/coffee/CompileControllerTests.coffee

218 lines
6 KiB
CoffeeScript
Raw Normal View History

2014-02-12 17:27:43 +00:00
SandboxedModule = require('sandboxed-module')
sinon = require('sinon')
require('chai').should()
modulePath = require('path').join __dirname, '../../../app/js/CompileController'
tk = require("timekeeper")
describe "CompileController", ->
beforeEach ->
@CompileController = SandboxedModule.require modulePath, requires:
"./CompileManager": @CompileManager = {}
"./RequestParser": @RequestParser = {}
"settings-sharelatex": @Settings =
apis:
clsi:
url: "http://clsi.example.com"
"./ProjectPersistenceManager": @ProjectPersistenceManager = {}
"logger-sharelatex": @logger = { log: sinon.stub(), error: sinon.stub() }
@Settings.externalUrl = "http://www.example.com"
@req = {}
@res = {}
2014-04-08 14:18:56 +00:00
@next = sinon.stub()
2014-02-12 17:27:43 +00:00
describe "compile", ->
beforeEach ->
@req.body = {
compile: "mock-body"
}
@req.params =
project_id: @project_id = "project-id-123"
@request = {
compile: "mock-parsed-request"
}
@request_with_project_id =
compile: @request.compile
project_id: @project_id
@output_files = [{
path: "output.pdf"
type: "pdf"
2015-02-26 15:30:57 +00:00
build: 1234
2014-02-12 17:27:43 +00:00
}, {
path: "output.log"
type: "log"
2015-02-26 15:30:57 +00:00
build: 1234
2014-02-12 17:27:43 +00:00
}]
@RequestParser.parse = sinon.stub().callsArgWith(1, null, @request)
@ProjectPersistenceManager.markProjectAsJustAccessed = sinon.stub().callsArg(1)
@res.status = sinon.stub().returnsThis()
2014-02-12 17:27:43 +00:00
@res.send = sinon.stub()
describe "successfully", ->
beforeEach ->
@CompileManager.doCompile = sinon.stub().callsArgWith(1, null, @output_files)
@CompileController.compile @req, @res
it "should parse the request", ->
@RequestParser.parse
.calledWith(@req.body)
.should.equal true
it "should run the compile for the specified project", ->
@CompileManager.doCompile
.calledWith(@request_with_project_id)
.should.equal true
it "should mark the project as accessed", ->
@ProjectPersistenceManager.markProjectAsJustAccessed
.calledWith(@project_id)
.should.equal true
it "should return the JSON response", ->
@res.status.calledWith(200).should.equal true
2014-02-12 17:27:43 +00:00
@res.send
.calledWith(
2014-02-12 17:27:43 +00:00
compile:
status: "success"
error: null
outputFiles: @output_files.map (file) =>
url: "#{@Settings.apis.clsi.url}/project/#{@project_id}/build/#{file.build}/output/#{file.path}"
path: file.path
2014-02-12 17:27:43 +00:00
type: file.type
2015-02-26 15:30:57 +00:00
build: file.build
2014-02-12 17:27:43 +00:00
)
.should.equal true
describe "with an error", ->
beforeEach ->
@CompileManager.doCompile = sinon.stub().callsArgWith(1, new Error(@message = "error message"), null)
@CompileController.compile @req, @res
it "should return the JSON response with the error", ->
@res.status.calledWith(500).should.equal true
2014-02-12 17:27:43 +00:00
@res.send
.calledWith(
2014-02-12 17:27:43 +00:00
compile:
2014-05-19 11:18:57 +00:00
status: "error"
2014-02-12 17:27:43 +00:00
error: @message
outputFiles: []
)
.should.equal true
2014-05-19 11:18:57 +00:00
describe "when the request times out", ->
beforeEach ->
@error = new Error(@message = "container timed out")
@error.timedout = true
@CompileManager.doCompile = sinon.stub().callsArgWith(1, @error, null)
@CompileController.compile @req, @res
it "should return the JSON response with the timeout status", ->
@res.status.calledWith(200).should.equal true
2014-05-19 11:18:57 +00:00
@res.send
.calledWith(
2014-05-19 11:18:57 +00:00
compile:
status: "timedout"
error: @message
outputFiles: []
)
.should.equal true
describe "when the request returns no output files", ->
beforeEach ->
@CompileManager.doCompile = sinon.stub().callsArgWith(1, null, [])
@CompileController.compile @req, @res
it "should return the JSON response with the failure status", ->
@res.status.calledWith(200).should.equal true
2014-05-19 11:18:57 +00:00
@res.send
.calledWith(
2014-05-19 11:18:57 +00:00
compile:
error: null
status: "failure"
outputFiles: []
)
.should.equal true
2014-04-08 14:18:56 +00:00
describe "syncFromCode", ->
beforeEach ->
@file = "main.tex"
@line = 42
@column = 5
@project_id = "mock-project-id"
@req.params =
project_id: @project_id
@req.query =
file: @file
line: @line.toString()
column: @column.toString()
@res.send = sinon.stub()
2016-05-27 14:29:26 +00:00
@CompileManager.syncFromCode = sinon.stub().callsArgWith(5, null, @pdfPositions = ["mock-positions"])
2014-04-08 14:18:56 +00:00
@CompileController.syncFromCode @req, @res, @next
it "should find the corresponding location in the PDF", ->
@CompileManager.syncFromCode
2016-05-27 14:29:26 +00:00
.calledWith(@project_id, undefined, @file, @line, @column)
2014-04-08 14:18:56 +00:00
.should.equal true
it "should return the positions", ->
@res.send
.calledWith(JSON.stringify
pdf: @pdfPositions
)
.should.equal true
describe "syncFromPdf", ->
beforeEach ->
@page = 5
@h = 100.23
@v = 45.67
@project_id = "mock-project-id"
@req.params =
project_id: @project_id
@req.query =
page: @page.toString()
h: @h.toString()
v: @v.toString()
@res.send = sinon.stub()
2016-05-27 14:29:26 +00:00
@CompileManager.syncFromPdf = sinon.stub().callsArgWith(5, null, @codePositions = ["mock-positions"])
2014-04-08 14:18:56 +00:00
@CompileController.syncFromPdf @req, @res, @next
it "should find the corresponding location in the code", ->
@CompileManager.syncFromPdf
2016-05-27 14:29:26 +00:00
.calledWith(@project_id, undefined, @page, @h, @v)
2014-04-08 14:18:56 +00:00
.should.equal true
it "should return the positions", ->
@res.send
.calledWith(JSON.stringify
code: @codePositions
)
.should.equal true
2015-06-08 22:27:47 +00:00
describe "wordcount", ->
beforeEach ->
@file = "main.tex"
@project_id = "mock-project-id"
@req.params =
project_id: @project_id
@req.query =
file: @file
image: @image = "example.com/image"
2015-06-08 22:27:47 +00:00
@res.send = sinon.stub()
2016-05-27 14:29:26 +00:00
@CompileManager.wordcount = sinon.stub().callsArgWith(4, null, @texcount = ["mock-texcount"])
2015-06-08 22:27:47 +00:00
@CompileController.wordcount @req, @res, @next
it "should return the word count of a file", ->
@CompileManager.wordcount
2016-05-27 14:29:26 +00:00
.calledWith(@project_id, undefined, @file, @image)
2015-06-08 22:27:47 +00:00
.should.equal true
it "should return the texcount info", ->
@res.send
.calledWith(JSON.stringify
texcount: @texcount
)
.should.equal true