expressCart/test/specs/users.js

152 lines
4.2 KiB
JavaScript

import{ serial as test }from'ava';
const {
runBefore,
g
} = require('../helper');
test.before(async () => {
await runBefore();
});
test('[Success] Create API key', async t => {
// Login
await g.request
.post('/admin/login_action')
.send({
email: g.users[0].userEmail,
password: 'test'
});
const res = await g.request
.post('/admin/createApiKey')
.expect(200);
g.users[0].apiKey = res.body.apiKey;
t.deepEqual(res.body.message, 'API Key generated');
t.deepEqual(res.body.apiKey.length, 24);
});
test('[Success] User Login', async t => {
const res = await g.request
.post('/admin/login_action')
.send({
email: g.users[0].userEmail,
password: 'test'
})
.expect(200);
t.deepEqual(res.body.message, 'Login successful');
});
test('[Fail] Incorrect user password', async t => {
const res = await g.request
.post('/admin/login_action')
.send({
email: g.users[0].userEmail,
password: 'test1'
})
.expect(400);
t.deepEqual(res.body.message, 'Access denied. Check password and try again.');
});
test('[Fail] Delete own user account', async t => {
const res = await g.request
.post('/admin/user/delete')
.send({
userId: g.users[0]._id
})
.expect(400);
t.deepEqual(res.body.message, 'Unable to delete own user account');
});
test('[Fail] Delete invalid user ID', async t => {
const res = await g.request
.post('/admin/user/delete')
.send({
userId: 'invalid_user_id'
})
.expect(400);
t.deepEqual(res.body.message, 'User not found.');
});
test('[Success] Create new user', async t => {
const user = {
usersName: 'Jim Smith',
userEmail: 'jim.smith@gmail.com',
userPassword: 'test',
isAdmin: false
};
const res = await g.request
.post('/admin/user/insert')
.send(user)
.set('apiKey', g.users[0].apiKey)
.expect(200);
t.deepEqual(res.body.message, 'User account inserted');
});
test('[Fail] Create new user with invalid email', async t => {
const user = {
usersName: 'Jim Smith',
userEmail: 'jim.smith@gmail',
userPassword: 'test',
isAdmin: false
};
const res = await g.request
.post('/admin/user/insert')
.send(user)
.set('apiKey', g.users[0].apiKey)
.expect(400);
t.deepEqual(res.body.message, 'Failed to create user. Check inputs.');
t.deepEqual(res.body.error[0].message, 'should match format "emailAddress"');
});
test('[Success] Update user', async t => {
const user = {
userId: g.users[1]._id,
usersName: 'Jim Smith',
userEmail: 'jim.smith@gmail.com',
userPassword: 'test',
isAdmin: false
};
const res = await g.request
.post('/admin/user/update')
.send(user)
.set('apiKey', g.users[0].apiKey)
.expect(200);
t.deepEqual(res.body.user._id, g.users[1]._id.toString());
t.deepEqual(res.body.user.usersName, 'Jim Smith');
t.deepEqual(res.body.user.userEmail, 'jim.smith@gmail.com');
t.deepEqual(res.body.message, 'User account updated');
});
test('[Fail] Update user invalid email', async t => {
const user = {
userId: g.users[1]._id,
usersName: 'Jim Smith',
userEmail: 'jim.smith@gmail',
userPassword: 'test',
isAdmin: false
};
const res = await g.request
.post('/admin/user/update')
.send(user)
.set('apiKey', g.users[0].apiKey)
.expect(400);
t.deepEqual(res.body.message, 'Failed to create user. Check inputs.');
t.deepEqual(res.body.error[0].message, 'should match format "emailAddress"');
});
test('[Fail] Update user invalid userId', async t => {
const user = {
userId: '5dcfc8a5492532d1943e259e',
usersName: 'Jim Smith',
userEmail: 'jim.smith@gmail',
userPassword: 'test',
isAdmin: false
};
const res = await g.request
.post('/admin/user/update')
.send(user)
.set('apiKey', g.users[0].apiKey)
.expect(400);
t.deepEqual(res.body.message, 'User not found');
});