2019-11-09 12:14:56 +10:00
|
|
|
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
|
2019-12-16 14:45:02 +10:00
|
|
|
.post('/admin/user/delete')
|
|
|
|
.send({
|
|
|
|
userId: g.users[0]._id
|
|
|
|
})
|
|
|
|
.expect(400);
|
|
|
|
t.deepEqual(res.body.message, 'Unable to delete own user account');
|
2019-11-09 12:14:56 +10:00
|
|
|
});
|
|
|
|
|
|
|
|
test('[Fail] Delete invalid user ID', async t => {
|
|
|
|
const res = await g.request
|
2019-12-16 14:45:02 +10:00
|
|
|
.post('/admin/user/delete')
|
|
|
|
.send({
|
|
|
|
userId: 'invalid_user_id'
|
|
|
|
})
|
|
|
|
.expect(400);
|
|
|
|
t.deepEqual(res.body.message, 'User not found.');
|
2019-11-09 12:14:56 +10:00
|
|
|
});
|
2019-11-16 19:37:48 +10:00
|
|
|
|
|
|
|
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);
|
2019-12-16 14:22:27 +10:00
|
|
|
t.deepEqual(res.body.message, 'Failed to create user. Check inputs.');
|
|
|
|
t.deepEqual(res.body.error[0].message, 'should match format "emailAddress"');
|
2019-11-16 19:37:48 +10:00
|
|
|
});
|
2019-11-16 19:57:50 +10:00
|
|
|
|
|
|
|
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');
|
|
|
|
});
|
2019-11-16 20:01:49 +10:00
|
|
|
|
|
|
|
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);
|
2019-12-16 14:22:27 +10:00
|
|
|
t.deepEqual(res.body.message, 'Failed to create user. Check inputs.');
|
|
|
|
t.deepEqual(res.body.error[0].message, 'should match format "emailAddress"');
|
2019-11-16 20:01:49 +10:00
|
|
|
});
|
|
|
|
|
|
|
|
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');
|
|
|
|
});
|