Newer
Older
Sebastian Mihalache
committed
process.env.NODE_TLS_REJECT_UNAUTHORIZED = '0'
process.env.SUPPRESS_NO_CONFIG_WARNING = true
const Chance = require('chance')
const cloneDeep = require('lodash/cloneDeep')
const fixturesService = require('pubsweet-component-fixture-service')
const requests = require('../requests')
const { Model, fixtures } = fixturesService
Sebastian Mihalache
committed
jest.mock('@pubsweet/component-send-email', () => ({
send: jest.fn(),
Sebastian Mihalache
committed
}))
Sebastian Mihalache
committed
Sebastian Mihalache
committed
const chance = new Chance()
const reqBody = {
email: chance.email(),
role: 'reviewer',
firstName: chance.first(),
lastName: chance.last(),
title: 'Mr',
affiliation: chance.company(),
admin: false,
Andrei Cioromila
committed
country: chance.country(),
Sebastian Mihalache
committed
}
const route = {
path: '/api/collections/:collectionId/fragments/:fragmentId/invitations',
}
const path = '../routes/fragmentsInvitations/post'
describe('Post fragments invitations route handler', () => {
let testFixtures = {}
let body = {}
let models
beforeEach(() => {
testFixtures = cloneDeep(fixtures)
body = cloneDeep(reqBody)
models = Model.build(testFixtures)
})
it('should return an error params are missing', async () => {
const { admin } = testFixtures.users
delete body.email
const res = await requests.sendRequest({
body,
userId: admin.id,
route,
models,
path,
})
expect(res.statusCode).toBe(400)
const data = JSON.parse(res._getData())
Andrei Cioromila
committed
expect(data.error).toEqual('Missing parameters.')
Sebastian Mihalache
committed
})
it('should return success when a reviewer is invited', async () => {
Sebastian Mihalache
committed
const { user, editorInChief } = testFixtures.users
const { collection } = testFixtures.collections
const { fragment } = testFixtures.fragments
Andrei Cioromila
committed
body = Object.assign(body, {
Sebastian Mihalache
committed
email: user.email,
role: 'reviewer',
Andrei Cioromila
committed
})
Sebastian Mihalache
committed
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
const res = await requests.sendRequest({
body,
userId: editorInChief.id,
route,
models,
path,
params: {
collectionId: collection.id,
fragmentId: fragment.id,
},
})
expect(res.statusCode).toBe(200)
const data = JSON.parse(res._getData())
expect(data.role).toEqual(body.role)
})
it('should return an error when inviting his self', async () => {
const { editorInChief } = testFixtures.users
body.email = editorInChief.email
const res = await requests.sendRequest({
body,
userId: editorInChief.id,
route,
models,
path,
})
expect(res.statusCode).toBe(400)
const data = JSON.parse(res._getData())
expect(data.error).toEqual('Cannot invite yourself.')
})
it('should return an error when the role is invalid', async () => {
const { editorInChief } = testFixtures.users
body.role = 'someRandomRole'
const res = await requests.sendRequest({
body,
userId: editorInChief.id,
route,
models,
path,
})
const data = JSON.parse(res._getData())
expect(data.error).toEqual(
`Role ${body.role} is invalid. Only reviewer is accepted.`,
)
})
it('should return an error when the invitation is already answered', async () => {
const { answerReviewer, handlingEditor } = testFixtures.users
const { collection } = testFixtures.collections
const { fragment } = testFixtures.fragments
Andrei Cioromila
committed
body = Object.assign(body, {
Sebastian Mihalache
committed
email: answerReviewer.email,
role: 'reviewer',
Andrei Cioromila
committed
})
Sebastian Mihalache
committed
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
const res = await requests.sendRequest({
body,
userId: handlingEditor.id,
route,
models,
path,
params: {
collectionId: collection.id,
fragmentId: fragment.id,
},
})
expect(res.statusCode).toBe(400)
const data = JSON.parse(res._getData())
expect(data.error).toEqual(
`User has already replied to a previous invitation.`,
)
})
it('should return an error when the user does not have invitation rights', async () => {
const { author } = testFixtures.users
const { collection } = testFixtures.collections
const { fragment } = testFixtures.fragments
const res = await requests.sendRequest({
body,
userId: author.id,
route,
models,
path,
params: {
collectionId: collection.id,
fragmentId: fragment.id,
},
})
expect(res.statusCode).toBe(403)
const data = JSON.parse(res._getData())
expect(data.error).toEqual('Unauthorized.')
})
it('should return an error when the invited user is inactive', async () => {
const { inactiveUser, handlingEditor } = testFixtures.users
const { collection } = testFixtures.collections
const { fragment } = testFixtures.fragments
Andrei Cioromila
committed
body = Object.assign(body, {
email: inactiveUser.email,
role: 'reviewer',
Andrei Cioromila
committed
})
const res = await requests.sendRequest({
body,
userId: handlingEditor.id,
route,
models,
path,
params: {
collectionId: collection.id,
fragmentId: fragment.id,
},
})
expect(res.statusCode).toBe(400)
const data = JSON.parse(res._getData())
expect(data.error).toEqual(`Invited user is inactive.`)
})