import userEvent from '@testing-library/user-event'; import React from 'react'; import { __stub } from 'soapbox/api'; import { fireEvent, render, screen, waitFor } from 'soapbox/jest/test-helpers'; import EmailVerification from '../email-verification'; describe('', () => { it('successfully renders the Email step', async() => { render(); expect(screen.getByRole('heading')).toHaveTextContent('Enter your email address'); }); describe('with valid data', () => { beforeEach(() => { __stub(mock => { mock.onPost('/api/v1/pepe/verify_email/request') .reply(200, {}); }); }); it('successfully submits', async() => { render(); await userEvent.type(screen.getByLabelText('E-mail address'), 'foo@bar.com{enter}'); await waitFor(() => { fireEvent.submit( screen.getByRole('button'), { preventDefault: () => {}, }, ); }); expect(screen.getByRole('button')).toHaveTextContent('Resend verification email'); }); }); describe('with invalid data', () => { beforeEach(() => { __stub(mock => { mock.onPost('/api/v1/pepe/verify_email/request') .reply(422, { error: 'email_taken', }); }); }); it('renders errors', async() => { render(); await userEvent.type(screen.getByLabelText('E-mail address'), 'foo@bar.com{enter}'); await waitFor(() => { fireEvent.submit( screen.getByRole('button'), { preventDefault: () => {}, }, ); }); expect(screen.getByTestId('form-group-error')).toHaveTextContent('is taken'); }); }); });