overleaf/services/web/test/acceptance/coffee/ProjectInviteTests.coffee

151 lines
4.2 KiB
CoffeeScript
Raw Normal View History

expect = require("chai").expect
Async = require("async")
User = require "./helpers/User"
request = require "./helpers/request"
settings = require "settings-sharelatex"
2016-07-28 11:00:18 -04:00
CollaboratorsEmailHandler = require "../../../app/js/Features/Collaborators/CollaboratorsEmailHandler"
2016-07-29 06:04:07 -04:00
createInvite = (projectId, sendingUser, email, callback=(err, invite)->) ->
2016-07-29 04:52:55 -04:00
sendingUser.getCsrfToken (err) ->
2016-07-28 11:00:18 -04:00
return callback(err) if err
2016-07-29 04:52:55 -04:00
sendingUser.request.post {
2016-07-28 11:00:18 -04:00
url: "/project/#{projectId}/invite",
json:
email: email
2016-07-29 06:04:07 -04:00
privileges: 'readAndWrite'
2016-07-28 11:00:18 -04:00
}, (err, response, body) ->
return callback(err) if err
callback(err, body.invite)
2016-07-29 06:04:07 -04:00
followInviteLink = (user, link, callback=(err, response, body)->) ->
user.request.get {
uri: link
baseUrl: null
}, callback
acceptInvite = (user, invite, callback=(err, response, body)->) ->
user.request.post {
uri: "/project/#{invite.projectId}/invite/#{invite._id}/accept"
json:
token: invite.token
}, callback
describe "ProjectInviteTests", ->
before (done) ->
@timeout(20000)
@sendingUser = new User()
@user = new User()
@site_admin = new User({email: "admin@example.com"})
2016-07-29 04:52:55 -04:00
@email = 'smoketestuser@example.com'
2016-07-28 11:00:18 -04:00
@projectName = 'sharing test'
@projectId = null
2016-07-28 11:00:18 -04:00
@fakeProject = null
Async.series [
(cb) => @user.login cb
(cb) => @sendingUser.login cb
2016-07-28 11:00:18 -04:00
(cb) => @sendingUser.createProject(@projectName, (err, projectId, project) =>
throw err if err
@projectId = projectId
2016-07-28 11:00:18 -04:00
@fakeProject = {
_id: projectId,
name: @projectName,
owner_ref: @sendingUser
}
cb()
)
], done
2016-07-28 11:00:18 -04:00
after (done) ->
Async.series [
(cb) => @sendingUser.deleteProject(@projectId, cb)
], done
describe "user is logged in", ->
beforeEach (done) ->
@user.login (err) =>
if err
throw err
done()
2016-07-29 04:52:55 -04:00
describe 'user is not a member of the project', ->
2016-07-28 11:00:18 -04:00
beforeEach (done) ->
@invite = null
@link = null
2016-07-29 06:04:07 -04:00
createInvite @projectId, @sendingUser, @email, (err, invite) =>
2016-07-28 11:00:18 -04:00
@invite = invite
@link = CollaboratorsEmailHandler._buildInviteUrl(@fakeProject, @invite)
done()
it 'should not grant access if the user does not accept the invite', (done) ->
Async.series(
[
# go to the invite page
(cb) =>
followInviteLink @user, @link, (err, response, body) =>
expect(err).to.be.oneOf [null, undefined]
expect(response.statusCode).to.equal 200
expect(body).to.match new RegExp("<title>Project Invite - .*</title>")
cb()
2016-07-29 06:54:08 -04:00
# forbid access to the project page
(cb) =>
@user.openProject @invite.projectId, (err) =>
expect(err).to.be.instanceof Error
cb()
], done
)
it 'should render the invalid-invite page if the token is invalid', (done) ->
Async.series(
[
# go to the invite page with an invalid token
(cb) =>
link = @link.replace(@invite.token, 'not_a_real_token')
followInviteLink @user, link, (err, response, body) =>
expect(err).to.be.oneOf [null, undefined]
expect(response.statusCode).to.equal 200
expect(body).to.match new RegExp("<title>Invalid Invite - .*</title>")
cb()
# forbid access to the project page
(cb) =>
@user.openProject @invite.projectId, (err) =>
expect(err).to.be.instanceof Error
cb()
], done
)
2016-07-29 06:04:07 -04:00
it 'should allow the user to accept the invite and access the project', (done) ->
Async.series(
[
2016-07-29 06:04:07 -04:00
# go to the invite page
(cb) =>
2016-07-29 06:04:07 -04:00
followInviteLink @user, @link, (err, response, body) =>
2016-07-29 04:52:55 -04:00
expect(err).to.be.oneOf [null, undefined]
expect(response.statusCode).to.equal 200
expect(body).to.match new RegExp("<title>Project Invite - .*</title>")
cb()
2016-07-29 06:04:07 -04:00
# accept the invite
(cb) =>
acceptInvite @user, @invite, (err, response, body) =>
expect(err).to.be.oneOf [null, undefined]
expect(response.statusCode).to.equal 302
expect(response.headers.location).to.equal "/project/#{@invite.projectId}"
cb()
# access the project page
(cb) =>
@user.openProject @invite.projectId, (err) =>
expect(err).to.be.oneOf [null, undefined]
cb()
], done
)