UNPKG

@brightlayer-ui/react-native-auth-workflow

Version:

Re-usable workflow components for Authentication and Registration within Eaton applications.

73 lines (72 loc) 3.02 kB
import { jsx as _jsx } from "react/jsx-runtime"; import { fireEvent, render, screen, waitFor } from '@testing-library/react-native'; import { RegistrationWorkflow } from '../../components/index.js'; import { RegistrationContextProvider } from '../../contexts/index.js'; import { VerifyCodeScreen } from '../../screens/index.js'; import { registrationContextProviderProps } from '../../testUtils/index.js'; import { PaperProvider } from 'react-native-paper'; describe('Verify Code Full Screen Test cases', () => { let mockOnPrevious; let mockOnResend; let mockOnClose; beforeEach(() => { mockOnPrevious = jest.fn(); mockOnResend = jest.fn(); mockOnClose = jest.fn(); }); afterEach(() => { jest.clearAllMocks(); }); const renderer = (props) => render(_jsx(PaperProvider, { children: _jsx(RegistrationContextProvider, { ...registrationContextProviderProps, children: _jsx(RegistrationWorkflow, { initialScreenIndex: 0, children: _jsx(VerifyCodeScreen, { ...props }) }) }) })); it('Should render correctly', () => { renderer(); expect(screen.getByText('Verify Email')).toBeOnTheScreen(); }); it('clicking on close Icon test with mock function', () => { renderer({ WorkflowCardHeaderProps: { onIconPress: mockOnClose(), }, }); const closeIcon = screen.getByTestId('blui-workflow-card-header-icon'); fireEvent.press(closeIcon); expect(mockOnClose).toHaveBeenCalled(); }); it('clicking on close Icon test', () => { renderer(); const closeIcon = screen.getByTestId('blui-workflow-card-header-icon'); fireEvent.press(closeIcon); expect(render).toBeTruthy(); }); it('requestResendCode function test', () => { renderer({ resendLabel: 'Send Again', onResend: mockOnResend(), }); const resendLink = screen.getByText('Send Again'); fireEvent.press(resendLink); expect(mockOnResend).toHaveBeenCalled(); }); it('onPrevious function call test', () => { renderer({ WorkflowCardActionsProps: { canGoPrevious: true, showPrevious: true, previousLabel: 'Back', onPrevious: mockOnPrevious(), }, }); const prevButton = screen.getByTestId('blui-workflow-card-actions-previous-button'); fireEvent.press(prevButton); expect(mockOnPrevious).toHaveBeenCalled(); }); it('should display loader, when next button is pressed', async () => { renderer(); const codeInput = screen.getByTestId('blui-verify-code-text-input'); fireEvent.changeText(codeInput, '123'); const nextButton = screen.getByText('Next'); expect(nextButton).toBeOnTheScreen(); fireEvent.press(nextButton); await waitFor(() => expect(screen.getByTestId('blui-spinner')).toBeOnTheScreen()); }); });