sinon = require('sinon') chai = require('chai') should = chai.should() modulePath = "../../../../app/js/HttpController.js" SandboxedModule = require('sandboxed-module') Errors = require "../../../../app/js/Errors.js" describe "HttpController.setDoc", -> beforeEach -> @HttpController = SandboxedModule.require modulePath, requires: "./DocumentManager": @DocumentManager = {} "./ProjectManager": {} "logger-sharelatex" : @logger = { log: sinon.stub() } "./Metrics": @Metrics = {} @Metrics.Timer = class Timer done: sinon.stub() @project_id = "project-id-123" @doc_id = "doc-id-123" @lines = ["one", "two", "three"] @source = "dropbox" @user_id = "user-id-123" @res = send: sinon.stub() @req = headers: {} params: project_id: @project_id doc_id: @doc_id body: lines: @lines source: @source user_id: @user_id @next = sinon.stub() describe "successfully", -> beforeEach -> @DocumentManager.setDocWithLock = sinon.stub().callsArgWith(5) @HttpController.setDoc(@req, @res, @next) it "should set the doc", -> @DocumentManager.setDocWithLock .calledWith(@project_id, @doc_id, @lines, @source, @user_id) .should.equal true it "should return a successful No Content response", -> @res.send .calledWith(204) .should.equal true it "should log the request", -> @logger.log .calledWith(doc_id: @doc_id, project_id: @project_id, lines: @lines, source: @source, user_id: @user_id, "setting doc via http") .should.equal true it "should time the request", -> @Metrics.Timer::done.called.should.equal true describe "when an errors occurs", -> beforeEach -> @DocumentManager.setDocWithLock = sinon.stub().callsArgWith(5, new Error("oops")) @HttpController.setDoc(@req, @res, @next) it "should call next with the error", -> @next .calledWith(new Error("oops")) .should.equal true describe "when the payload is too large", -> beforeEach -> @req.headers['content-length'] = 40 * 1024 * 1024 @DocumentManager.setDocWithLock = sinon.stub().callsArgWith(5) @HttpController.setDoc(@req, @res, @next) it 'should send back a 406 response', -> @res.send.calledWith(406).should.equal true it 'should not call setDocWithLock', -> @DocumentManager.setDocWithLock.callCount.should.equal 0