- Created all Tests with Mocha: User + Todo tables

This commit is contained in:
Paolo Arena
2019-02-07 00:52:48 +01:00
parent 779bd1cb63
commit 87378fe732
10 changed files with 309 additions and 150 deletions

View File

@@ -1,4 +1,4 @@
DATABASE =FreePlanet DATABASE=FreePlanet
SEND_EMAIL=1 SEND_EMAIL=1
PORT=3000 PORT=3000
URLBASE_APP1=https://freeplanet.app URLBASE_APP1=https://freeplanet.app

View File

@@ -1,11 +1,14 @@
var {User} = require('../models/user'); var {User} = require('../models/user');
const tools = require('../tools/general');
var authenticate = (req, res, next) => { var authenticate = (req, res, next) => {
var token = req.header('x-auth'); var token = req.header('x-auth');
// console.log("TOKEN = " + token); // console.log("TOKEN = " + token);
User.findByToken(token).then((user) => { User.findByToken(token).then((user) => {
// tools.mylogshow('userid', user._id)
if (!user) { if (!user) {
return Promise.reject(); return Promise.reject();
} }

View File

@@ -2,6 +2,7 @@ var mongoose = require('mongoose');
const _ = require('lodash'); const _ = require('lodash');
const tools = require('../tools/general');
mongoose.Promise = global.Promise; mongoose.Promise = global.Promise;
mongoose.level = "F"; mongoose.level = "F";
@@ -69,8 +70,7 @@ TodoSchema.methods.toJSON = function () {
// console.log(todoObject); // console.log(todoObject);
return _.pick(todoObject, ['_id', 'userId', 'pos', 'category', 'descr', 'priority', 'completed', 'created_at', 'modify_at', return _.pick(todoObject, tools.allfieldTodoWithId());
'completed_at', 'expiring_at', 'enableExpiring', 'id_prev', 'id_next', 'progress', 'modified']);
}; };

View File

@@ -2,6 +2,10 @@ const express = require('express');
const router = express.Router(); const router = express.Router();
const webpush = require('web-push'); const webpush = require('web-push');
const tools = require('../tools/general');
var server_constants = require('../tools/server_constants');
var { authenticate } = require('../middleware/authenticate'); var { authenticate } = require('../middleware/authenticate');
var mongoose = require('mongoose'); var mongoose = require('mongoose');
@@ -13,18 +17,27 @@ const _ = require('lodash');
const { ObjectID } = require('mongodb'); const { ObjectID } = require('mongodb');
const allfieldTodo = ['userId', 'pos', 'category', 'descr', 'priority', 'completed', 'created_at', 'modify_at',
'completed_at', 'expiring_at', 'enableExpiring', 'id_prev', 'id_next', 'progress', 'modified'];
const allfieldTodoWithId = ['_id', ...allfieldTodo];
router.post('/:id', authenticate, (req, res) => { router.post('/', authenticate, (req, res) => {
var body = _.pick(req.body, allfieldTodoWithId); var body = _.pick(req.body, tools.allfieldTodoWithId());
var todo = new Todo(body); var todo = new Todo(body);
console.log('POST ', todo.descr); // tools.mylogshow('ID :', todo._id)
// tools.mylogshow('userid', todo.userId, req.user._id)
if (!('descr' in req.body)){
return res.status(400).send({ code: server_constants.RIS_CODE_LOGIN_ERR_GENERIC });
}
if (todo.userId !== String(req.user._id)) {
// I'm trying to write something not mine!
return res.status(404).send({ code: server_constants.RIS_CODE_TODO_CREATING_NOTMYUSER });
}
tools.mylog('POST ', todo.descr);
todo.modified = false; todo.modified = false;
if (!todo.descr) { if (!todo.descr) {
@@ -34,6 +47,7 @@ router.post('/:id', authenticate, (req, res) => {
sendNotificationToUser(todo.userId, 'New Todo', 'New Todo added!', '/' + todo.category, 'todo'); sendNotificationToUser(todo.userId, 'New Todo', 'New Todo added!', '/' + todo.category, 'todo');
todo.save().then((doc) => { todo.save().then((doc) => {
// tools.mylogshow('ID SAVED :', doc._id)
res.send(doc); res.send(doc);
}).catch((e) => { }).catch((e) => {
console.log(e.message); console.log(e.message);
@@ -115,18 +129,24 @@ function sendNotificationToUser(userId, title, content, openUrl, tag) {
router.patch('/:id', authenticate, (req, res) => { router.patch('/:id', authenticate, (req, res) => {
var id = req.params.id; var id = req.params.id;
var body = _.pick(req.body, allfieldTodo); var body = _.pick(req.body, tools.allfieldTodo());
if (!ObjectID.isValid(id)) { if (!ObjectID.isValid(id)) {
console.log('ERROR: id not VALID', id); tools.mylog('ERROR: id not VALID', id);
return res.status(404).send(); return res.status(404).send();
} }
Todo.findByIdAndUpdate(id, {$set: body}, {new: true}).then((todo) => { Todo.findByIdAndUpdate(id, {$set: body}, {new: true}).then((todo) => {
if (!todo) { if (!todo) {
return res.status(404).send(); return res.status(404).send();
} }
if (todo.userId !== String(req.user._id)) {
// I'm trying to write something not mine!
return res.status(404).send({ code: server_constants.RIS_CODE_TODO_CREATING_NOTMYUSER });
}
todo.modified = false; todo.modified = false;
res.send({todo}); res.send({todo});
@@ -140,10 +160,20 @@ router.patch('/:id', authenticate, (req, res) => {
router.get('/:userId', authenticate, (req, res) => { router.get('/:userId', authenticate, (req, res) => {
var userId = req.params.userId; var userId = req.params.userId;
console.log('GET : ', req.params); // tools.mylogshow('GET : ', req.params);
if (!ObjectID.isValid(userId)) {
return res.status(404).send();
}
if (userId !== String(req.user._id)) {
// I'm trying to write something not mine!
return res.status(404).send({ code: server_constants.RIS_CODE_TODO_CREATING_NOTMYUSER });
}
// Extract all the todos of the userId only // Extract all the todos of the userId only
Todo.findAllByUserId(userId).then((todos) => { Todo.findAllByUserId(userId).then((todos) => {
// tools.mylogshow('todos', todos)
res.send({ todos }); res.send({ todos });
}).catch((e) => { }).catch((e) => {
console.log(e); console.log(e);

View File

@@ -5,6 +5,8 @@ var { User } = require('../models/user');
var sendemail = require('../sendemail'); var sendemail = require('../sendemail');
const tools = require('../tools/general');
var server_constants = require('../tools/server_constants'); var server_constants = require('../tools/server_constants');
const _ = require('lodash'); const _ = require('lodash');
@@ -13,30 +15,18 @@ var reg = require('../reg/registration');
var { authenticate } = require('../middleware/authenticate'); var { authenticate } = require('../middleware/authenticate');
function testing() {
return (process.env.TESTING_ON === '1')
}
function mylog(...args) {
if (!testing())
console.log(args)
}
function mylogshow(...args) {
console.log(args)
}
// POST /users // POST /users
router.post('/', (req, res) => { router.post('/', (req, res) => {
mylog("POST /users"); tools.mylog("POST /users");
var body = _.pick(req.body, ['email', 'password', 'username', 'idapp', 'keyappid', 'lang']); var body = _.pick(req.body, ['email', 'password', 'username', 'idapp', 'keyappid', 'lang']);
var user = new User(body); var user = new User(body);
// mylog("LANG PASSATO = " + user.lang, "IDAPP", user.idapp); // tools.mylog("LANG PASSATO = " + user.lang, "IDAPP", user.idapp);
user.linkreg = reg.getlinkregByEmail(body.email, body.username); user.linkreg = reg.getlinkregByEmail(body.email, body.username);
user.verified_email = false; user.verified_email = false;
if (testing()) { if (tools.testing()) {
user.verified_email = true; user.verified_email = true;
} }
@@ -44,7 +34,7 @@ router.post('/', (req, res) => {
User.findByUsername(user.username) User.findByUsername(user.username)
.then((usertrovato) => { .then((usertrovato) => {
mylog("TROVATO USERNAME ? ", user.username, usertrovato); tools.mylog("TROVATO USERNAME ? ", user.username, usertrovato);
if (usertrovato !== null) { if (usertrovato !== null) {
return user.generateAuthToken(); return user.generateAuthToken();
} else { } else {
@@ -52,13 +42,13 @@ router.post('/', (req, res) => {
return 0; return 0;
} }
}).then((token) => { }).then((token) => {
// mylog("passo il TOKEN: ", token); // tools.mylog("passo il TOKEN: ", token);
res.header('x-auth', token).send(user); res.header('x-auth', token).send(user);
// mylog("LINKREG = " + user.linkreg); // tools.mylog("LINKREG = " + user.linkreg);
// Invia un'email all'utente // Invia un'email all'utente
// mylog('process.env.TESTING_ON', process.env.TESTING_ON); // tools.mylog('process.env.TESTING_ON', process.env.TESTING_ON);
if (!testing()) { if (!tools.testing()) {
sendemail.sendEmail_Registration(res.locale, user.email, user.username, user.idapp, user.linkreg); sendemail.sendEmail_Registration(res.locale, user.email, user.username, user.idapp, user.linkreg);
} }
@@ -86,9 +76,9 @@ router.post('/login', (req, res) => {
var body = _.pick(req.body, ['username', 'password', 'idapp', 'keyappid', 'lang']); var body = _.pick(req.body, ['username', 'password', 'idapp', 'keyappid', 'lang']);
var user = new User(body); var user = new User(body);
mylogshow("username: " + user.username + " pwd = " + user.password); tools.mylog("username: " + user.username + " pwd = " + user.password);
mylogshow("user REC:", user); tools.mylog("user REC:", user);
if (body.keyappid !== process.env.KEY_APP_ID) if (body.keyappid !== process.env.KEY_APP_ID)
return res.status(400).send(); return res.status(400).send();
@@ -96,9 +86,9 @@ router.post('/login', (req, res) => {
User.findByCredentials(user.username, user.password) User.findByCredentials(user.username, user.password)
.then((user) => { .then((user) => {
mylogshow("CREDENZIALI ! "); tools.mylog("CREDENZIALI ! ");
if (!user) { if (!user) {
mylogshow("NOT FOUND !"); tools.mylogshow("NOT FOUND !");
res.status(404).send({ code: server_constants.RIS_CODE_LOGIN_ERR }); res.status(404).send({ code: server_constants.RIS_CODE_LOGIN_ERR });
} else { } else {
return user.generateAuthToken().then((token) => { return user.generateAuthToken().then((token) => {
@@ -108,23 +98,23 @@ router.post('/login', (req, res) => {
usertosend.userId = user._id.toHexString(); usertosend.userId = user._id.toHexString();
usertosend.verified_email = user.verified_email; usertosend.verified_email = user.verified_email;
// mylog("user.verified_email:" + user.verified_email); // tools.mylog("user.verified_email:" + user.verified_email);
// mylog("usertosend.userId", usertosend.userId); // tools.mylog("usertosend.userId", usertosend.userId);
// mylog("usertosend:"); // tools.mylog("usertosend:");
// mylog(usertosend); // tools.mylog(usertosend);
res.header('x-auth', token).send(usertosend); res.header('x-auth', token).send(usertosend);
// mylog("TROVATOOO!"); // tools.mylog("TROVATOOO!");
}); });
} }
}).catch((e) => { }).catch((e) => {
mylog("ERR: " + e); tools.mylog("ERR: " + e);
res.status(400).send({ code: server_constants.RIS_CODE_LOGIN_ERR_GENERIC }); res.status(400).send({ code: server_constants.RIS_CODE_LOGIN_ERR_GENERIC });
}); });
}); });
router.delete('/me/token', authenticate, (req, res) => { router.delete('/me/token', authenticate, (req, res) => {
mylog("TOKENREM = " + req.token); tools.mylog("TOKENREM = " + req.token);
req.user.removeToken(req.token).then(() => { req.user.removeToken(req.token).then(() => {
res.status(200).send(); res.status(200).send();
}, () => { }, () => {

View File

@@ -1,4 +1,4 @@
var tools = require('./tools/general'); const tools = require('./tools/general');
const Email = require('email-templates'); const Email = require('email-templates');
@@ -6,7 +6,7 @@ var i18n = require("i18n");
const previewEmail = require('preview-email'); const previewEmail = require('preview-email');
var nodemailer = require("nodemailer"); const nodemailer = require("nodemailer");
const transport_preview = nodemailer.createTransport({ const transport_preview = nodemailer.createTransport({
jsonTransport: true jsonTransport: true

View File

@@ -6,21 +6,26 @@ const { User } = require('./../../models/user');
var bcrypt = require('bcrypt'); var bcrypt = require('bcrypt');
const tools = require('../../tools/general');
let myuserIdOne = '';
const userOneId = new ObjectID(); const userOneId = new ObjectID();
const userTwoId = new ObjectID(); const userTwoId = new ObjectID();
const userThreeId = new ObjectID(); // const userThreeId = new ObjectID();
// let mypwdchiaro = 'mypassword@1A';
// let mypwdcrypt = bcrypt.hash(mypwdchiaro, bcrypt.genSaltSync(12)) // let mypwdcrypt = bcrypt.hash(mypwdchiaro, bcrypt.genSaltSync(12))
// .then((hashedPassword) => { // .then((hashedPassword) => {
// console.log('pwd=',hashedPassword); // console.log('pwd=',hashedPassword);
// }); // });
// String(mypwdcrypt) // String(mypwdcrypt)
let mypwdchiaro = 'mypassword@1A';
let mypwdcrypted = '$2b$12$mteST.isuWO0SNsfeZ0aCe.Dz3qwPh5SU8t9rc5SaPTkb3j0ywGv6' let mypwdcrypted = '$2b$12$mteST.isuWO0SNsfeZ0aCe.Dz3qwPh5SU8t9rc5SaPTkb3j0ywGv6'
const users = [ { const users = [{
_id: userTwoId, _id: userOneId,
keyappid: process.env.KEY_APP_ID, keyappid: process.env.KEY_APP_ID,
lang: 'it', lang: 'it',
idapp: '1', idapp: '1',
@@ -33,7 +38,7 @@ const users = [ {
}] }]
}, },
{ {
_id: userThreeId, _id: userTwoId,
keyappid: process.env.KEY_APP_ID, keyappid: process.env.KEY_APP_ID,
lang: 'it', lang: 'it',
idapp: '1', idapp: '1',
@@ -45,7 +50,7 @@ const users = [ {
token: jwt.sign({ _id: userTwoId, access: 'auth' }, process.env.SIGNCODE).toString() token: jwt.sign({ _id: userTwoId, access: 'auth' }, process.env.SIGNCODE).toString()
}] }]
}, { }, {
keyappid: process.env.KEY_APP_ID, keyappid: process.env.KEY_APP_ID, // RECORD CHE VERRA' UTILIZZATO PER UNA NUOVA REGISTRAZIONE
lang: 'it', lang: 'it',
idapp: '1', idapp: '1',
email: 'pao.loarena77@gmail.com', email: 'pao.loarena77@gmail.com',
@@ -60,35 +65,106 @@ const userjson = JSON.stringify(users[0]);
const todos = [{ const todos = [{
_id: new ObjectID(), _id: new ObjectID(),
text: 'First test todo', category: "personal",
_creator: userOneId completed: false,
completed_at: 0,
created_at: 6,
descr: "Primo Task Esempio",
enableExpiring: false,
expiring_at: 16,
id_next: "10000000",
id_prev: "0",
modified: false,
modify_at: 6,
pos: 1,
priority: 1,
progress: 0,
userId: users[0]._id
}, { }, {
_id: new ObjectID(), _id: new ObjectID(),
text: 'Second test todo', category: "personal",
completed: true, completed: false,
completedAt: 333, completed_at: 0,
_creator: userTwoId created_at: 6,
descr: "Secondo Task Esempio",
enableExpiring: false,
expiring_at: 16,
id_next: "10000000",
id_prev: "1",
modified: false,
modify_at: 6,
pos: 2,
priority: 1,
progress: 0,
userId: users[0]._id
}, {
_id: new ObjectID(),
category: "personal",
completed: false,
completed_at: 0,
created_at: 6,
descr: "Terzo Task Esempio",
enableExpiring: false,
expiring_at: 16,
id_next: "10000000",
id_prev: "1",
modified: false,
modify_at: 6,
pos: 3,
priority: 1,
progress: 0,
userId: users[1]._id
}, { // RECORD CHE VERRA' UTILIZZATO PER AGGIUNGERE UN NUOVO TASK
_id: new ObjectID(),
category: "personal",
completed: false,
completed_at: 0,
created_at: 6,
descr: "Nuovo Quarto Task Esempio da Inserire",
enableExpiring: false,
expiring_at: 16,
id_next: "10000000",
id_prev: "2",
modified: false,
modify_at: 6,
pos: 4,
priority: 1,
progress: 0,
userId: users[0]._id
}]; }];
const populateTodos = (done) => { const populateTodos = (done) => {
const lista = [ users[0]._id, users[1]._id, users[2]._id];
Todo.deleteMany({ userId: {$in: lista } }) Todo.deleteMany({})
.then(() => { .then(() => {
return Todo.insertMany(todos);
}).then(() => done()) var TodoOne = new Todo(todos[0]).save();
var TodoTwo = new Todo(todos[1]).save();
return Promise.all([TodoOne, TodoTwo])
}).then(() => {
done()
// tools.mylogshow('todos[0]', todos[0]._id);
// tools.mylogshow('todos[1]', todos[1]._id);
});
}; };
const populateUsers = (done) => { const populateUsers = (done) => {
const lista = [ users[0].username, users[1].username, users[2].username];
// const lista = [ "aa"] User.deleteMany({})
User.deleteMany({ username: {$in: lista } })
.then(() => { .then(() => {
// console.log('users[0]', users[0])
var userOne = new User(users[0]).save(); var userOne = new User(users[0]).save();
var userTwo = new User(users[1]).save(); var userTwo = new User(users[1]).save();
return Promise.all([userOne, userTwo]) return Promise.all([userOne, userTwo])
}).then(() => done()); }).then(() => done());
}; };
module.exports = { todos, populateTodos, users, populateUsers, userjson, mypwdcrypted }; module.exports = { todos, populateTodos, users, populateUsers, userjson, mypwdcrypted, mypwdchiaro };

View File

@@ -5,7 +5,9 @@ const { ObjectID } = require('mongodb');
const { app } = require('./../server'); const { app } = require('./../server');
const { Todo } = require('./../models/todo'); const { Todo } = require('./../models/todo');
const { User } = require('./../models/user'); const { User } = require('./../models/user');
const { todos, populateTodos, users, populateUsers, userjson } = require('./seed/seed'); const { todos, populateTodos, users, populateUsers, userjson, mypwdcrypted, mypwdchiaro } = require('./seed/seed');
const tools = require('../tools/general');
// const { debug } = require('debug'); // const { debug } = require('debug');
// const log = debug('server'); // const log = debug('server');
@@ -23,6 +25,8 @@ beforeEach(populateUsers);
beforeEach(populateTodos); beforeEach(populateTodos);
const IndexUserToCreate = 2; const IndexUserToCreate = 2;
const IndexTodoToCreate = 3;
// console.log('UserOne:', users[0]); // console.log('UserOne:', users[0]);
// console.log('UserTwo:', users[0]); // console.log('UserTwo:', users[0]);
@@ -98,7 +102,7 @@ describe('POST /users/login', () => {
.set('x-auth', users[0].tokens[0].token) .set('x-auth', users[0].tokens[0].token)
.send({ .send({
username: users[0].username, username: users[0].username,
password: users[0].password, password: mypwdchiaro,
idapp: users[0].idapp, idapp: users[0].idapp,
keyappid: users[0].keyappid, keyappid: users[0].keyappid,
lang: users[0].lang, lang: users[0].lang,
@@ -121,13 +125,13 @@ describe('POST /users/login', () => {
}).catch((e) => done(e)); }).catch((e) => done(e));
}); });
}); });
/*
it('should reject invalid login', (done) => { it('should reject invalid login', (done) => {
request(app) request(app)
.post('/users/login') .post('/users/login')
.send({ .send({
email: users[1].email, username: users[0].username,
password: users[1].password + '1' password: mypwdchiaro + '1'
}) })
.expect(400) .expect(400)
.expect((res) => { .expect((res) => {
@@ -144,42 +148,78 @@ describe('POST /users/login', () => {
}).catch((e) => done(e)); }).catch((e) => done(e));
}); });
}); });
*/
}); });
describe('DELETE /users/me/token', () => {
it('should logout user deleting auth token', (done) => {
describe('POST /todos', () => {
/*
it('should create a new Todos', (done) => {
request(app) request(app)
.post('/todos') .delete('/users/me/token')
.set('x-auth', users[0].tokens[0].token) .set('x-auth', users[0].tokens[0].token)
.send(users[0]) .send()
.expect(200) .expect(200)
.expect((res) => { .expect((res) => {
expect(res.body.text).toBe(text); expect(res.headers['x-auth']).toNotExist();
}) })
.end((err, res) => { .end((err, res) => {
if (err) { if (err) {
return done(err); return done(err);
} }
Todo.find({ text }).then((todos) => { done();
expect(todos.length).toBe(1); });
expect(todos[0].text).toBe(text); });
it('should return 401 deleting an invalid token', (done) => {
request(app)
.delete('/users/me/token')
.set('x-auth', users[0].tokens[0].token + '1')
.send()
.expect(401)
.end((err, res) => {
if (err) {
return done(err);
}
done();
});
});
});
describe('POST /todos', () => {
it('should create a new Todos', (done) => {
request(app)
.post('/todos')
.set('x-auth', users[0].tokens[0].token)
.send(todos[IndexTodoToCreate])
.expect(200)
.end((err, res) => {
if (err) {
return done(err);
}
Todo.find({ descr: todos[IndexTodoToCreate].descr }).then((arr_todos) => {
expect(arr_todos.length).toBe(1);
expect(arr_todos[0].descr).toBe(todos[IndexTodoToCreate].descr);
expect(String(arr_todos[0]._id)).toBe(String(todos[IndexTodoToCreate]._id));
expect(String(arr_todos[0].userId)).toBe(String(users[0]._id));
done(); done();
}).catch((e) => done(e)); }).catch((e) => done(e));
}); });
}); });
*/
})
/* it('should return 404 if not authenticated', (done) => {
request(app)
.post('/todos')
.set('x-auth', users[0].tokens[0].token)
.send(todos[IndexTodoToCreate])
.expect(404)
.end((err) => {
done();
});
});
it('should not create todo with invalid body data', (done) => { it('should not create todo with invalid body data', (done) => {
request(app) request(app)
@@ -193,7 +233,6 @@ describe('POST /todos', () => {
} }
Todo.find().then((todos) => { Todo.find().then((todos) => {
expect(todos.length).toBe(2);
done(); done();
}).catch((e) => done(e)); }).catch((e) => done(e));
}); });
@@ -203,43 +242,50 @@ describe('POST /todos', () => {
describe('GET /todos', () => { describe('GET /todos', () => {
it('should get all todos', (done) => { it('should get all todos', (done) => {
request(app) request(app)
.get('/todos') .get(`/todos/${users[0]._id }`)
.set('x-auth', users[0].tokens[0].token) .set('x-auth', users[0].tokens[0].token)
.expect(200) .expect(200)
.expect((res) => { .expect((res) => {
expect(res.body.todos.length).toBe(1); expect(res.body.todos.length).toBe(2);
}) })
.end(done); .end(done);
}); });
}); });
describe('GET /todos/:id', () => { describe('GET /todos/:id', () => {
it('should return todo doc', (done) => { it('should return todos of the User', (done) => {
request(app) request(app)
.get(`/todos/${todos[0]._id.toHexString()}`) .get(`/todos/${todos[0].userId}`)
.set('x-auth', users[0].tokens[0].token) .set('x-auth', users[0].tokens[0].token)
.expect(200) .expect(200)
.expect((res) => { .expect((res) => {
expect(res.body.todo.text).toBe(todos[0].text); let miores = res
let miadescr = miores.body.todos[0].descr
expect(res.body.todos.length).toBe(2);
expect(miadescr).toBe(todos[0].descr);
}) })
.end(done); .end(done);
}); });
it('should not return todo doc created by other user', (done) => { it('should not return todo doc created by other user', (done) => {
request(app) request(app)
.get(`/todos/${todos[1]._id.toHexString()}`) .get(`/todos/${todos[2].userId}`)
.set('x-auth', users[0].tokens[0].token) .set('x-auth', users[0].tokens[0].token)
.expect(404) .expect(404)
.end(done); .end(done);
}); });
it('should return 404 if todo not found', (done) => { it('should return [] if user not found', (done) => {
var hexId = new ObjectID().toHexString(); var hexId = new ObjectID().toHexString();
request(app) request(app)
.get(`/todos/${hexId}`) .get(`/todos/${users[0]._id + '111'}`)
.set('x-auth', users[0].tokens[0].token) .set('x-auth', users[0].tokens[0].token)
.expect(404) .expect(404)
.expect((res) => {
expect(res.body.todos).toBe(undefined);
})
.end(done); .end(done);
}); });
@@ -254,11 +300,11 @@ describe('GET /todos/:id', () => {
describe('DELETE /todos/:id', () => { describe('DELETE /todos/:id', () => {
it('should remove a todo', (done) => { it('should remove a todo', (done) => {
var hexId = todos[1]._id.toHexString(); var hexId = todos[0]._id.toHexString();
request(app) request(app)
.delete(`/todos/${hexId}`) .delete(`/todos/${hexId}`)
.set('x-auth', users[1].tokens[0].token) .set('x-auth', users[0].tokens[0].token)
.expect(200) .expect(200)
.expect((res) => { .expect((res) => {
expect(res.body.todo._id).toBe(hexId); expect(res.body.todo._id).toBe(hexId);
@@ -275,31 +321,12 @@ describe('DELETE /todos/:id', () => {
}); });
}); });
it('should remove a todo', (done) => {
var hexId = todos[0]._id.toHexString();
request(app)
.delete(`/todos/${hexId}`)
.set('x-auth', users[1].tokens[0].token)
.expect(404)
.end((err, res) => {
if (err) {
return done(err);
}
Todo.findById(hexId).then((todo) => {
expect(todo).toExist();
done();
}).catch((e) => done(e));
});
});
it('should return 404 if todo not found', (done) => { it('should return 404 if todo not found', (done) => {
var hexId = new ObjectID().toHexString(); var hexId = new ObjectID().toHexString();
request(app) request(app)
.delete(`/todos/${hexId}`) .delete(`/todos/${hexId}`)
.set('x-auth', users[1].tokens[0].token) .set('x-auth', users[0].tokens[0].token)
.expect(404) .expect(404)
.end(done); .end(done);
}); });
@@ -307,7 +334,7 @@ describe('DELETE /todos/:id', () => {
it('should return 404 if object id is invalid', (done) => { it('should return 404 if object id is invalid', (done) => {
request(app) request(app)
.delete('/todos/123abc') .delete('/todos/123abc')
.set('x-auth', users[1].tokens[0].token) .set('x-auth', users[0].tokens[0].token)
.expect(404) .expect(404)
.end(done); .end(done);
}); });
@@ -316,60 +343,68 @@ describe('DELETE /todos/:id', () => {
describe('PATCH /todos/:id', () => { describe('PATCH /todos/:id', () => {
it('should update the todo', (done) => { it('should update the todo', (done) => {
var hexId = todos[0]._id.toHexString(); var hexId = todos[0]._id.toHexString();
var text = 'This should be the new text'; var descr = 'This should be the new text';
request(app) request(app)
.patch(`/todos/${hexId}`) .patch(`/todos/${hexId}`)
.set('x-auth', users[0].tokens[0].token) .set('x-auth', users[0].tokens[0].token)
.send({ .send({
completed: true, completed: true,
text descr
}) })
.expect(200) .expect(200)
.expect((res) => { .expect((res) => {
expect(res.body.todo.text).toBe(text); expect(res.body.todo.descr).toBe(descr);
expect(res.body.todo.completed).toBe(true); expect(res.body.todo.completed).toBe(true);
expect(res.body.todo.completedAt).toBeA('number'); // expect(res.body.todo.completedAt).toBeA('number');
}) })
.end(done); .end(done);
}); });
it('should not update the todo created by other user', (done) => { it('should not update the todo created by other user', (done) => {
var hexId = todos[0]._id.toHexString(); var hexId = todos[0]._id.toHexString();
var text = 'This should be the new text'; var descr = 'This should be the new text';
request(app) request(app)
.patch(`/todos/${hexId}`) .patch(`/todos/${hexId}`)
.set('x-auth', users[1].tokens[0].token) .set('x-auth', users[1].tokens[0].token)
.send({ .send({
completed: true, completed: true,
text descr
}) })
.expect(404) .expect(404)
.end(done); .end(done);
}); });
it('should clear completedAt when todo is not completed', (done) => { // it('should clear completedAt when todo is not completed', (done) => {
var hexId = todos[1]._id.toHexString(); // var hexId = todos[1]._id.toHexString();
var text = 'This should be the new text!!'; // var text = 'This should be the new text!!';
//
request(app) // request(app)
.patch(`/todos/${hexId}`) // .patch(`/todos/${hexId}`)
.set('x-auth', users[1].tokens[0].token) // .set('x-auth', users[1].tokens[0].token)
.send({ // .send({
completed: false, // completed: false,
text // text
}) // })
.expect(200) // .expect(200)
.expect((res) => { // .expect((res) => {
expect(res.body.todo.text).toBe(text); // expect(res.body.todo.text).toBe(text);
expect(res.body.todo.completed).toBe(false); // expect(res.body.todo.completed).toBe(false);
expect(res.body.todo.completedAt).toNotExist(); // expect(res.body.todo.completedAt).toNotExist();
}) // })
.end(done); // .end(done);
}); // });
}); });
/*
});
describe('GET /users/me', () => { describe('GET /users/me', () => {
it('should return user if authenticated', (done) => { it('should return user if authenticated', (done) => {
request(app) request(app)
@@ -383,10 +418,10 @@ describe('GET /users/me', () => {
.end(done); .end(done);
}); });
it('should return 401 if not authenticated', (done) => { it('should return 404 if not authenticated', (done) => {
request(app) request(app)
.get('/users/me') .get('/users/me')
.expect(401) .expect(404)
.expect((res) => { .expect((res) => {
expect(res.body).toEqual({}); expect(res.body).toEqual({});
}) })

View File

@@ -3,5 +3,27 @@ var os = require("os");
module.exports = { module.exports = {
getHostname: function () { getHostname: function () {
return os.hostname() return os.hostname()
},
testing: function () {
return (process.env.TESTING_ON === '1')
},
mylog: function (...args) {
if (!this.testing())
console.log(args)
},
mylogshow: function (...args) {
console.log(args)
},
allfieldTodo: function () {
return ['userId', 'pos', 'category', 'descr', 'priority', 'completed', 'created_at', 'modify_at',
'completed_at', 'expiring_at', 'enableExpiring', 'id_prev', 'id_next', 'progress', 'modified']
},
allfieldTodoWithId: function () {
return ['_id', ...this.allfieldTodo()]
} }
}; };

View File

@@ -1,10 +1,13 @@
module.exports = Object.freeze({ module.exports = Object.freeze({
RIS_CODE_TODO_CREATING_NOTMYUSER: -1001,
RIS_CODE_ERR: -99, RIS_CODE_ERR: -99,
RIS_CODE_EMAIL_ALREADY_VERIFIED: -5, RIS_CODE_EMAIL_ALREADY_VERIFIED: -5,
RIS_CODE_EMAIL_VERIFIED: 1, RIS_CODE_EMAIL_VERIFIED: 1,
RIS_CODE_OK: 1,
RIS_CODE_LOGIN_ERR_GENERIC: -20, RIS_CODE_LOGIN_ERR_GENERIC: -20,
RIS_CODE_LOGIN_ERR: -10, RIS_CODE_LOGIN_ERR: -10,
RIS_CODE_OK: 1,
RIS_CODE_LOGIN_OK: 1, RIS_CODE_LOGIN_OK: 1,
}); });