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')
    })
})