ee-authn.test.ts•4.03 kB
import { faker } from '@faker-js/faker'
import { FastifyBaseLogger, FastifyInstance } from 'fastify'
import { StatusCodes } from 'http-status-codes'
import { initializeDatabase } from '../../../../src/app/database'
import { databaseConnection } from '../../../../src/app/database/database-connection'
import { emailService } from '../../../../src/app/ee/helper/email/email-service'
import { stripeHelper } from '../../../../src/app/ee/platform/platform-plan/stripe-helper'
import { setupServer } from '../../../../src/app/server'
import {
createMockCustomDomain,
mockAndSaveBasicSetup,
} from '../../../../test/helpers/mocks'
import { createMockSignUpRequest } from '../../../helpers/mocks/authn'
let app: FastifyInstance | null = null
let mockLog: FastifyBaseLogger
beforeAll(async () => {
await initializeDatabase({ runMigrations: false })
app = await setupServer()
mockLog = app!.log!
})
beforeEach(async () => {
emailService(mockLog).sendOtp = jest.fn()
stripeHelper(mockLog).createCustomer = jest
.fn()
.mockResolvedValue(faker.string.alphanumeric())
await databaseConnection().getRepository('flag').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
expect(response?.statusCode).toBe(StatusCodes.OK)
const responseBody = response?.json()
expect(responseBody?.id).toHaveLength(21)
expect(responseBody?.created).toBeDefined()
expect(responseBody?.updated).toBeDefined()
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?.password).toBeUndefined()
expect(responseBody?.status).toBe('ACTIVE')
expect(responseBody?.verified).toBe(true)
expect(responseBody?.platformId).toBeDefined()
expect(responseBody?.externalId).toBe(null)
expect(responseBody?.projectId).toHaveLength(21)
expect(responseBody?.token).toBeDefined()
})
})
it('fails to sign up invited user platform if no project exist', async () => {
// arrange
const { mockPlatform } = await mockAndSaveBasicSetup({
platform: {
emailAuthEnabled: true,
enforceAllowedAuthDomains: false,
},
plan: {
ssoEnabled: false,
},
})
const mockCustomDomain = createMockCustomDomain({
platformId: mockPlatform.id,
})
await databaseConnection()
.getRepository('custom_domain')
.save(mockCustomDomain)
const mockedUpEmail = faker.internet.email()
const mockSignUpRequest = createMockSignUpRequest({ email: mockedUpEmail })
// act
const response = await app?.inject({
method: 'POST',
url: '/v1/authentication/sign-up',
headers: {
Host: mockCustomDomain.domain,
},
body: mockSignUpRequest,
})
// assert
expect(response?.statusCode).toBe(StatusCodes.FORBIDDEN)
const responseBody = response?.json()
expect(responseBody?.code).toBe('INVITATION_ONLY_SIGN_UP')
})
})