2015-12-31 10:28:19 +00:00
|
|
|
SandboxedModule = require('sandboxed-module')
|
|
|
|
should = require('chai').should()
|
|
|
|
expect = require('chai').expect
|
|
|
|
sinon = require 'sinon'
|
|
|
|
assert = require("chai").assert
|
2016-02-08 17:04:27 +00:00
|
|
|
modulePath = "../../../../app/js/Features/References/ReferencesHandler"
|
2015-12-31 10:28:19 +00:00
|
|
|
|
2016-02-08 17:04:27 +00:00
|
|
|
describe 'ReferencesHandler', ->
|
2015-12-31 10:28:19 +00:00
|
|
|
|
2016-01-26 14:29:23 +00:00
|
|
|
beforeEach ->
|
2016-01-26 16:14:17 +00:00
|
|
|
@projectId = '222'
|
|
|
|
@fakeProject =
|
|
|
|
_id: @projectId
|
|
|
|
owner_ref: @fakeOwner =
|
|
|
|
_id: 'some_owner'
|
|
|
|
features:
|
|
|
|
references: false
|
|
|
|
rootFolder: [
|
|
|
|
docs: [
|
|
|
|
{name: 'one.bib', _id: 'aaa'},
|
|
|
|
{name: 'two.txt', _id: 'bbb'},
|
|
|
|
]
|
|
|
|
folders: [
|
2016-05-19 13:58:12 +00:00
|
|
|
{
|
|
|
|
docs: [{name: 'three.bib', _id: 'ccc'}],
|
|
|
|
fileRefs: [{name: 'four.bib', _id: 'ghg'}],
|
|
|
|
folders: []
|
|
|
|
}
|
2016-01-26 16:14:17 +00:00
|
|
|
]
|
|
|
|
]
|
|
|
|
@docIds = ['aaa', 'ccc']
|
2016-01-26 14:29:23 +00:00
|
|
|
@handler = SandboxedModule.require modulePath, requires:
|
|
|
|
'logger-sharelatex': {
|
|
|
|
log: ->
|
|
|
|
err: ->
|
|
|
|
}
|
|
|
|
'settings-sharelatex': @settings = {
|
|
|
|
apis:
|
2016-01-27 09:58:54 +00:00
|
|
|
references: {url: 'http://some.url/references'}
|
|
|
|
docstore: {url: 'http://some.url/docstore'}
|
2016-05-19 13:58:12 +00:00
|
|
|
filestore: {url: 'http://some.url/filestore'}
|
2016-01-26 14:29:23 +00:00
|
|
|
}
|
|
|
|
'request': @request = {
|
|
|
|
get: sinon.stub()
|
|
|
|
post: sinon.stub()
|
|
|
|
}
|
2016-03-18 11:43:39 +00:00
|
|
|
'../Project/ProjectGetter': @ProjectGetter = {
|
|
|
|
getProject: sinon.stub().callsArgWith(2, null, @fakeProject)
|
2016-01-26 14:29:23 +00:00
|
|
|
}
|
2016-03-18 11:43:39 +00:00
|
|
|
'../User/UserGetter': @UserGetter = {
|
|
|
|
getUser: sinon.stub()
|
2016-03-08 14:05:56 +00:00
|
|
|
}
|
2016-01-27 13:33:42 +00:00
|
|
|
'../DocumentUpdater/DocumentUpdaterHandler': @DocumentUpdaterHandler = {
|
|
|
|
flushDocToMongo: sinon.stub().callsArgWith(2, null)
|
|
|
|
}
|
2016-01-26 16:14:17 +00:00
|
|
|
@fakeResponseData =
|
|
|
|
projectId: @projectId
|
|
|
|
keys: ['k1', 'k2']
|
|
|
|
|
|
|
|
describe 'index', ->
|
|
|
|
|
|
|
|
beforeEach ->
|
|
|
|
sinon.stub(@handler, '_findBibDocIds')
|
2016-05-19 13:58:12 +00:00
|
|
|
sinon.stub(@handler, '_findBibFileIds')
|
2016-01-26 16:14:17 +00:00
|
|
|
sinon.stub(@handler, '_isFullIndex').callsArgWith(1, null, true)
|
|
|
|
@request.post.callsArgWith(1, null, {statusCode: 200}, @fakeResponseData)
|
|
|
|
@call = (callback) =>
|
|
|
|
@handler.index @projectId, @docIds, callback
|
|
|
|
|
|
|
|
describe 'with docIds as an array', ->
|
|
|
|
|
|
|
|
beforeEach ->
|
|
|
|
@docIds = ['aaa', 'ccc']
|
|
|
|
|
|
|
|
it 'should not call _findBibDocIds', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
@handler._findBibDocIds.callCount.should.equal 0
|
|
|
|
done()
|
|
|
|
|
2016-03-18 11:43:39 +00:00
|
|
|
it 'should call ProjectGetter.getProject', (done) ->
|
2016-01-26 16:14:17 +00:00
|
|
|
@call (err, data) =>
|
2016-03-18 11:43:39 +00:00
|
|
|
@ProjectGetter.getProject.callCount.should.equal 1
|
|
|
|
@ProjectGetter.getProject.calledWith(@projectId).should.equal true
|
2016-01-26 16:14:17 +00:00
|
|
|
done()
|
|
|
|
|
2016-01-27 16:00:53 +00:00
|
|
|
it 'should not call _findBibDocIds', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
@handler._findBibDocIds.callCount.should.equal 0
|
|
|
|
done()
|
|
|
|
|
2016-01-27 13:33:42 +00:00
|
|
|
it 'should call DocumentUpdaterHandler.flushDocToMongo', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
@DocumentUpdaterHandler.flushDocToMongo.callCount.should.equal 2
|
|
|
|
@docIds.forEach (docId) =>
|
|
|
|
@DocumentUpdaterHandler.flushDocToMongo.calledWith(@projectId, docId).should.equal true
|
|
|
|
done()
|
|
|
|
|
2016-01-26 16:14:17 +00:00
|
|
|
it 'should make a request to references service', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
@request.post.callCount.should.equal 1
|
|
|
|
arg = @request.post.firstCall.args[0]
|
|
|
|
expect(arg.json).to.have.all.keys 'docUrls', 'fullIndex'
|
|
|
|
expect(arg.json.docUrls.length).to.equal 2
|
|
|
|
expect(arg.json.fullIndex).to.equal true
|
|
|
|
done()
|
|
|
|
|
|
|
|
it 'should not produce an error', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
expect(err).to.equal null
|
|
|
|
done()
|
|
|
|
|
|
|
|
it 'should return data', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
expect(data).to.not.equal null
|
|
|
|
expect(data).to.not.equal undefined
|
|
|
|
expect(data).to.equal @fakeResponseData
|
|
|
|
done()
|
|
|
|
|
2016-03-18 11:43:39 +00:00
|
|
|
describe 'when ProjectGetter.getProject produces an error', ->
|
2016-01-26 16:14:17 +00:00
|
|
|
|
|
|
|
beforeEach ->
|
2016-03-18 11:43:39 +00:00
|
|
|
@ProjectGetter.getProject.callsArgWith(2, new Error('woops'))
|
2016-01-26 16:14:17 +00:00
|
|
|
|
|
|
|
it 'should produce an error', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
expect(err).to.not.equal null
|
|
|
|
expect(err).to.be.instanceof Error
|
|
|
|
expect(data).to.equal undefined
|
|
|
|
done()
|
|
|
|
|
|
|
|
it 'should not send request', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
@request.post.callCount.should.equal 0
|
|
|
|
done()
|
|
|
|
|
|
|
|
describe 'when _isFullIndex produces an error', ->
|
|
|
|
|
|
|
|
beforeEach ->
|
2016-03-18 11:43:39 +00:00
|
|
|
@ProjectGetter.getProject.callsArgWith(2, null, @fakeProject)
|
2016-01-26 16:14:17 +00:00
|
|
|
@handler._isFullIndex.callsArgWith(1, new Error('woops'))
|
|
|
|
|
|
|
|
it 'should produce an error', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
expect(err).to.not.equal null
|
|
|
|
expect(err).to.be.instanceof Error
|
|
|
|
expect(data).to.equal undefined
|
|
|
|
done()
|
|
|
|
|
|
|
|
it 'should not send request', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
@request.post.callCount.should.equal 0
|
|
|
|
done()
|
|
|
|
|
2016-01-27 13:33:42 +00:00
|
|
|
describe 'when flushDocToMongo produces an error', ->
|
|
|
|
|
|
|
|
beforeEach ->
|
2016-03-18 11:43:39 +00:00
|
|
|
@ProjectGetter.getProject.callsArgWith(2, null, @fakeProject)
|
2016-01-27 13:33:42 +00:00
|
|
|
@handler._isFullIndex.callsArgWith(1, false)
|
|
|
|
@DocumentUpdaterHandler.flushDocToMongo.callsArgWith(2, new Error('woops'))
|
|
|
|
|
|
|
|
it 'should produce an error', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
expect(err).to.not.equal null
|
|
|
|
expect(err).to.be.instanceof Error
|
|
|
|
expect(data).to.equal undefined
|
|
|
|
done()
|
|
|
|
|
|
|
|
it 'should not send request', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
@request.post.callCount.should.equal 0
|
|
|
|
done()
|
|
|
|
|
|
|
|
|
2016-01-26 16:14:17 +00:00
|
|
|
describe 'when request produces an error', ->
|
|
|
|
|
|
|
|
beforeEach ->
|
2016-03-18 11:43:39 +00:00
|
|
|
@ProjectGetter.getProject.callsArgWith(2, null, @fakeProject)
|
2016-01-26 16:14:17 +00:00
|
|
|
@handler._isFullIndex.callsArgWith(1, null, false)
|
2016-01-27 13:33:42 +00:00
|
|
|
@DocumentUpdaterHandler.flushDocToMongo.callsArgWith(2, null)
|
2016-01-26 16:14:17 +00:00
|
|
|
@request.post.callsArgWith(1, new Error('woops'))
|
2016-01-26 14:29:23 +00:00
|
|
|
|
2016-01-26 16:14:17 +00:00
|
|
|
it 'should produce an error', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
expect(err).to.not.equal null
|
|
|
|
expect(err).to.be.instanceof Error
|
|
|
|
expect(data).to.equal undefined
|
|
|
|
done()
|
|
|
|
|
|
|
|
describe 'when request responds with error status', ->
|
|
|
|
|
|
|
|
beforeEach ->
|
2016-03-18 11:43:39 +00:00
|
|
|
@ProjectGetter.getProject.callsArgWith(2, null, @fakeProject)
|
2016-01-26 16:14:17 +00:00
|
|
|
@handler._isFullIndex.callsArgWith(1, null, false)
|
|
|
|
@request.post.callsArgWith(1, null, {statusCode: 500}, null)
|
|
|
|
|
|
|
|
it 'should produce an error', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
expect(err).to.not.equal null
|
|
|
|
expect(err).to.be.instanceof Error
|
|
|
|
expect(data).to.equal undefined
|
|
|
|
done()
|
2016-01-26 14:29:23 +00:00
|
|
|
|
2016-01-27 16:00:53 +00:00
|
|
|
describe 'indexAll', ->
|
|
|
|
|
|
|
|
beforeEach ->
|
|
|
|
sinon.stub(@handler, '_findBibDocIds').returns(['aaa', 'ccc'])
|
2016-05-19 13:58:12 +00:00
|
|
|
sinon.stub(@handler, '_findBibFileIds').returns(['fff', 'ggg'])
|
2016-01-27 16:00:53 +00:00
|
|
|
sinon.stub(@handler, '_isFullIndex').callsArgWith(1, null, true)
|
|
|
|
@request.post.callsArgWith(1, null, {statusCode: 200}, @fakeResponseData)
|
|
|
|
@call = (callback) =>
|
|
|
|
@handler.indexAll @projectId, callback
|
|
|
|
|
|
|
|
it 'should call _findBibDocIds', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
@handler._findBibDocIds.callCount.should.equal 1
|
|
|
|
@handler._findBibDocIds.calledWith(@fakeProject).should.equal true
|
|
|
|
done()
|
|
|
|
|
2016-05-19 13:58:12 +00:00
|
|
|
it 'should call _findBibFileIds', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
@handler._findBibDocIds.callCount.should.equal 1
|
|
|
|
@handler._findBibDocIds.calledWith(@fakeProject).should.equal true
|
|
|
|
done()
|
|
|
|
|
2016-01-27 16:00:53 +00:00
|
|
|
it 'should call DocumentUpdaterHandler.flushDocToMongo', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
@DocumentUpdaterHandler.flushDocToMongo.callCount.should.equal 2
|
|
|
|
done()
|
|
|
|
|
|
|
|
it 'should make a request to references service', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
@request.post.callCount.should.equal 1
|
|
|
|
arg = @request.post.firstCall.args[0]
|
|
|
|
expect(arg.json).to.have.all.keys 'docUrls', 'fullIndex'
|
2016-05-19 13:58:12 +00:00
|
|
|
expect(arg.json.docUrls.length).to.equal 4
|
2016-01-27 16:00:53 +00:00
|
|
|
expect(arg.json.fullIndex).to.equal true
|
|
|
|
done()
|
|
|
|
|
|
|
|
it 'should not produce an error', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
expect(err).to.equal null
|
|
|
|
done()
|
|
|
|
|
|
|
|
it 'should return data', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
expect(data).to.not.equal null
|
|
|
|
expect(data).to.not.equal undefined
|
|
|
|
expect(data).to.equal @fakeResponseData
|
|
|
|
done()
|
|
|
|
|
2016-03-18 11:43:39 +00:00
|
|
|
describe 'when ProjectGetter.getProject produces an error', ->
|
2016-01-27 16:03:40 +00:00
|
|
|
|
|
|
|
beforeEach ->
|
2016-03-18 11:43:39 +00:00
|
|
|
@ProjectGetter.getProject.callsArgWith(2, new Error('woops'))
|
2016-01-27 16:03:40 +00:00
|
|
|
|
|
|
|
it 'should produce an error', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
expect(err).to.not.equal null
|
|
|
|
expect(err).to.be.instanceof Error
|
|
|
|
expect(data).to.equal undefined
|
|
|
|
done()
|
|
|
|
|
|
|
|
it 'should not send request', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
@request.post.callCount.should.equal 0
|
|
|
|
done()
|
|
|
|
|
|
|
|
describe 'when _isFullIndex produces an error', ->
|
|
|
|
|
|
|
|
beforeEach ->
|
2016-03-18 11:43:39 +00:00
|
|
|
@ProjectGetter.getProject.callsArgWith(2, null, @fakeProject)
|
2016-01-27 16:03:40 +00:00
|
|
|
@handler._isFullIndex.callsArgWith(1, new Error('woops'))
|
|
|
|
|
|
|
|
it 'should produce an error', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
expect(err).to.not.equal null
|
|
|
|
expect(err).to.be.instanceof Error
|
|
|
|
expect(data).to.equal undefined
|
|
|
|
done()
|
|
|
|
|
|
|
|
it 'should not send request', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
@request.post.callCount.should.equal 0
|
|
|
|
done()
|
|
|
|
|
|
|
|
describe 'when flushDocToMongo produces an error', ->
|
|
|
|
|
|
|
|
beforeEach ->
|
2016-03-18 11:43:39 +00:00
|
|
|
@ProjectGetter.getProject.callsArgWith(2, null, @fakeProject)
|
2016-01-27 16:03:40 +00:00
|
|
|
@handler._isFullIndex.callsArgWith(1, false)
|
|
|
|
@DocumentUpdaterHandler.flushDocToMongo.callsArgWith(2, new Error('woops'))
|
|
|
|
|
|
|
|
it 'should produce an error', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
expect(err).to.not.equal null
|
|
|
|
expect(err).to.be.instanceof Error
|
|
|
|
expect(data).to.equal undefined
|
|
|
|
done()
|
|
|
|
|
|
|
|
it 'should not send request', (done) ->
|
|
|
|
@call (err, data) =>
|
|
|
|
@request.post.callCount.should.equal 0
|
|
|
|
done()
|
|
|
|
|
2016-01-27 16:00:53 +00:00
|
|
|
|
2016-01-26 14:29:23 +00:00
|
|
|
describe '_findBibDocIds', ->
|
|
|
|
|
|
|
|
beforeEach ->
|
|
|
|
@fakeProject =
|
|
|
|
rootFolder: [
|
|
|
|
docs: [
|
|
|
|
{name: 'one.bib', _id: 'aaa'},
|
|
|
|
{name: 'two.txt', _id: 'bbb'},
|
|
|
|
]
|
|
|
|
folders: [
|
|
|
|
{docs: [{name: 'three.bib', _id: 'ccc'}], folders: []}
|
|
|
|
]
|
|
|
|
]
|
|
|
|
@expectedIds = ['aaa', 'ccc']
|
|
|
|
|
|
|
|
it 'should select the correct docIds', ->
|
|
|
|
result = @handler._findBibDocIds(@fakeProject)
|
|
|
|
expect(result).to.deep.equal @expectedIds
|
|
|
|
|
2016-08-02 14:28:53 +00:00
|
|
|
it 'should not error with a non array of folders from dirty data', ->
|
|
|
|
@fakeProject.rootFolder[0].folders[0].folders = {}
|
|
|
|
result = @handler._findBibDocIds(@fakeProject)
|
|
|
|
expect(result).to.deep.equal @expectedIds
|
|
|
|
|
2016-05-19 13:58:12 +00:00
|
|
|
describe '_findBibFileIds', ->
|
|
|
|
|
|
|
|
beforeEach ->
|
|
|
|
@fakeProject =
|
|
|
|
rootFolder: [
|
|
|
|
docs: [
|
|
|
|
{name: 'one.bib', _id: 'aaa'},
|
|
|
|
{name: 'two.txt', _id: 'bbb'},
|
|
|
|
]
|
|
|
|
fileRefs: [
|
|
|
|
{name: 'other.bib', _id: 'ddd'}
|
|
|
|
],
|
|
|
|
folders: [
|
|
|
|
{
|
|
|
|
docs: [{name: 'three.bib', _id: 'ccc'}],
|
|
|
|
fileRefs: [{name: 'four.bib', _id: 'ghg'}],
|
|
|
|
folders: []
|
|
|
|
}
|
|
|
|
]
|
|
|
|
]
|
|
|
|
@expectedIds = ['ddd', 'ghg']
|
|
|
|
|
|
|
|
it 'should select the correct docIds', ->
|
|
|
|
result = @handler._findBibFileIds(@fakeProject)
|
|
|
|
expect(result).to.deep.equal @expectedIds
|
|
|
|
|
2016-01-26 14:29:23 +00:00
|
|
|
describe '_isFullIndex', ->
|
|
|
|
|
|
|
|
beforeEach ->
|
|
|
|
@fakeProject =
|
2016-03-08 14:05:56 +00:00
|
|
|
owner_ref: @owner_ref = "owner-ref-123"
|
|
|
|
@owner =
|
|
|
|
features:
|
|
|
|
references: false
|
2016-03-18 11:43:39 +00:00
|
|
|
@UserGetter.getUser = sinon.stub()
|
|
|
|
@UserGetter.getUser.withArgs(@owner_ref, {features: true}).yields(null, @owner)
|
2016-01-26 14:29:23 +00:00
|
|
|
@call = (callback) =>
|
|
|
|
@handler._isFullIndex @fakeProject, callback
|
|
|
|
|
|
|
|
describe 'with references feature on', ->
|
|
|
|
|
|
|
|
beforeEach ->
|
2016-03-08 14:05:56 +00:00
|
|
|
@owner.features.references = true
|
2016-01-26 14:29:23 +00:00
|
|
|
|
|
|
|
it 'should return true', ->
|
|
|
|
@call (err, isFullIndex) =>
|
|
|
|
expect(err).to.equal null
|
|
|
|
expect(isFullIndex).to.equal true
|
|
|
|
|
|
|
|
describe 'with references feature off', ->
|
|
|
|
|
|
|
|
beforeEach ->
|
2016-03-08 14:05:56 +00:00
|
|
|
@owner.features.references = false
|
2016-01-26 14:29:23 +00:00
|
|
|
|
|
|
|
it 'should return false', ->
|
|
|
|
@call (err, isFullIndex) =>
|
|
|
|
expect(err).to.equal null
|
|
|
|
expect(isFullIndex).to.equal false
|