refactored server-side tests
This commit is contained in:
parent
3f02a67686
commit
5798f5aa95
|
@ -136,7 +136,7 @@ var UserSchema = new Schema({
|
|||
unique: true,
|
||||
index: true,
|
||||
sparse: true
|
||||
},
|
||||
}
|
||||
});
|
||||
|
||||
UserSchema.virtual('displayName').get(function () {
|
||||
|
|
|
@ -16,13 +16,13 @@ module.exports = function(app) {
|
|||
.get(core.redoc);
|
||||
|
||||
if(!config.subdomainsDisabled) {
|
||||
app.route('/subdomain/:userSlug((?!api$)[A-Za-z0-9]+)/')
|
||||
app.route('/subdomain/:userSubdomain((?!api$)[A-Za-z0-9]+)/')
|
||||
.get(core.form);
|
||||
|
||||
app.route('/subdomain/:userSlug((?!api$)[A-Za-z0-9]+)/forms/:formId([a-zA-Z0-9]+)')
|
||||
app.route('/subdomain/:userSubdomain((?!api$)[A-Za-z0-9]+)/forms/:formId([a-zA-Z0-9]+)')
|
||||
.post(forms.createSubmission);
|
||||
|
||||
app.route('/subdomain/:userSlug((?!api$)[A-Za-z0-9]+)/forms/:formId([a-zA-Z0-9]+)/render')
|
||||
app.route('/subdomain/:userSubdomain((?!api$)[A-Za-z0-9]+)/forms/:formId([a-zA-Z0-9]+)/render')
|
||||
.get(forms.readForRender);
|
||||
} else {
|
||||
app.route('/view/')
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
'use strict';
|
||||
process.env.NODE_ENV = 'test';
|
||||
|
||||
var should = require('should'),
|
||||
lodash = require('lodash'),
|
||||
|
@ -14,7 +15,14 @@ var should = require('should'),
|
|||
/**
|
||||
* Globals
|
||||
*/
|
||||
var credentials, user, myForm, userSession;
|
||||
var user, myForm, userSession;
|
||||
|
||||
// Create user credentials
|
||||
var credentials = {
|
||||
username: 'test1234',
|
||||
email: 'test1234@test.com',
|
||||
password: 'password'
|
||||
};
|
||||
|
||||
/**
|
||||
* Form routes tests
|
||||
|
@ -23,13 +31,6 @@ describe('Form Routes Unit tests', function() {
|
|||
|
||||
beforeEach(function(done) {
|
||||
|
||||
// Create user credentials
|
||||
credentials = {
|
||||
username: 'test',
|
||||
email: 'test@test.com',
|
||||
password: 'password'
|
||||
};
|
||||
|
||||
// Create a new user
|
||||
user = new User({
|
||||
firstName: 'Full',
|
||||
|
@ -52,7 +53,8 @@ describe('Form Routes Unit tests', function() {
|
|||
new Field({'fieldType':'textfield', 'title':'First Name', 'fieldValue': ''}),
|
||||
new Field({'fieldType':'checkbox', 'title':'nascar', 'fieldValue': ''}),
|
||||
new Field({'fieldType':'checkbox', 'title':'hockey', 'fieldValue': ''})
|
||||
]
|
||||
],
|
||||
isLive: true
|
||||
};
|
||||
|
||||
//Initialize Session
|
||||
|
@ -62,52 +64,6 @@ describe('Form Routes Unit tests', function() {
|
|||
});
|
||||
});
|
||||
|
||||
it(' > should be able to upload a PDF to Form if signed in', function(done) {
|
||||
userSession.post('/auth/signin')
|
||||
.send(credentials)
|
||||
.expect('Content-Type', /json/)
|
||||
.expect(200)
|
||||
.end(function(signinErr, signinRes) {
|
||||
|
||||
// Handle signin error
|
||||
if (signinErr) return done(signinErr);
|
||||
|
||||
var user = signinRes.body;
|
||||
var userId = user._id;
|
||||
|
||||
// Save a new Form
|
||||
userSession.post('/forms')
|
||||
.send({form: myForm})
|
||||
.expect('Content-Type', /json/)
|
||||
.expect(200)
|
||||
.end(function(FormSaveErr, FormSaveRes) {
|
||||
// Handle Form save error
|
||||
if (FormSaveErr) return done(FormSaveErr);
|
||||
|
||||
// Get a list of Forms
|
||||
userSession.get('/forms')
|
||||
.expect('Content-Type', /json/)
|
||||
.expect(200)
|
||||
.end(function(FormsGetErr, FormsGetRes) {
|
||||
// Handle Form save error
|
||||
if (FormsGetErr) return done(FormsGetErr);
|
||||
|
||||
// Get Forms list
|
||||
var Forms = FormsGetRes.body;
|
||||
|
||||
// Set assertions
|
||||
(Forms[0].admin).should.equal(userId);
|
||||
(Forms[0].title).should.match('Form Title');
|
||||
|
||||
// Call the assertion callback
|
||||
done();
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
});
|
||||
});
|
||||
|
||||
it(' > should not be able to create a Form if not logged in', function(done) {
|
||||
userSession.post('/forms')
|
||||
.send({form: myForm})
|
||||
|
@ -127,71 +83,6 @@ describe('Form Routes Unit tests', function() {
|
|||
});
|
||||
});
|
||||
|
||||
it(' > should not be able to save a Form if no title is provided', function(done) {
|
||||
// Set Form with a invalid title field
|
||||
myForm.title = '';
|
||||
|
||||
userSession.post('/auth/signin')
|
||||
.send(credentials)
|
||||
.expect('Content-Type', /json/)
|
||||
.expect(200)
|
||||
.end(function(signinErr, signinRes) {
|
||||
should.not.exist(signinErr);
|
||||
|
||||
// Save a new Form
|
||||
userSession.post('/forms')
|
||||
.send({form: myForm})
|
||||
.expect(400)
|
||||
.end(function(FormSaveErr, FormSaveRes) {
|
||||
// Set message assertion
|
||||
(FormSaveRes.body.message).should.equal('Form Title cannot be blank');
|
||||
|
||||
done();
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
it(' > should be able to update a Form if signed in', function(done) {
|
||||
userSession.post('/auth/signin')
|
||||
.send(credentials)
|
||||
.expect('Content-Type', /json/)
|
||||
.expect(200)
|
||||
.end(function(signinErr, signinRes) {
|
||||
// Handle signin error
|
||||
if (signinErr) return done(signinErr);
|
||||
|
||||
// Save a new Form
|
||||
userSession.post('/forms')
|
||||
.send({form: myForm})
|
||||
.expect('Content-Type', /json/)
|
||||
.expect(200)
|
||||
.end(function(FormSaveErr, FormSaveRes) {
|
||||
// Handle Form save error
|
||||
if (FormSaveErr) return done(FormSaveErr);
|
||||
|
||||
// Update Form title
|
||||
myForm.title = 'WHY YOU GOTTA BE SO MEAN?';
|
||||
|
||||
// Update an existing Form
|
||||
userSession.put('/forms/' + FormSaveRes.body._id)
|
||||
.send({form: myForm})
|
||||
.expect('Content-Type', /json/)
|
||||
.expect(200)
|
||||
.end(function(FormUpdateErr, FormUpdateRes) {
|
||||
// Handle Form update error
|
||||
if (FormUpdateErr) done(FormUpdateErr);
|
||||
|
||||
// Set assertions
|
||||
(FormUpdateRes.body._id).should.equal(FormSaveRes.body._id);
|
||||
(FormUpdateRes.body.title).should.match('WHY YOU GOTTA BE SO MEAN?');
|
||||
|
||||
// Call the assertion callback
|
||||
done();
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
it(' > should be able to read/get a Form if not signed in', function(done) {
|
||||
// Create new Form model instance
|
||||
var FormObj = new Form(myForm);
|
||||
|
@ -200,8 +91,7 @@ describe('Form Routes Unit tests', function() {
|
|||
FormObj.save(function(err, form) {
|
||||
if(err) return done(err);
|
||||
|
||||
userSession.get('/forms/' + form._id)
|
||||
.expect('Content-Type', /json/)
|
||||
userSession.get('/subdomain/' + credentials.username + '/forms/' + form._id + '/render')
|
||||
.expect(200)
|
||||
.end(function(err, res) {
|
||||
if(err) return done(err)
|
||||
|
@ -215,46 +105,6 @@ describe('Form Routes Unit tests', function() {
|
|||
});
|
||||
});
|
||||
|
||||
it(' > should be able to delete a Form if signed in', function(done) {
|
||||
|
||||
userSession.post('/auth/signin')
|
||||
.send(credentials)
|
||||
.expect('Content-Type', /json/)
|
||||
.expect(200)
|
||||
.end(function(signinErr, signinRes) {
|
||||
// Handle signin error
|
||||
if (signinErr) return done(signinErr);
|
||||
|
||||
// Save a new Form
|
||||
userSession.post('/forms')
|
||||
.send({form: myForm})
|
||||
.expect('Content-Type', /json/)
|
||||
.expect(200)
|
||||
.end(function(FormSaveErr, FormSaveRes) {
|
||||
// Handle Form save error
|
||||
if (FormSaveErr) return done(FormSaveErr);
|
||||
|
||||
// Delete an existing Form
|
||||
userSession.delete('/forms/' + FormSaveRes.body._id)
|
||||
.send(myForm)
|
||||
.expect('Content-Type', /json/)
|
||||
.expect(200)
|
||||
.end(function(FormDeleteErr, FormDeleteRes) {
|
||||
// Handle Form error error
|
||||
if (FormDeleteErr) return done(FormDeleteErr);
|
||||
|
||||
// Set assertions
|
||||
should.exist(FormDeleteRes.body);
|
||||
// (FormDeleteRes.body._id).should.equal(FormSaveRes.body._id);
|
||||
|
||||
// Call the assertion callback
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
});
|
||||
});
|
||||
|
||||
it(' > should not be able to delete an Form if not signed in', function(done) {
|
||||
// Set Form user
|
||||
myForm.admin = user;
|
||||
|
@ -276,57 +126,159 @@ describe('Form Routes Unit tests', function() {
|
|||
});
|
||||
});
|
||||
|
||||
describe(' > Login as User', function() {
|
||||
//Initialize Session
|
||||
var authenticatedSession;
|
||||
var loginSession = Session(app);
|
||||
|
||||
describe(' > Login and Save a new Form >', function() {
|
||||
var _user, _form, _userSession = Session(app);
|
||||
it('should be able to login as user', function(done){
|
||||
_userSession.post('/auth/signin')
|
||||
beforeEach(function(done) {
|
||||
loginSession.post('/auth/signin')
|
||||
.send(credentials)
|
||||
.expect('Content-Type', /json/)
|
||||
.expect(200)
|
||||
.end(function(signinErr, signinRes) {
|
||||
if(signinErr) {
|
||||
return done(signinErr);
|
||||
}
|
||||
|
||||
// Handle signin error
|
||||
if (signinErr) return done(signinErr);
|
||||
authenticatedSession = loginSession;
|
||||
return done();
|
||||
});
|
||||
});
|
||||
|
||||
_user = signinRes.body;
|
||||
// Save a new Form
|
||||
_userSession.post('/forms')
|
||||
.send({form: myForm})
|
||||
.expect('Content-Type', /json/)
|
||||
.expect(200)
|
||||
.end(function(FormSaveErr, FormSaveRes) {
|
||||
// Handle Form save error
|
||||
if (FormSaveErr) return done(FormSaveErr);
|
||||
_form = FormSaveRes.body;
|
||||
it(' > should not be able to save a Form if no title is provided', function(done) {
|
||||
// Set Form with a invalid title field
|
||||
myForm.title = '';
|
||||
|
||||
// Get a list of Forms
|
||||
_userSession.get('/forms/'+_form._id)
|
||||
.expect('Content-Type', /json/)
|
||||
.expect(200)
|
||||
.end(function(FormsGetErr, FormsGetRes) {
|
||||
// Handle Form save error
|
||||
if (FormsGetErr) return done(FormsGetErr);
|
||||
// Save a new Form
|
||||
authenticatedSession.post('/forms')
|
||||
.send({form: myForm})
|
||||
.expect(405)
|
||||
.end(function(FormSaveErr, FormSaveRes) {
|
||||
// Handle Form save error
|
||||
if (FormSaveErr) {
|
||||
return done(FormSaveErr);
|
||||
}
|
||||
|
||||
var fetchedForm = FormsGetRes.body;
|
||||
// Set assertions
|
||||
(fetchedForm.admin._id).should.equal(_user._id);
|
||||
(fetchedForm.title).should.match(_form.title);
|
||||
// Set message assertion
|
||||
(FormSaveRes.body.message).should.equal('Form Title cannot be blank');
|
||||
|
||||
// Call the assertion callback
|
||||
done();
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
after('should be able to signout user', function(done){
|
||||
userSession.get('/auth/signout')
|
||||
.end(function(signoutErr, signoutRes) {
|
||||
done();
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
it(' > should be able to update a Form if signed in', function(done) {
|
||||
|
||||
// Save a new Form
|
||||
loginSession.post('/forms')
|
||||
.send({form: myForm})
|
||||
.expect('Content-Type', /json/)
|
||||
.expect(200)
|
||||
.end(function(FormSaveErr, FormSaveRes) {
|
||||
// Handle Form save error
|
||||
if (FormSaveErr) {
|
||||
return done(FormSaveErr);
|
||||
}
|
||||
|
||||
// Update Form title
|
||||
myForm.title = 'WHY YOU GOTTA BE SO MEAN?';
|
||||
|
||||
// Update an existing Form
|
||||
loginSession.put('/forms/' + FormSaveRes.body._id)
|
||||
.send({form: myForm})
|
||||
.expect('Content-Type', /json/)
|
||||
.expect(200)
|
||||
.end(function(FormUpdateErr, FormUpdateRes) {
|
||||
// Handle Form update error
|
||||
if (FormUpdateErr){
|
||||
done(FormUpdateErr);
|
||||
}
|
||||
|
||||
// Set assertions
|
||||
(FormUpdateRes.body._id).should.equal(FormSaveRes.body._id);
|
||||
(FormUpdateRes.body.title).should.match('WHY YOU GOTTA BE SO MEAN?');
|
||||
|
||||
// Call the assertion callback
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
it(' > should be able to delete a Form if signed in', function(done) {
|
||||
|
||||
// Save a new Form
|
||||
loginSession.post('/forms')
|
||||
.send({form: myForm})
|
||||
.expect('Content-Type', /json/)
|
||||
.expect(200)
|
||||
.end(function(FormSaveErr, FormSaveRes) {
|
||||
// Handle Form save error
|
||||
if (FormSaveErr) {
|
||||
return done(FormSaveErr);
|
||||
}
|
||||
|
||||
// Delete an existing Form
|
||||
loginSession.delete('/forms/' + FormSaveRes.body._id)
|
||||
.send(myForm)
|
||||
.expect('Content-Type', /json/)
|
||||
.expect(200)
|
||||
.end(function(FormDeleteErr, FormDeleteRes) {
|
||||
// Handle Form error error
|
||||
if (FormDeleteErr) {
|
||||
return done(FormDeleteErr);
|
||||
}
|
||||
|
||||
// Set assertions
|
||||
should.exist(FormDeleteRes.body);
|
||||
(FormDeleteRes.body._id).should.equal(FormSaveRes.body._id);
|
||||
|
||||
// Call the assertion callback
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
it('should be able to save new form while logged in', function(done){
|
||||
// Save a new Form
|
||||
authenticatedSession.post('/forms')
|
||||
.send({form: myForm})
|
||||
.expect('Content-Type', /json/)
|
||||
.expect(200)
|
||||
.end(function(FormSaveErr, FormSaveRes) {
|
||||
// Handle Form save error
|
||||
if (FormSaveErr) return done(FormSaveErr);
|
||||
var _form = FormSaveRes.body;
|
||||
|
||||
// Get a list of Forms
|
||||
authenticatedSession.get('/forms/'+_form._id)
|
||||
.expect('Content-Type', /json/)
|
||||
.expect(200)
|
||||
.end(function(FormsGetErr, FormsGetRes) {
|
||||
// Handle Form save error
|
||||
if (FormsGetErr) return done(FormsGetErr);
|
||||
|
||||
var fetchedForm = FormsGetRes.body;
|
||||
// Set assertions
|
||||
(fetchedForm.admin.email).should.equal(user.email);
|
||||
(fetchedForm.title).should.match(_form.title);
|
||||
|
||||
// Call the assertion callback
|
||||
done();
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
afterEach('should be able to signout user', function(done){
|
||||
authenticatedSession.get('/auth/signout')
|
||||
.expect(200)
|
||||
.end(function(signoutErr, signoutRes) {
|
||||
// Handle signout error
|
||||
if (signoutErr) return done(signoutErr);
|
||||
_userSession.destroy();
|
||||
done();
|
||||
authenticatedSession.destroy();
|
||||
done();
|
||||
});
|
||||
});
|
||||
});
|
||||
|
|
|
@ -37,7 +37,7 @@ describe('User CRUD tests', function() {
|
|||
_User = {
|
||||
email: credentials.email,
|
||||
username: credentials.username,
|
||||
password: credentials.password,
|
||||
password: credentials.password
|
||||
};
|
||||
|
||||
//Initialize Session
|
||||
|
@ -101,9 +101,7 @@ describe('User CRUD tests', function() {
|
|||
});
|
||||
|
||||
});
|
||||
|
||||
it(' > should be able to reset a User\'s password');
|
||||
|
||||
|
||||
afterEach(function(done) {
|
||||
User.remove().exec(function () {
|
||||
tmpUser.remove().exec(function(){
|
||||
|
|
2
config/env/all.js
vendored
2
config/env/all.js
vendored
|
@ -58,7 +58,7 @@ module.exports = {
|
|||
secure: false,
|
||||
// Only set the maxAge to null if the cookie shouldn't be expired
|
||||
// at all. The cookie will expunge when the browser is closed.
|
||||
maxAge: 24 * 60 * 60 * 1000, // 24 hours
|
||||
maxAge: 24 * 60 * 60 * 1000 // 24 hours
|
||||
// To set the cookie in a specific domain uncomment the following
|
||||
// setting:
|
||||
//domain: process.env.COOKIE_SESSION_URL || process.env.BASE_URL || '.tellform.com'
|
||||
|
|
5
config/env/test.js
vendored
5
config/env/test.js
vendored
|
@ -1,7 +1,7 @@
|
|||
'use strict';
|
||||
|
||||
module.exports = {
|
||||
baseUrl: 'http://localhost:3000',
|
||||
baseUrl: '127.0.0.1:3001',
|
||||
db: {
|
||||
uri: 'mongodb://localhost/mean-test',
|
||||
options: {
|
||||
|
@ -22,6 +22,9 @@ module.exports = {
|
|||
app: {
|
||||
title: 'TellForm Test'
|
||||
},
|
||||
sessionCookie: {
|
||||
maxAge: 24 * 60 * 60 * 1000 // 24 hours
|
||||
},
|
||||
facebook: {
|
||||
clientID: process.env.FACEBOOK_ID || 'APP_ID',
|
||||
clientSecret: process.env.FACEBOOK_SECRET || 'APP_SECRET',
|
||||
|
|
|
@ -5,7 +5,7 @@ var passport = require("passport");
|
|||
module.exports.isAuthenticatedOrApiKey = function isAuthenticated(req, res, next) {
|
||||
if (req.isAuthenticated()) {
|
||||
return next();
|
||||
}
|
||||
}
|
||||
// Try authenticate with API KEY
|
||||
if (req.headers.apikey || req.query.apikey || req.body.apikey) {
|
||||
passport.authenticate("localapikey", function (err, user, info) {
|
||||
|
@ -23,8 +23,9 @@ module.exports.isAuthenticatedOrApiKey = function isAuthenticated(req, res, next
|
|||
});
|
||||
|
||||
})(req, res, next);
|
||||
}
|
||||
return res.sendStatus(401);
|
||||
} else {
|
||||
return res.sendStatus(401);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
|
@ -32,7 +33,7 @@ module.exports.hasRole = function hasRole(roleRequired) {
|
|||
if (!roleRequired) {
|
||||
throw new Error("Required role needs to be set");
|
||||
}
|
||||
|
||||
|
||||
return function(req, res, next) {
|
||||
return module.exports.isAuthenticated(req, res, function() {
|
||||
if (req.user && req.user.roles && req.user.roles.indexOf(roleRequired) !== -1){
|
||||
|
|
Loading…
Reference in a new issue