e36d26cb91
Use human-readable message from the API as the default See merge request soapbox-pub/soapbox!2126
114 lines
3.3 KiB
TypeScript
114 lines
3.3 KiB
TypeScript
import React from 'react';
|
|
|
|
import { __stub } from 'soapbox/api';
|
|
|
|
import { fireEvent, render, screen, waitFor } from '../../../jest/test-helpers';
|
|
import Registration from '../registration';
|
|
|
|
describe('<Registration />', () => {
|
|
it('renders', () => {
|
|
render(<Registration />);
|
|
|
|
expect(screen.getByRole('heading')).toHaveTextContent(/register your account/i);
|
|
});
|
|
|
|
describe('with valid data', () => {
|
|
beforeEach(() => {
|
|
__stub(mock => {
|
|
mock.onPost('/api/v1/pepe/accounts').reply(200, {});
|
|
mock.onPost('/api/v1/apps').reply(200, {});
|
|
mock.onPost('/oauth/token').reply(200, {});
|
|
mock.onGet('/api/v1/accounts/verify_credentials').reply(200, { id: '123' });
|
|
mock.onGet('/api/v1/instance').reply(200, {});
|
|
});
|
|
});
|
|
|
|
it('handles successful submission', async() => {
|
|
render(<Registration />);
|
|
|
|
await waitFor(() => {
|
|
fireEvent.submit(screen.getByTestId('button'), { preventDefault: () => {} });
|
|
});
|
|
|
|
await waitFor(() => {
|
|
expect(screen.getByTestId('toast')).toHaveTextContent(/welcome to/i);
|
|
});
|
|
|
|
expect(screen.queryAllByRole('heading')).toHaveLength(0);
|
|
});
|
|
});
|
|
|
|
describe('with invalid data', () => {
|
|
it('handles 422 errors', async() => {
|
|
__stub(mock => {
|
|
mock.onPost('/api/v1/pepe/accounts').reply(
|
|
422, {
|
|
error: 'user_taken',
|
|
},
|
|
);
|
|
});
|
|
|
|
render(<Registration />);
|
|
|
|
await waitFor(() => {
|
|
fireEvent.submit(screen.getByTestId('button'), { preventDefault: () => {} });
|
|
});
|
|
|
|
await waitFor(() => {
|
|
expect(screen.getByTestId('toast')).toHaveTextContent(/this username has already been taken/i);
|
|
});
|
|
});
|
|
|
|
it('handles 422 errors with messages', async() => {
|
|
__stub(mock => {
|
|
mock.onPost('/api/v1/pepe/accounts').reply(
|
|
422, {
|
|
error: 'user_vip',
|
|
message: 'This username is unavailable.',
|
|
},
|
|
);
|
|
});
|
|
|
|
render(<Registration />);
|
|
|
|
await waitFor(() => {
|
|
fireEvent.submit(screen.getByTestId('button'), { preventDefault: () => {} });
|
|
});
|
|
|
|
expect(screen.getByTestId('toast')).toHaveTextContent(/this username is unavailable/i);
|
|
});
|
|
|
|
it('handles generic errors', async() => {
|
|
__stub(mock => {
|
|
mock.onPost('/api/v1/pepe/accounts').reply(500, {});
|
|
});
|
|
|
|
render(<Registration />);
|
|
|
|
await waitFor(() => {
|
|
fireEvent.submit(screen.getByTestId('button'), { preventDefault: () => {} });
|
|
});
|
|
|
|
await waitFor(() => {
|
|
expect(screen.getByTestId('toast')).toHaveTextContent(/failed to register your account/i);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('validations', () => {
|
|
it('should undisable button with valid password', async() => {
|
|
render(<Registration />);
|
|
|
|
expect(screen.getByTestId('button')).toBeDisabled();
|
|
fireEvent.change(screen.getByTestId('password-input'), { target: { value: 'Password' } });
|
|
expect(screen.getByTestId('button')).not.toBeDisabled();
|
|
});
|
|
|
|
it('should disable button with invalid password', async() => {
|
|
render(<Registration />);
|
|
|
|
fireEvent.change(screen.getByTestId('password-input'), { target: { value: 'Passwor' } });
|
|
expect(screen.getByTestId('button')).toBeDisabled();
|
|
});
|
|
});
|
|
});
|