bigbuffet-rw/app/soapbox/features/verification/steps/__tests__/email-verification.test.tsx

67 lines
1.8 KiB
TypeScript
Raw Normal View History

2022-04-04 08:54:00 -07:00
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('<EmailVerification />', () => {
it('successfully renders the Email step', async() => {
render(<EmailVerification />);
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(<EmailVerification />);
await userEvent.type(screen.getByLabelText('E-mail address'), 'foo@bar.com{enter}');
2022-04-04 08:54:00 -07:00
await waitFor(() => {
fireEvent.submit(
2022-12-20 10:14:38 -08:00
screen.getByTestId('button'), {
2022-04-04 08:54:00 -07:00
preventDefault: () => {},
},
);
});
2022-12-20 10:14:38 -08:00
expect(screen.getByTestId('button')).toHaveTextContent('Resend verification email');
2022-04-04 08:54:00 -07:00
});
});
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(<EmailVerification />);
await userEvent.type(screen.getByLabelText('E-mail address'), 'foo@bar.com{enter}');
2022-04-04 08:54:00 -07:00
await waitFor(() => {
fireEvent.submit(
2022-12-20 10:14:38 -08:00
screen.getByTestId('button'), {
2022-04-04 08:54:00 -07:00
preventDefault: () => {},
},
);
});
expect(screen.getByTestId('form-group-error')).toHaveTextContent('is taken');
});
});
});