salix/back/methods/vn-user/specs/validate-auth.spec.js

42 lines
1.3 KiB
JavaScript
Raw Normal View History

2023-04-13 09:54:56 +00:00
const {models} = require('vn-loopback/server/server');
2023-04-13 10:01:51 +00:00
describe('account validateAuth()', () => {
2023-04-13 09:54:56 +00:00
const developerId = 9;
it('should throw an error for a non existent code', async() => {
const ctx = {req: {accessToken: {userId: developerId}}};
let error;
try {
2023-04-18 12:37:20 +00:00
await models.VnUser.validateAuth(ctx, 'developer', 'nightmare', '123456');
2023-04-13 09:54:56 +00:00
} catch (e) {
error = e;
}
expect(error).toBeDefined();
expect(error.statusCode).toBe(400);
expect(error.message).toEqual('Invalid or expired verification code');
});
it('should throw an error when a code doesn`t match the login username', async() => {
const ctx = {req: {accessToken: {userId: developerId}}};
let error;
try {
const authCode = await models.AuthCode.create({
userFk: 1,
code: '555555',
expires: Date.vnNow() + (60 * 1000)
});
2023-04-18 12:37:20 +00:00
await models.VnUser.validateAuth(ctx, 'developer', 'nightmare', '555555');
2023-04-13 09:54:56 +00:00
await authCode.destroy();
} catch (e) {
error = e;
}
expect(error).toBeDefined();
expect(error.statusCode).toBe(400);
expect(error.message).toEqual('Authentication failed');
});
});