mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-07 20:31:06 -05:00
5b40eca697
Added projection to User.find() queries in Referal feature GitOrigin-RevId: 4929bcd9c1b242b7e35cc2632bbd8da3f378cd1d
116 lines
3.3 KiB
JavaScript
116 lines
3.3 KiB
JavaScript
const SandboxedModule = require('sandboxed-module')
|
|
const should = require('chai').should()
|
|
const sinon = require('sinon')
|
|
const modulePath = require('path').join(
|
|
__dirname,
|
|
'../../../../app/src/Features/Referal/ReferalHandler.js'
|
|
)
|
|
|
|
describe('Referal handler', function() {
|
|
beforeEach(function() {
|
|
this.User = { findById: sinon.stub() }
|
|
this.handler = SandboxedModule.require(modulePath, {
|
|
globals: {
|
|
console: console
|
|
},
|
|
requires: {
|
|
'logger-sharelatex': {
|
|
log() {},
|
|
err() {}
|
|
},
|
|
'../../models/User': {
|
|
User: this.User
|
|
}
|
|
}
|
|
})
|
|
this.user_id = '12313'
|
|
})
|
|
|
|
describe('getting refered user_ids', function() {
|
|
it('should get the user from mongo and return the refered users array', function(done) {
|
|
const user = {
|
|
refered_users: ['1234', '312312', '3213129'],
|
|
refered_user_count: 3
|
|
}
|
|
this.User.findById.callsArgWith(2, null, user)
|
|
|
|
this.handler.getReferedUsers(
|
|
this.user_id,
|
|
(err, passedReferedUserIds, passedReferedUserCount) => {
|
|
should.not.exist(err)
|
|
passedReferedUserIds.should.deep.equal(user.refered_users)
|
|
passedReferedUserCount.should.equal(3)
|
|
done()
|
|
}
|
|
)
|
|
})
|
|
|
|
it('should return an empty array if it is not set', function(done) {
|
|
const user = {}
|
|
this.User.findById.callsArgWith(2, null, user)
|
|
|
|
this.handler.getReferedUsers(
|
|
this.user_id,
|
|
(err, passedReferedUserIds, passedReferedUserCount) => {
|
|
should.not.exist(err)
|
|
passedReferedUserIds.length.should.equal(0)
|
|
done()
|
|
}
|
|
)
|
|
})
|
|
|
|
it('should return a zero count if neither it or the array are set', function(done) {
|
|
const user = {}
|
|
this.User.findById.callsArgWith(2, null, user)
|
|
|
|
this.handler.getReferedUsers(
|
|
this.user_id,
|
|
(err, passedReferedUserIds, passedReferedUserCount) => {
|
|
should.not.exist(err)
|
|
passedReferedUserCount.should.equal(0)
|
|
done()
|
|
}
|
|
)
|
|
})
|
|
|
|
it('should return the array length if count is not set', function(done) {
|
|
const user = { refered_users: ['1234', '312312', '3213129'] }
|
|
this.User.findById.callsArgWith(2, null, user)
|
|
|
|
this.handler.getReferedUsers(
|
|
this.user_id,
|
|
(err, passedReferedUserIds, passedReferedUserCount) => {
|
|
should.not.exist(err)
|
|
passedReferedUserCount.should.equal(3)
|
|
done()
|
|
}
|
|
)
|
|
})
|
|
|
|
it('should return the count if it differs from the array length', function(done) {
|
|
const user = {
|
|
refered_users: ['1234', '312312', '3213129'],
|
|
refered_user_count: 5
|
|
}
|
|
this.User.findById.callsArgWith(2, null, user)
|
|
|
|
this.handler.getReferedUsers(
|
|
this.user_id,
|
|
(err, passedReferedUserIds, passedReferedUserCount) => {
|
|
should.not.exist(err)
|
|
passedReferedUserCount.should.equal(5)
|
|
done()
|
|
}
|
|
)
|
|
})
|
|
|
|
it('should error if finding the user fails', function(done) {
|
|
this.User.findById.callsArgWith(2, new Error('user not found'))
|
|
|
|
this.handler.getReferedUsers(this.user_id, err => {
|
|
err.should.match(/user not found/)
|
|
done()
|
|
})
|
|
})
|
|
})
|
|
})
|