UNPKG

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

Version:

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

97 lines (96 loc) 4.59 kB
import { jsx as _jsx } from "react/jsx-runtime"; import { ResetPasswordScreen } from '../../screens/ResetPasswordScreen/index.js'; import { cleanup, fireEvent, render, screen, waitFor } from '@testing-library/react-native'; import { AuthContextProvider } from '../../contexts/index.js'; import { authContextProviderProps } from '../../testUtils/index.js'; import { PaperProvider } from 'react-native-paper'; afterEach(cleanup); describe('Reset Password Screen Tests', () => { let mockFunction; beforeEach(() => { mockFunction = jest.fn(); }); afterEach(() => { jest.clearAllMocks(); }); const renderer = (props) => render(_jsx(PaperProvider, { children: _jsx(AuthContextProvider, { ...authContextProviderProps, children: _jsx(ResetPasswordScreen, { ...props }) }) })); it('renders correctly', () => { renderer(); expect(screen.getByText('Reset Password')).toBeOnTheScreen(); }); it('clicking on close Icon test', () => { renderer(); const closeIcon = screen.getByTestId('blui-workflow-card-header-icon'); fireEvent.press(closeIcon); expect(render).toBeTruthy(); }); it('Clicking on Back button test', () => { renderer({ WorkflowCardActionsProps: { onPrevious: mockFunction(), }, }); const prevButton = screen.getByTestId('blui-workflow-card-actions-previous-button'); fireEvent.press(prevButton); expect(mockFunction).toHaveBeenCalled(); }); it('should call handleOnNext when next button is clicked', () => { renderer({ showSuccessScreen: false, }); const passwordInput = screen.getByTestId('blui-set-password-password-text-field'); expect(passwordInput.props.value).toBe(''); const confirmInput = screen.getByTestId('blui-set-password-confirm-password-text-field'); expect(confirmInput.props.value).toBe(''); const nextButton = screen.getByTestId('blui-workflow-card-actions-next-button'); expect(nextButton).toBeDisabled(); fireEvent.changeText(passwordInput, 'Test@123'); fireEvent.changeText(confirmInput, 'Test@123'); expect(nextButton).toBeEnabled(); fireEvent.press(nextButton); expect(screen.getByTestId('blui-spinner')).toBeOnTheScreen(); }); it('when passed empty password requirements', () => { renderer({ PasswordProps: { passwordRequirements: [], }, }); const passwordInput = screen.getByTestId('blui-set-password-password-text-field'); expect(passwordInput.props.value).toBe(''); const confirmInput = screen.getByTestId('blui-set-password-confirm-password-text-field'); expect(confirmInput.props.value).toBe(''); const nextButton = screen.getByTestId('blui-workflow-card-actions-next-button'); expect(nextButton).toBeDisabled(); fireEvent.changeText(passwordInput, 'Test@123'); fireEvent.changeText(confirmInput, 'Test@123'); expect(nextButton).toBeEnabled(); fireEvent.press(nextButton); expect(screen.getByTestId('blui-spinner')).toBeOnTheScreen(); }); it('should return false when password is not matching as per requirements', () => { renderer(); const passwordInput = screen.getByTestId('blui-set-password-password-text-field'); expect(passwordInput.props.value).toBe(''); const confirmInput = screen.getByTestId('blui-set-password-confirm-password-text-field'); expect(confirmInput.props.value).toBe(''); fireEvent.changeText(passwordInput, 'test@123'); fireEvent.changeText(confirmInput, 'Test@123'); expect(screen.getByText('Passwords do not match')).toBeOnTheScreen(); }); it('should call onSubmit callBack function', async () => { renderer(); const passwordInput = screen.getByTestId('blui-set-password-password-text-field'); expect(passwordInput.props.value).toBe(''); const confirmInput = screen.getByTestId('blui-set-password-confirm-password-text-field'); expect(confirmInput.props.value).toBe(''); fireEvent.changeText(passwordInput, 'Test@123'); fireEvent.changeText(confirmInput, 'Test@123'); fireEvent(confirmInput, 'submitEditing'); expect(screen.getByTestId('blui-spinner')).toBeOnTheScreen(); await waitFor(() => { fireEvent.press(screen.getByText('Done')); }); expect(render).toBeTruthy(); }); });