166 lines
6.0 KiB
TypeScript
166 lines
6.0 KiB
TypeScript
import { FastifyInstance } from 'fastify'
|
|
import { StatusCodes } from 'http-status-codes'
|
|
import { initializeDatabase } from '../../../../src/app/database'
|
|
import { databaseConnection } from '../../../../src/app/database/database-connection'
|
|
import { setupServer } from '../../../../src/app/server'
|
|
import {
|
|
createMockSignInRequest,
|
|
createMockSignUpRequest,
|
|
} from '../../../helpers/mocks/authn'
|
|
|
|
let app: FastifyInstance | null = null
|
|
|
|
beforeAll(async () => {
|
|
await initializeDatabase({ runMigrations: false })
|
|
app = await setupServer()
|
|
})
|
|
|
|
beforeEach(async () => {
|
|
await databaseConnection().getRepository('flag').delete({})
|
|
await databaseConnection().getRepository('project').delete({})
|
|
await databaseConnection().getRepository('platform').delete({})
|
|
await databaseConnection().getRepository('user').delete({})
|
|
})
|
|
|
|
afterAll(async () => {
|
|
await databaseConnection().destroy()
|
|
await app?.close()
|
|
})
|
|
|
|
describe('Authentication API', () => {
|
|
describe('Sign up Endpoint', () => {
|
|
it('Adds new user', async () => {
|
|
// arrange
|
|
const mockSignUpRequest = createMockSignUpRequest()
|
|
|
|
// act
|
|
const response = await app?.inject({
|
|
method: 'POST',
|
|
url: '/v1/authentication/sign-up',
|
|
body: mockSignUpRequest,
|
|
})
|
|
|
|
// assert
|
|
const responseBody = response?.json()
|
|
|
|
expect(response?.statusCode).toBe(StatusCodes.OK)
|
|
expect(responseBody?.id).toHaveLength(21)
|
|
expect(responseBody?.created).toBeDefined()
|
|
expect(responseBody?.updated).toBeDefined()
|
|
expect(responseBody?.verified).toBe(true)
|
|
expect(responseBody?.email).toBe(mockSignUpRequest.email.toLocaleLowerCase().trim())
|
|
expect(responseBody?.firstName).toBe(mockSignUpRequest.firstName)
|
|
expect(responseBody?.lastName).toBe(mockSignUpRequest.lastName)
|
|
expect(responseBody?.trackEvents).toBe(mockSignUpRequest.trackEvents)
|
|
expect(responseBody?.newsLetter).toBe(mockSignUpRequest.newsLetter)
|
|
expect(responseBody?.status).toBe('ACTIVE')
|
|
expect(responseBody?.platformId).toBeDefined()
|
|
expect(responseBody?.externalId).toBe(null)
|
|
expect(responseBody?.projectId).toHaveLength(21)
|
|
expect(responseBody?.token).toBeDefined()
|
|
})
|
|
|
|
it('Creates new project for user', async () => {
|
|
// arrange
|
|
const mockSignUpRequest = createMockSignUpRequest()
|
|
|
|
// act
|
|
const response = await app?.inject({
|
|
method: 'POST',
|
|
url: '/v1/authentication/sign-up',
|
|
body: mockSignUpRequest,
|
|
})
|
|
|
|
const responseBody = response?.json()
|
|
// assert
|
|
expect(response?.statusCode).toBe(StatusCodes.OK)
|
|
|
|
const project = await databaseConnection()
|
|
.getRepository('project')
|
|
.findOneBy({
|
|
id: responseBody.projectId,
|
|
})
|
|
|
|
expect(project?.ownerId).toBe(responseBody.id)
|
|
expect(project?.displayName).toBeDefined()
|
|
expect(project?.platformId).toBeDefined()
|
|
})
|
|
})
|
|
|
|
describe('Sign in Endpoint', () => {
|
|
it('Logs in existing users', async () => {
|
|
// arrange
|
|
const mockSignUpRequest = createMockSignUpRequest()
|
|
|
|
// First sign up the user
|
|
const signUpResponse = await app?.inject({
|
|
method: 'POST',
|
|
url: '/v1/authentication/sign-up',
|
|
body: mockSignUpRequest,
|
|
})
|
|
|
|
const signUpBody = signUpResponse?.json()
|
|
|
|
// Then try to sign in
|
|
const mockSignInRequest = createMockSignInRequest({
|
|
email: mockSignUpRequest.email,
|
|
password: mockSignUpRequest.password,
|
|
})
|
|
|
|
// act
|
|
const response = await app?.inject({
|
|
method: 'POST',
|
|
url: '/v1/authentication/sign-in',
|
|
body: mockSignInRequest,
|
|
})
|
|
|
|
// assert
|
|
const responseBody = response?.json()
|
|
|
|
expect(response?.statusCode).toBe(StatusCodes.OK)
|
|
expect(responseBody?.id).toBe(signUpBody.id)
|
|
expect(responseBody?.email).toBe(mockSignUpRequest.email.toLowerCase().trim())
|
|
expect(responseBody?.firstName).toBe(mockSignUpRequest.firstName)
|
|
expect(responseBody?.lastName).toBe(mockSignUpRequest.lastName)
|
|
expect(responseBody?.trackEvents).toBe(mockSignUpRequest.trackEvents)
|
|
expect(responseBody?.newsLetter).toBe(mockSignUpRequest.newsLetter)
|
|
expect(responseBody?.password).toBeUndefined()
|
|
expect(responseBody?.status).toBe('ACTIVE')
|
|
expect(responseBody?.verified).toBe(true)
|
|
expect(responseBody?.platformId).toBe(signUpBody.platformId)
|
|
expect(responseBody?.externalId).toBe(null)
|
|
expect(responseBody?.projectId).toBe(signUpBody.projectId)
|
|
expect(responseBody?.token).toBeDefined()
|
|
})
|
|
|
|
it('Fails if password doesn\'t match', async () => {
|
|
// arrange
|
|
const mockSignUpRequest = createMockSignUpRequest()
|
|
|
|
// First sign up the user
|
|
await app?.inject({
|
|
method: 'POST',
|
|
url: '/v1/authentication/sign-up',
|
|
body: mockSignUpRequest,
|
|
})
|
|
|
|
const mockSignInRequest = createMockSignInRequest({
|
|
email: mockSignUpRequest.email,
|
|
password: 'wrong password',
|
|
})
|
|
|
|
// act
|
|
const response = await app?.inject({
|
|
method: 'POST',
|
|
url: '/v1/authentication/sign-in',
|
|
body: mockSignInRequest,
|
|
})
|
|
|
|
// assert
|
|
expect(response?.statusCode).toBe(StatusCodes.UNAUTHORIZED)
|
|
const responseBody = response?.json()
|
|
expect(responseBody?.code).toBe('INVALID_CREDENTIALS')
|
|
})
|
|
})
|
|
})
|