mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-21 20:47:08 -05:00
Merge pull request #16918 from overleaf/dp-mongoose-callback-referal-handler
Promisify ReferalHandler and ReferalHandlerTests GitOrigin-RevId: b73eda0063b04227a0d58d8e9bd0dea1ff6f0af1
This commit is contained in:
parent
72eeb5a9ee
commit
144e22c209
3 changed files with 75 additions and 74 deletions
|
@ -6,7 +6,7 @@ module.exports = {
|
||||||
const userId = SessionManager.getLoggedInUserId(req.session)
|
const userId = SessionManager.getLoggedInUserId(req.session)
|
||||||
ReferalHandler.getReferedUsers(
|
ReferalHandler.getReferedUsers(
|
||||||
userId,
|
userId,
|
||||||
(err, referedUsers, referedUserCount) => {
|
(err, { referedUsers, referedUserCount }) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
next(err)
|
next(err)
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -1,15 +1,17 @@
|
||||||
|
const { callbackify } = require('@overleaf/promise-utils')
|
||||||
const { User } = require('../../models/User')
|
const { User } = require('../../models/User')
|
||||||
|
|
||||||
|
async function getReferedUsers(userId) {
|
||||||
|
const projection = { refered_users: 1, refered_user_count: 1 }
|
||||||
|
const user = await User.findById(userId, projection).exec()
|
||||||
|
const referedUsers = user.refered_users || []
|
||||||
|
const referedUserCount = user.refered_user_count || referedUsers.length
|
||||||
|
return { referedUsers, referedUserCount }
|
||||||
|
}
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
getReferedUsers(userId, callback) {
|
getReferedUsers: callbackify(getReferedUsers),
|
||||||
const projection = { refered_users: 1, refered_user_count: 1 }
|
promises: {
|
||||||
User.findById(userId, projection, function (err, user) {
|
getReferedUsers,
|
||||||
if (err) {
|
|
||||||
return callback(err)
|
|
||||||
}
|
|
||||||
const referedUsers = user.refered_users || []
|
|
||||||
const referedUserCount = user.refered_user_count || referedUsers.length
|
|
||||||
callback(null, referedUsers, referedUserCount)
|
|
||||||
})
|
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,7 +8,11 @@ const modulePath = require('path').join(
|
||||||
|
|
||||||
describe('Referal handler', function () {
|
describe('Referal handler', function () {
|
||||||
beforeEach(function () {
|
beforeEach(function () {
|
||||||
this.User = { findById: sinon.stub() }
|
this.User = {
|
||||||
|
findById: sinon.stub().returns({
|
||||||
|
exec: sinon.stub(),
|
||||||
|
}),
|
||||||
|
}
|
||||||
this.handler = SandboxedModule.require(modulePath, {
|
this.handler = SandboxedModule.require(modulePath, {
|
||||||
requires: {
|
requires: {
|
||||||
'../../models/User': {
|
'../../models/User': {
|
||||||
|
@ -20,73 +24,68 @@ describe('Referal handler', function () {
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('getting refered user_ids', function () {
|
describe('getting refered user_ids', function () {
|
||||||
it('should get the user from mongo and return the refered users array', function (done) {
|
it('should get the user from mongo and return the refered users array', async function () {
|
||||||
const user = {
|
const user = {
|
||||||
refered_users: ['1234', '312312', '3213129'],
|
refered_users: ['1234', '312312', '3213129'],
|
||||||
refered_user_count: 3,
|
refered_user_count: 3,
|
||||||
}
|
}
|
||||||
this.User.findById.callsArgWith(2, null, user)
|
this.User.findById.returns({
|
||||||
|
exec: sinon.stub().resolves(user),
|
||||||
this.handler.getReferedUsers(
|
|
||||||
this.user_id,
|
|
||||||
(err, passedReferedUserIds, passedReferedUserCount) => {
|
|
||||||
expect(err).not.to.exist
|
|
||||||
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) => {
|
|
||||||
expect(err).not.to.exist
|
|
||||||
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) => {
|
|
||||||
expect(err).not.to.exist
|
|
||||||
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) => {
|
|
||||||
expect(err).not.to.exist
|
|
||||||
passedReferedUserCount.should.equal(3)
|
|
||||||
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()
|
|
||||||
})
|
})
|
||||||
|
|
||||||
|
const {
|
||||||
|
referedUsers: passedReferedUserIds,
|
||||||
|
referedUserCount: passedReferedUserCount,
|
||||||
|
} = await this.handler.promises.getReferedUsers(this.user_id)
|
||||||
|
|
||||||
|
passedReferedUserIds.should.deep.equal(user.refered_users)
|
||||||
|
passedReferedUserCount.should.equal(3)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should return an empty array if it is not set', async function () {
|
||||||
|
const user = {}
|
||||||
|
this.User.findById.returns({
|
||||||
|
exec: sinon.stub().resolves(user),
|
||||||
|
})
|
||||||
|
|
||||||
|
const { referedUsers: passedReferedUserIds } =
|
||||||
|
await this.handler.promises.getReferedUsers(this.user_id)
|
||||||
|
|
||||||
|
passedReferedUserIds.length.should.equal(0)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should return a zero count if neither it or the array are set', async function () {
|
||||||
|
const user = {}
|
||||||
|
this.User.findById.returns({
|
||||||
|
exec: sinon.stub().resolves(user),
|
||||||
|
})
|
||||||
|
|
||||||
|
const { referedUserCount: passedReferedUserCount } =
|
||||||
|
await this.handler.promises.getReferedUsers(this.user_id)
|
||||||
|
|
||||||
|
passedReferedUserCount.should.equal(0)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should return the array length if count is not set', async function () {
|
||||||
|
const user = { refered_users: ['1234', '312312', '3213129'] }
|
||||||
|
this.User.findById.returns({
|
||||||
|
exec: sinon.stub().resolves(user),
|
||||||
|
})
|
||||||
|
|
||||||
|
const { referedUserCount: passedReferedUserCount } =
|
||||||
|
await this.handler.promises.getReferedUsers(this.user_id)
|
||||||
|
|
||||||
|
passedReferedUserCount.should.equal(3)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should error if finding the user fails', async function () {
|
||||||
|
this.User.findById.returns({
|
||||||
|
exec: sinon.stub().rejects(new Error('user not found')),
|
||||||
|
})
|
||||||
|
|
||||||
|
expect(
|
||||||
|
this.handler.promises.getReferedUsers(this.user_id)
|
||||||
|
).to.be.rejectedWith('user not found')
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
Loading…
Reference in a new issue