feat: write REST API endpoint to register user

This commit is contained in:
Ali BARIN
2024-09-11 13:06:39 +00:00
committed by Faruk AYDIN
parent 09dd8abe23
commit 369f04fdbc
5 changed files with 160 additions and 0 deletions

View File

@@ -0,0 +1,96 @@
import { beforeEach, describe, it, expect, vi } from 'vitest';
import request from 'supertest';
import app from '../../../../app.js';
import User from '../../../../models/user.js';
import appConfig from '../../../../config/app.js';
import { createUser } from '../../../../../test/factories/user.js';
import { createRole } from '../../../../../test/factories/role.js';
import registerUserMock from '../../../../../test/mocks/rest/api/v1/users/register-user.ee.js';
describe('POST /api/v1/users/register', () => {
beforeEach(async () => {
vi.spyOn(appConfig, 'isCloud', 'get').mockReturnValue(true);
});
it('should return registered user with valid data', async () => {
await createRole({ name: 'User' });
const userData = {
email: 'registered@sample.com',
fullName: 'Full Name',
password: 'samplePassword123',
};
const response = await request(app)
.post('/api/v1/users/register')
.send(userData)
.expect(201);
const refetchedRegisteredUser = await User.query()
.findById(response.body.data.id)
.throwIfNotFound();
const expectedPayload = registerUserMock(refetchedRegisteredUser);
expect(response.body).toStrictEqual(expectedPayload);
});
it('should return not found response without user role existing', async () => {
const userData = {
email: 'registered@sample.com',
fullName: 'Full Name',
password: 'samplePassword123',
};
await request(app)
.post('/api/v1/users/register')
.send(userData)
.expect(404);
});
it('should return unprocessable entity respones with already used email', async () => {
await createRole({ name: 'User' });
await createUser({
email: 'registered@sample.com',
});
const userData = {
email: 'registered@sample.com',
fullName: 'Full Name',
password: 'samplePassword123',
};
const response = await request(app)
.post('/api/v1/users/register')
.send(userData)
.expect(422);
expect(response.body.errors).toStrictEqual({
email: ["'email' must be unique."],
});
expect(response.body.meta).toStrictEqual({
type: 'UniqueViolationError',
});
});
it('should return unprocessable entity response with invalid user data', async () => {
await createRole({ name: 'User' });
const userData = {
email: null,
fullName: null,
};
const response = await request(app)
.post('/api/v1/users/register')
.send(userData)
.expect(422);
expect(response.body.meta.type).toStrictEqual('ModelValidation');
expect(response.body.errors).toStrictEqual({
email: ['must be string'],
fullName: ['must be string'],
});
});
});