/* eslint-env jest */ import React from 'react' import { renderWithGlobalConfig, act, fireEvent, waitFor } from 'test-utils' import TokenProjectSignup from './TokenProjectSignup' import * as mockVerifyExtensionsToken from '../../api/verifyExtensionsToken' import * as mockSetProjectName from '../../api/setProjectName' it('should close modal after completing sign up process', async () => { mockVerifyExtensionsToken.default = jest.fn().mockImplementation(() => { return { loading: false, error: null, data: { success: true } } }) mockSetProjectName.default = jest.fn().mockImplementation(() => { return { loading: false, error: null, data: { success: true } } }) const onCloseCallback = jest.fn() const { getByTestId } = renderWithGlobalConfig(( <>
), { config: { project_name: 'Default Project Name' } }) // Fill in and submit step 1 of the token flow:: await act(async () => { // Input box: const tokenInputBox = getByTestId('token-input') fireEvent.change(tokenInputBox, { target: { value: 'test-token-value' } }) expect(tokenInputBox.value).toBe('test-token-value') // Button click const tokenSubmitButton = getByTestId('elements-token-submit') fireEvent.click(tokenSubmitButton) // Check the API call was fired: expect(mockVerifyExtensionsToken.default).toHaveBeenCalled() // Wait for the modal to swap to step 2 await waitFor(() => { expect(getByTestId('project-name-input')).toBeInTheDocument() }, { timeout: 2000 }) }) // Fill in and submit step 2 of the token flow:: await act(async () => { // Input box: const projectInputBox = getByTestId('project-name-input') expect(projectInputBox.value).toBe('Default Project Name') fireEvent.change(projectInputBox, { target: { value: 'My project name' } }) expect(projectInputBox.value).toBe('My project name') // Button click const projectSubmitButton = getByTestId('project-name-submit') fireEvent.click(projectSubmitButton) // Check the API call was fired: expect(mockSetProjectName.default).toHaveBeenCalled() // Wait for the modal to swap to final step await waitFor(() => { expect(getByTestId('complete-signup-wizard')).toBeInTheDocument() }, { timeout: 2000 }) }) // Click the final "complete" button await act(async () => { // Input box: const completeButton = getByTestId('complete-signup-wizard') fireEvent.click(completeButton) // Wait for modal to be closed await waitFor(() => { act(() => { expect(onCloseCallback).toHaveBeenCalled() }) }, { timeout: 4000 }) }) })