Disabled debug Mongoose

Updated modules
fixed tests
This commit is contained in:
Paolo Arena
2021-09-22 01:13:41 +02:00
parent 10e9da805e
commit 396bfea289
73 changed files with 2831 additions and 2853 deletions

View File

@@ -1,8 +1,8 @@
const { ObjectID } = require('mongodb');
const {ObjectID} = require('mongodb');
const jwt = require('jsonwebtoken');
const { Todo } = require('../../models/todo');
const { User } = require('../../models/user');
const {Todo} = require('../../models/todo');
const {User} = require('../../models/user');
var bcrypt = require('bcryptjs');
@@ -20,49 +20,54 @@ const userTwoId = new ObjectID();
// });
// String(mypwdcrypt)
let mypwdchiaro = 'mypassword@1A';
let mypwdcrypted = '$2b$12$mteST.isuWO0SNsfeZ0aCe.Dz3qwPh5SU8t9rc5SaPTkb3j0ywGv6'
let mypwdcrypted = '$2b$12$mteST.isuWO0SNsfeZ0aCe.Dz3qwPh5SU8t9rc5SaPTkb3j0ywGv6';
const date_login = new Date();
// const useragent = "auth Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/72.0.3626.96 Safari/537.36"
const useragent = "node-superagent/2.3.0";
const useragent = 'node-superagent/2.3.0';
const users = [{
_id: userOneId,
keyappid: process.env.KEY_APP_ID,
lang: 'it',
idapp: '1',
email: 'paoloa.rena77@gmail.com',
username: 'paoloar77B',
name: 'Paolo',
surname: 'Arena',
password: mypwdcrypted,
tokens: [{
access: 'auth',
browser: useragent,
token: jwt.sign({ _id: userOneId, access: 'auth' }, process.env.SIGNCODE).toString(),
date_login
}]
},
const users = [
{
_id: userOneId,
keyappid: process.env.KEY_APP_ID,
lang: 'it',
idapp: '1',
email: 'paoloa.rena77@gmail.com',
username: 'paoloar77B',
name: 'Paolo',
surname: 'Arena',
password: mypwdcrypted,
tokens: [
{
access: 'auth',
browser: useragent,
token: jwt.sign({_id: userOneId, access: 'auth'}, process.env.SIGNCODE).
toString(),
date_login,
}],
},
{
_id: userTwoId,
keyappid: process.env.KEY_APP_ID,
lang: 'it',
idapp: '1',
email: 'pa@com',
email: 'patesttest@com',
name: 'Paolo2',
surname: 'Arena2',
password: mypwdcrypted,
username: 'paoloar77C',
tokens: [{
access: 'auth',
browser: useragent,
token: jwt.sign({ _id: userTwoId, access: 'auth' }, process.env.SIGNCODE).toString(),
date_login
}]
}, {
tokens: [
{
access: 'auth',
browser: useragent,
token: jwt.sign({_id: userTwoId, access: 'auth'}, process.env.SIGNCODE).
toString(),
date_login,
}],
},
{
keyappid: process.env.KEY_APP_ID, // RECORD CHE VERRA' UTILIZZATO PER UNA NUOVA REGISTRAZIONE
lang: 'it',
idapp: '1',
@@ -77,101 +82,117 @@ const userjson = JSON.stringify(users[0]);
// console.log('userjson=', userjson)
const mynewID = new ObjectID();
const todos = [{
_id: new ObjectID(),
// category: "personal",
statustodo: 0,
completed_at: new Date(),
created_at: new Date(),
descr: "Primo Task Esempio",
enableExpiring: false,
expiring_at: new Date(),
modified: false,
modify_at: new Date(),
pos: 1,
priority: 1,
progress: 0,
userId: users[0]._id
}, {
_id: new ObjectID(),
// category: "personal",
statustodo: 0,
completed_at: new Date(),
created_at: new Date(),
descr: "Secondo Task Esempio",
enableExpiring: false,
expiring_at: new Date(),
modified: false,
modify_at: new Date(),
pos: 2,
priority: 1,
progress: 0,
userId: users[0]._id
}, {
_id: new ObjectID(),
// category: "personal",
statustodo: 0,
completed_at: new Date(),
created_at: new Date(),
descr: "Terzo Task Esempio",
enableExpiring: false,
expiring_at: new Date(),
modified: false,
modify_at: new Date(),
pos: 3,
priority: 1,
progress: 0,
}, { // RECORD CHE VERRA' UTILIZZATO PER AGGIUNGERE UN NUOVO TASK
_id: new ObjectID(),
// category: "personal",
statustodo: 0,
completed_at: new Date(),
created_at: new Date(),
descr: "Nuovo Quarto Task Esempio da Inserire",
enableExpiring: false,
expiring_at: new Date(),
modified: false,
modify_at: new Date(),
pos: 4,
priority: 1,
progress: 0,
userId: users[0]._id
}];
const mongoose = require('mongoose').set('debug', false)
const populateTodos = (done) => {
var ObjectId = mongoose.Types.ObjectId;
Todo.deleteMany({})
.then(() => {
const todos = [
{
_id: mynewID,
category: ObjectId(),
statustodo: 0,
completed_at: new Date(),
created_at: new Date(),
// category: "personal",
descr: 'Primo Task Esempio',
enableExpiring: false,
expiring_at: new Date(),
modified: false,
modify_at: new Date(),
pos: 1,
priority: 1,
progress: 0,
userId: users[0]._id,
}, {
_id: new ObjectID(),
category: ObjectId(mynewID),
statustodo: 0,
completed_at: new Date(),
created_at: new Date(),
descr: 'Secondo Task Esempio',
enableExpiring: false,
expiring_at: new Date(),
modified: false,
modify_at: new Date(),
pos: 2,
priority: 1,
progress: 0,
userId: users[1]._id,
}, {
_id: new ObjectID(),
category: ObjectId(mynewID),
statustodo: 0,
completed_at: new Date(),
created_at: new Date(),
descr: 'Terzo Task Esempio',
enableExpiring: false,
expiring_at: new Date(),
modified: false,
modify_at: new Date(),
pos: 3,
priority: 1,
progress: 0,
userId: users[2]._id,
}, { // RECORD CHE VERRA' UTILIZZATO PER AGGIUNGERE UN NUOVO TASK
_id: new ObjectID(),
category: ObjectId(mynewID),
statustodo: 0,
completed_at: new Date(),
created_at: new Date(),
descr: 'Nuovo Quarto Task Esempio da Inserire',
enableExpiring: false,
expiring_at: new Date(),
modified: false,
modify_at: new Date(),
pos: 4,
priority: 1,
progress: 0,
userId: users[0]._id,
}];
const TodoOne = new Todo(todos[0]).save();
const 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 populateTodos = async (done) => {
// console.log(' delete Todos...')
await Todo.deleteMany({}).then(() => {
// console.log(' deleted ...')
const TodoOne = new Todo(todos[0]).save();
const TodoTwo = new Todo(todos[1]).save();
return Promise.all([TodoOne, TodoTwo]);
}).then(() => {
// console.log('populateTodos done !')
// done()
});
};
const populateUsers = async (done) => {
const populateUsers = (done) => {
// console.log(' delete Users ...')
await User.deleteMany({}).then(() => {
User.deleteMany({})
.then(() => {
// console.log(' deleted ...')
// console.log('users[0]', users[0])
var userOne = new User(users[0]).save();
var userTwo = new User(users[1]).save();
// console.log('users[0]', users[0])
var userOne = new User(users[0]).save();
var userTwo = new User(users[1]).save();
return Promise.all([userOne, userTwo])
}).then(() => done());
return Promise.all([userOne, userTwo]);
}).then(() => {
// console.log('populateUsers done !')
// done()
});
};
module.exports = { todos, populateTodos, users, populateUsers, userjson, mypwdcrypted, mypwdchiaro, date_login };
module.exports = {
todos,
populateTodos,
users,
populateUsers,
userjson,
mypwdcrypted,
mypwdchiaro,
date_login,
};

View File

@@ -1,11 +1,12 @@
const expect = require('expect');
const request = require('supertest');
const { ObjectID } = require('mongodb');
const {ObjectID} = require('mongodb');
const { app } = require('../server');
const { Todo } = require('../models/todo');
const { User } = require('../models/user');
const { todos, populateTodos, users, populateUsers, userjson, mypwdcrypted, mypwdchiaro, date_login } = require('./seed/seed');
const {app} = require('../server');
const {Todo} = require('../models/todo');
const {User} = require('../models/user');
const {todos, populateTodos, users, populateUsers, userjson, mypwdcrypted, mypwdchiaro, date_login} = require(
'./seed/seed');
const tools = require('../tools/general');
@@ -13,382 +14,370 @@ const tools = require('../tools/general');
// const log = debug('server');
let jsonUser1 = {
email: "paolo.arena77@gmail.com",
password: "$2a$12$hTv40mdq.x35Up7HQ9faae1JgHrohcvp45vt8eMkGhQv/Zv.8.MIG",
username: "paoloar77",
email: 'paolo.arena77@gmail.com',
password: '$2a$12$hTv40mdq.x35Up7HQ9faae1JgHrohcvp45vt8eMkGhQv/Zv.8.MIG',
username: 'paoloar77',
name: 'Paolo',
surname: 'Arena',
idapp: "1",
lang: "it",
keyappid: "KKPPAA5KJK435J3KSS9F9D8S9F8SD98F9SDF"
idapp: '1',
lang: 'it',
keyappid: 'KKPPAA5KJK435J3KSS9F9D8S9F8SD98F9SDF',
};
beforeEach(populateUsers);
beforeEach(populateTodos);
beforeEach(async function() {
this.timeout(5000);
await populateUsers()
})
beforeEach(async function() {
this.timeout(5000);
await populateTodos()
})
const IndexUserToCreate = 2;
const IndexTodoToCreate = 3;
// console.log('UserOne:', users[0]);
// console.log('UserTwo:', users[0]);
// console.log('userjson', userjson);
// const useragent = "auth Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/72.0.3626.96 Safari/537.36";
const useragent = "node-superagent/2.3.0";
const useragent = 'node-superagent/2.3.0';
const testsingolo = false;
if (testsingolo) {
describe('POST /users/login', () => {
it('should login user and return auth token', (done) => {
request(app)
.post('/users/login')
// .set('x-auth', users[0].tokens[0].token)
.send({
username: users[0].username,
name: users[0].name,
surname: users[0].surname,
password: mypwdchiaro,
idapp: users[0].idapp,
keyappid: users[0].keyappid,
lang: users[0].lang,
subs: null,
})
.expect(200)
.expect((res) => {
expect(res.headers['x-auth']).toBeTruthy();
})
.end((err, res) => {
if (err) {
return done(err);
}
it.only('should login user and return auth token', (done) => {
request(app).post('/users/login')
// .set('x-auth', users[0].tokens[0].token)
.send({
username: users[0].username,
name: users[0].name,
surname: users[0].surname,
password: mypwdchiaro,
idapp: users[0].idapp,
keyappid: users[0].keyappid,
lang: users[0].lang,
subs: null,
}).expect(200).expect((res) => {
expect(res.headers['x-auth']).toBeTruthy();
}).end((err, res) => {
if (err) {
return done(err);
}
User.findById(users[0]._id).then((user) => {
expect(user.tokens[0]).toContain({
access: 'auth',
// token: res.headers['x-auth'],
date_login: date_login
});
done();
}).catch((e) => done(e));
});
User.findById(users[0]._id).then((user) => {
expect(user.tokens[0]).toEqual({
access: 'auth',
// token: res.headers['x-auth'],
date_login: date_login,
});
return done();
}).catch((e) => done(e));
});
});
});
} else {
describe('POST /users', () => {
describe('POST /users', function() {
this.timeout(8000);
it('should create a user', (done) => {
request(app)
.post('/users')
.send(users[IndexUserToCreate])
.expect(200)
.expect((res) => {
expect(res.headers['x-auth']).toBeTruthy();
expect(res.body._id).toBeTruthy();
expect(res.body.email).toBe(users[IndexUserToCreate].email);
expect(res.body.username).toBe(users[IndexUserToCreate].username);
expect(res.body.name).toBe(users[IndexUserToCreate].name);
expect(res.body.surname).toBe(users[IndexUserToCreate].surname);
})
.end((err) => {
if (err) {
console.log('ERR:', err);
return done(err);
}
request(app).
post('/users').
send(users[IndexUserToCreate]).
expect(200).
expect((res) => {
expect(res.headers['x-auth']).toBeTruthy();
expect(res.body._id).toBeTruthy();
expect(res.body.email).toBe(users[IndexUserToCreate].email);
expect(res.body.username).toBe(users[IndexUserToCreate].username);
expect(res.body.name).toBe(users[IndexUserToCreate].name);
expect(res.body.surname).toBe(users[IndexUserToCreate].surname);
}).
end((err) => {
User.findOne({ email: users[IndexUserToCreate].email }).then((user) => {
expect(user).toBeTruthy();
done();
}).catch((e) => done(e));
});
if (err) {
console.log('ERR:', err);
return done(err);
}
return User.findOne({email: users[IndexUserToCreate].email}).
then((user) => {
expect(user).toBeTruthy();
return done();
}).
catch((e) => {
return done(e)
});
});
});
it('should return validation errors if request invalid', (done) => {
request(app)
.post('/users')
.send({
email: 'and',
password: '123'
})
.expect(400)
.end(done);
request(app).post('/users').send({
email: 'test@test.com',
username: 'and',
password: '123',
}).expect(400).end(done);
});
it('should not create user if email in use', (done) => {
request(app)
.post('/users')
.send(users[1])
.expect(400)
.end(done);
request(app).post('/users').send(users[1]).expect(400).end(done);
});
});
describe('GET /users/idapp/myusername', () => {
it('should return 200 if myusername exist', (done) => {
request(app)
.get('/users/' + users[0].idapp + '/' + users[0].username)
// .set('x-auth', users[0].tokens[0].token)
.expect(200)
.end(done);
request(app).get('/users/' + users[0].idapp + '/' + users[0].username)
// .set('x-auth', users[0].tokens[0].token)
.expect(200).end(done);
});
it('should return 404 if myusername doesn\'t exist', (done) => {
request(app)
.get('/users/' + users[0].idapp + '/' + users[0].username + 'pippo')
.expect(404)
.end(done);
request(app).
get('/users/' + users[0].idapp + '/' + users[0].username + 'pippo').
expect(404).
end(done);
});
});
describe('POST /users/login', () => {
it('should login user and return auth token', (done) => {
request(app)
.post('/users/login')
// .set('x-auth', users[0].tokens[0].token)
.send({
username: users[0].username,
password: mypwdchiaro,
idapp: users[0].idapp,
keyappid: users[0].keyappid,
lang: users[0].lang,
})
.expect(200)
.expect((res) => {
expect(res.headers['x-auth']).toBeTruthy();
})
.end((err, res) => {
if (err) {
return done(err);
}
request(app).post('/users/login')
// .set('x-auth', users[0].tokens[0].token)
.send({
username: users[0].username,
password: mypwdchiaro,
idapp: users[0].idapp,
keyappid: users[0].keyappid,
lang: users[0].lang,
}).expect(200).expect((res) => {
expect(res.headers['x-auth']).toBeTruthy();
}).end((err, res) => {
if (err) {
return done(err);
}
User.findById(users[0]._id).then((user) => {
expect(user.tokens[0]).toContain({
_id: user.tokens[0]._id,
access: 'auth',
browser: useragent,
date_login: date_login,
token: users[0].tokens[0].token,
});
done();
}).catch((e) => done(e));
});
return User.findById(users[0]._id).then((user) => {
expect(user.tokens[0]._doc).toEqual({
_id: user.tokens[0]._id,
access: 'auth',
browser: useragent,
date_login: date_login,
token: users[0].tokens[0].token,
});
return done();
}).catch((e) => done(e));
});
});
it('should reject invalid login', (done) => {
request(app)
.post('/users/login')
.send({
username: users[0].username,
password: mypwdchiaro + '1'
})
.expect(400)
.expect((res) => {
expect(res.headers['x-auth']).not.toBeTruthy();
})
.end((err, res) => {
if (err) {
return done(err);
}
it('should reject invalid login', function(done) {
this.timeout(6000);
request(app).post('/users/login').send({
username: users[0].username,
password: mypwdchiaro + '1',
}).expect(400).expect((res) => {
expect(res.headers['x-auth']).not.toBeTruthy();
}).end((err, res) => {
if (err) {
return done(err);
}
User.findById(users[1]._id).then((user) => {
expect(user.tokens.length).toBe(1);
done();
}).catch((e) => done(e));
});
return User.findById(users[1]._id).then((user) => {
expect(user.tokens.length).toBe(1);
return done();
}).catch((e) => done(e));
});
});
});
describe('DELETE /users/me/token', () => {
it('should logout user deleting auth token', (done) => {
request(app)
.delete('/users/me/token')
.set('x-auth', users[0].tokens[0].token)
.send()
.expect(200)
.expect((res) => {
expect(res.headers['x-auth']).not.toBeTruthy();
})
.end((err, res) => {
if (err) {
return done(err);
}
request(app).
delete('/users/me/token').
set('x-auth', users[0].tokens[0].token).
send().
expect(200).
expect((res) => {
expect(res.headers['x-auth']).not.toBeTruthy();
}).
end((err, res) => {
if (err) {
return done(err);
}
done();
});
return done();
});
});
it('should return 403 deleting with an invalid token', (done) => {
request(app)
.delete('/users/me/token')
.set('x-auth', users[0].tokens[0].token + '1')
.send()
.expect(403)
.end((err, res) => {
if (err) {
return done(err);
}
request(app).
delete('/users/me/token').
set('x-auth', users[0].tokens[0].token + '1').
send().
expect(403).
end((err, res) => {
if (err) {
return done(err);
}
done();
});
return 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);
}
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();
}).catch((e) => done(e));
});
return 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();
}).
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();
});
request(app).
post('/todos').
set('x-auth', users[0].tokens[0].token).
send(todos[IndexTodoToCreate]).
expect(404).
end((err) => {
return done();
});
});
it('should not create todo with invalid body data', (done) => {
request(app)
.post('/todos')
.set('x-auth', users[0].tokens[0].token)
.send({})
.expect(400)
.end((err, res) => {
if (err) {
return done(err);
}
Todo.find().then((todos) => {
done();
}).catch((e) => done(e));
});
request(app).
post('/todos').
set('x-auth', users[0].tokens[0].token).
send({}).
expect(400).
end(done);
});
});
describe('GET /todos', () => {
it('should get all todos', (done) => {
request(app)
.get(`/todos/`)
.set('x-auth', users[0].tokens[0].token)
.expect(200)
.expect((res) => {
expect(res.body.todos.length).toBe(2);
})
.end(done);
request(app).
get(`/todos/`).
set('x-auth', users[0].tokens[0].token).
expect(200).
expect((res) => {
expect(res.body.todos.length).toBe(2);
}).
end(done);
});
});
describe('GET /todos/:id', () => {
it('should return todos of the User', (done) => {
request(app)
.get(`/todos/${todos[0].userId}`)
.set('x-auth', users[0].tokens[0].token)
.expect(200)
.expect((res) => {
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);
request(app).
get(`/todos/${todos[0].userId.toString()}`).
set('x-auth', users[0].tokens[0].token).
expect(200).
expect((res) => {
let miores = res;
let miadescr = miores.body.todos[0][0].descr;
expect(res.body.todos.length).toBe(2);
expect(miadescr).toBe(todos[1].descr);
}).
end(done);
});
it('should not return todo doc created by other user', (done) => {
request(app)
.get(`/todos/${todos[2].userId}`)
.set('x-auth', users[0].tokens[0].token)
.expect(404)
.end(done);
request(app).
get(`/todos/${todos[1].userId.toString()}`).
set('x-auth', users[0].tokens[0].token).
expect(404).
end(done);
});
it('FORBIDDEN ! should return [] if user not found', (done) => {
var hexId = new ObjectID().toHexString();
request(app)
.get(`/todos/${hexId}`)
.set('x-auth', users[0].tokens[0].token)
.expect(404)
.expect((res) => {
console.log('res', res.statustodo);
expect(res.body.todos).toBe(undefined);
})
.end(done);
request(app).
get(`/todos/${hexId}`).
set('x-auth', users[0].tokens[0].token).
expect(404).
expect((res) => {
console.log('res', res.statustodo);
expect(res.body.todos).toBe(undefined);
}).
end(done);
});
it('should return 404 for non-object ids', (done) => {
request(app)
.get('/todos/123abc')
.set('x-auth', users[0].tokens[0].token)
.expect(404)
.end(done);
request(app).
get('/todos/123abc').
set('x-auth', users[0].tokens[0].token).
expect(404).
end(done);
});
});
describe('DELETE /todos/:id', () => {
it('should remove a todo', (done) => {
var hexId = todos[0]._id.toHexString();
it('should hide a todo', (done) => {
var hexId = todos[0]._id.toString();
request(app)
.delete(`/todos/${hexId}`)
.set('x-auth', users[0].tokens[0].token)
.expect(200)
.expect((res) => {
expect(res.body.todo._id).toBe(hexId);
})
.end((err, res) => {
if (err) {
return done(err);
}
request(app).
delete(`/todos/${hexId}`).
set('x-auth', users[0].tokens[0].token).
expect(200).
expect((res) => {
expect(res.body.todo._id).toBe(hexId);
}).
end((err, res) => {
if (err) {
return done(err);
}
Todo.findById(hexId).then((todo) => {
expect(todo).not.toBeTruthy();
done();
}).catch((e) => done(e));
});
Todo.findById(hexId).then((todo) => {
expect(todo.deleted).toBe(true);
return done();
}).catch((e) => done(e));
});
});
it('should return 404 if todo not found', (done) => {
var hexId = new ObjectID().toHexString();
request(app)
.delete(`/todos/${hexId}`)
.set('x-auth', users[0].tokens[0].token)
.expect(404)
.end(done);
request(app).
delete(`/todos/${hexId}`).
set('x-auth', users[0].tokens[0].token).
expect(404).
end(done);
});
it('should return 404 if object id is invalid', (done) => {
request(app)
.delete('/todos/123abc')
.set('x-auth', users[0].tokens[0].token)
.expect(404)
.end(done);
request(app).
delete('/todos/123abc').
set('x-auth', users[0].tokens[0].token).
expect(404).
end(done);
});
});
@@ -397,37 +386,40 @@ if (testsingolo) {
var hexId = todos[0]._id.toHexString();
var descr = 'This should be the new text';
request(app)
.patch(`/todos/${hexId}`)
.set('x-auth', users[0].tokens[0].token)
.send({
statustodo: 1,
descr
})
.expect(200)
.expect((res) => {
expect(res.body.todo.descr).toBe(descr);
expect(res.body.todo.statustodo).toBe(1);
// expect(res.body.todo.completedAt).toBeA('number');
})
.end(done);
request(app).
patch(`/todos/${hexId}`).
set('x-auth', users[0].tokens[0].token).
send({
statustodo: 1,
descr,
}).
expect(200).
expect((res) => {
expect(res.body.todo.descr).toBe(descr);
expect(res.body.todo.statustodo).toBe(1);
// expect(res.body.todo.completedAt).toBeA('number');
}).
end(done);
});
/*
it('should not update the todo created by other user', (done) => {
var hexId = todos[0]._id.toHexString();
var descr = 'This should be the new text';
request(app)
.patch(`/todos/${hexId}`)
.set('x-auth', users[1].tokens[0].token)
.send({
statustodo: 1,
descr
})
.expect(404)
.end(done);
request(app).
patch(`/todos/${hexId}`).
set('x-auth', users[1].tokens[0].token).
send({
statustodo: 1,
descr,
}).
expect(404).
end(done);
});
*/
// it('should clear completedAt when todo is not completed', (done) => {
// var hexId = todos[1]._id.toHexString();
// var text = 'This should be the new text!!';