2014-02-12 10:23:40 +00:00
|
|
|
sinon = require('sinon')
|
|
|
|
chai = require('chai')
|
|
|
|
should = chai.should()
|
|
|
|
expect = chai.expect
|
|
|
|
modulePath = "../../../../app/js/Features/Project/ProjectGetter.js"
|
|
|
|
SandboxedModule = require('sandboxed-module')
|
|
|
|
ObjectId = require("mongojs").ObjectId
|
2014-03-31 17:05:33 +00:00
|
|
|
assert = require("chai").assert
|
2014-02-12 10:23:40 +00:00
|
|
|
|
|
|
|
describe "ProjectGetter", ->
|
|
|
|
beforeEach ->
|
|
|
|
@callback = sinon.stub()
|
|
|
|
@ProjectGetter = SandboxedModule.require modulePath, requires:
|
|
|
|
"../../infrastructure/mongojs":
|
|
|
|
db: @db =
|
|
|
|
projects: {}
|
|
|
|
users: {}
|
|
|
|
ObjectId: ObjectId
|
2017-04-03 15:18:30 +00:00
|
|
|
"metrics-sharelatex": timeAsyncMethod: sinon.stub()
|
2016-03-03 17:19:03 +00:00
|
|
|
"../../models/Project": Project: @Project = {}
|
|
|
|
"../Collaborators/CollaboratorsHandler": @CollaboratorsHandler = {}
|
2016-02-29 19:01:46 +00:00
|
|
|
"logger-sharelatex":
|
|
|
|
err:->
|
|
|
|
log:->
|
2014-02-12 10:23:40 +00:00
|
|
|
|
|
|
|
describe "getProjectWithoutDocLines", ->
|
|
|
|
beforeEach ->
|
|
|
|
@project =
|
2016-02-29 17:34:38 +00:00
|
|
|
_id: @project_id = "56d46b0a1d3422b87c5ebcb1"
|
2014-02-12 10:23:40 +00:00
|
|
|
@db.projects.find = sinon.stub().callsArgWith(2, null, [@project])
|
|
|
|
|
2016-02-29 17:34:38 +00:00
|
|
|
describe "passing an id", ->
|
|
|
|
beforeEach ->
|
|
|
|
@ProjectGetter.getProjectWithoutDocLines @project_id, @callback
|
|
|
|
|
|
|
|
it "should call find with the project id", ->
|
2017-02-27 13:54:57 +00:00
|
|
|
expect(@db.projects.find.lastCall.args[0]).to.deep.equal {
|
|
|
|
_id: ObjectId(@project_id)
|
|
|
|
}
|
2016-02-29 17:34:38 +00:00
|
|
|
|
|
|
|
it "should exclude the doc lines", ->
|
|
|
|
excludes =
|
|
|
|
"rootFolder.docs.lines": 0
|
|
|
|
"rootFolder.folder.docs.lines": 0
|
|
|
|
"rootFolder.folder.folder.docs.lines": 0
|
|
|
|
"rootFolder.folder.folder.folder.docs.lines": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.docs.lines": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.folder.docs.lines": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.folder.folder.docs.lines": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.folder.folder.folder.docs.lines": 0
|
|
|
|
@db.projects.find.calledWith(sinon.match.any, excludes)
|
|
|
|
.should.equal true
|
|
|
|
|
|
|
|
it "should call the callback with the project", ->
|
|
|
|
@callback.calledWith(null, @project).should.equal true
|
|
|
|
|
2014-02-12 10:23:40 +00:00
|
|
|
|
2015-10-21 15:56:06 +00:00
|
|
|
describe "getProjectWithOnlyFolders", ->
|
2016-03-09 11:16:27 +00:00
|
|
|
|
|
|
|
beforeEach ()->
|
2015-10-21 15:56:06 +00:00
|
|
|
@project =
|
2016-03-09 11:16:27 +00:00
|
|
|
_id: @project_id = "56d46b0a1d3422b87c5ebcb1"
|
|
|
|
@db.projects.find = sinon.stub().callsArgWith(2, null, [@project])
|
|
|
|
|
|
|
|
describe "passing an id", ->
|
2016-02-29 17:34:38 +00:00
|
|
|
beforeEach ->
|
2016-03-09 11:16:27 +00:00
|
|
|
@ProjectGetter.getProjectWithOnlyFolders @project_id, @callback
|
2016-02-29 17:34:38 +00:00
|
|
|
|
2016-03-09 11:16:27 +00:00
|
|
|
it "should call find with the project id", ->
|
2017-02-27 13:54:57 +00:00
|
|
|
expect(@db.projects.find.lastCall.args[0]).to.deep.equal {
|
|
|
|
_id: ObjectId(@project_id)
|
|
|
|
}
|
2016-03-09 11:16:27 +00:00
|
|
|
|
|
|
|
it "should exclude the docs and files linesaaaa", ->
|
|
|
|
excludes =
|
|
|
|
"rootFolder.docs": 0
|
|
|
|
"rootFolder.fileRefs": 0
|
|
|
|
"rootFolder.folder.docs": 0
|
|
|
|
"rootFolder.folder.fileRefs": 0
|
|
|
|
"rootFolder.folder.folder.docs": 0
|
|
|
|
"rootFolder.folder.folder.fileRefs": 0
|
|
|
|
"rootFolder.folder.folder.folder.docs": 0
|
|
|
|
"rootFolder.folder.folder.folder.fileRefs": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.docs": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.fileRefs": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.folder.docs": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.folder.fileRefs": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.folder.folder.docs": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.folder.folder.fileRefs": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.folder.folder.folder.docs": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.folder.folder.folder.fileRefs": 0
|
|
|
|
@db.projects.find.calledWith(sinon.match.any, excludes).should.equal true
|
2016-02-29 17:34:38 +00:00
|
|
|
|
|
|
|
it "should call the callback with the project", ->
|
|
|
|
@callback.calledWith(null, @project).should.equal true
|
|
|
|
|
2014-02-12 10:23:40 +00:00
|
|
|
|
2016-03-09 11:16:27 +00:00
|
|
|
|
|
|
|
describe "getProject", ->
|
2016-02-29 17:34:38 +00:00
|
|
|
beforeEach ()->
|
2015-10-21 15:56:06 +00:00
|
|
|
@project =
|
2016-02-29 17:34:38 +00:00
|
|
|
_id: @project_id = "56d46b0a1d3422b87c5ebcb1"
|
2015-10-21 15:56:06 +00:00
|
|
|
@db.projects.find = sinon.stub().callsArgWith(2, null, [@project])
|
2016-02-29 17:34:38 +00:00
|
|
|
|
|
|
|
describe "passing an id", ->
|
|
|
|
beforeEach ->
|
|
|
|
@ProjectGetter.getProjectWithOnlyFolders @project_id, @callback
|
|
|
|
|
|
|
|
it "should call find with the project id", ->
|
2017-02-27 13:54:57 +00:00
|
|
|
expect(@db.projects.find.lastCall.args[0]).to.deep.equal {
|
|
|
|
_id: ObjectId(@project_id)
|
|
|
|
}
|
2016-02-29 17:34:38 +00:00
|
|
|
|
|
|
|
it "should exclude the docs and files linesaaaa", ->
|
|
|
|
excludes =
|
|
|
|
"rootFolder.docs": 0
|
|
|
|
"rootFolder.fileRefs": 0
|
|
|
|
"rootFolder.folder.docs": 0
|
|
|
|
"rootFolder.folder.fileRefs": 0
|
|
|
|
"rootFolder.folder.folder.docs": 0
|
|
|
|
"rootFolder.folder.folder.fileRefs": 0
|
|
|
|
"rootFolder.folder.folder.folder.docs": 0
|
|
|
|
"rootFolder.folder.folder.folder.fileRefs": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.docs": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.fileRefs": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.folder.docs": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.folder.fileRefs": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.folder.folder.docs": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.folder.folder.fileRefs": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.folder.folder.folder.docs": 0
|
|
|
|
"rootFolder.folder.folder.folder.folder.folder.folder.folder.fileRefs": 0
|
|
|
|
@db.projects.find.calledWith(sinon.match.any, excludes).should.equal true
|
|
|
|
|
|
|
|
it "should call the callback with the project", ->
|
|
|
|
@callback.calledWith(null, @project).should.equal true
|
|
|
|
|
|
|
|
|
|
|
|
|
2016-03-09 11:16:27 +00:00
|
|
|
describe "getProject", ->
|
2016-02-29 17:34:38 +00:00
|
|
|
beforeEach ()->
|
|
|
|
@project =
|
|
|
|
_id: @project_id = "56d46b0a1d3422b87c5ebcb1"
|
2015-10-21 15:56:06 +00:00
|
|
|
@db.projects.find = sinon.stub().callsArgWith(2, null, [@project])
|
|
|
|
|
|
|
|
|
2016-03-03 17:19:03 +00:00
|
|
|
describe "findAllUsersProjects", ->
|
|
|
|
beforeEach ->
|
|
|
|
@fields = {"mock": "fields"}
|
|
|
|
@Project.find = sinon.stub()
|
|
|
|
@Project.find.withArgs({owner_ref: @user_id}, @fields).yields(null, ["mock-owned-projects"])
|
2017-09-20 12:16:50 +00:00
|
|
|
@CollaboratorsHandler.getProjectsUserIsMemberOf = sinon.stub()
|
2017-09-20 14:26:03 +00:00
|
|
|
@CollaboratorsHandler.getProjectsUserIsMemberOf.withArgs(@user_id, @fields).yields(
|
|
|
|
null,
|
|
|
|
{
|
2017-10-20 10:49:20 +00:00
|
|
|
readAndWrite: ["mock-rw-projects"],
|
|
|
|
readOnly: ["mock-ro-projects"],
|
|
|
|
tokenReadAndWrite: ['mock-token-rw-projects'],
|
|
|
|
tokenReadOnly: ['mock-token-ro-projects']
|
2017-09-20 14:26:03 +00:00
|
|
|
}
|
|
|
|
)
|
2016-03-03 17:19:03 +00:00
|
|
|
@ProjectGetter.findAllUsersProjects @user_id, @fields, @callback
|
|
|
|
|
|
|
|
it "should call the callback with all the projects", ->
|
|
|
|
@callback
|
2017-10-20 10:49:20 +00:00
|
|
|
.calledWith(null, {
|
|
|
|
owned: ["mock-owned-projects"],
|
|
|
|
readAndWrite: ["mock-rw-projects"],
|
|
|
|
readOnly: ["mock-ro-projects"]
|
|
|
|
tokenReadAndWrite: ['mock-token-rw-projects'],
|
|
|
|
tokenReadOnly: ['mock-token-ro-projects']
|
|
|
|
})
|
2016-03-03 17:19:03 +00:00
|
|
|
.should.equal true
|