import userEvent from '@testing-library/user-event'; import React from 'react'; import '@testing-library/jest-dom'; import { __stub } from 'soapbox/api'; import { fireEvent, render, screen, waitFor } from 'soapbox/jest/test-helpers'; import SmsVerification from '../sms-verification'; describe('', () => { it('successfully renders the SMS step', async() => { render(); expect(screen.getByRole('heading')).toHaveTextContent('Enter your phone number'); }); describe('with valid data', () => { beforeEach(() => { __stub(mock => { mock.onPost('/api/v1/pepe/verify_sms/request').reply(200, {}); }); }); it('successfully submits', async() => { __stub(mock => { mock.onPost('/api/v1/pepe/verify_sms/confirm').reply(200, {}); }); render(); await userEvent.type(screen.getByLabelText('Phone Number'), '+1 (555) 555-5555'); await waitFor(() => { fireEvent.submit( screen.getByRole('button'), { preventDefault: () => {}, }, ); }); expect(screen.getByRole('heading')).toHaveTextContent('Verification code'); expect(screen.getByTestId('toast')).toHaveTextContent('A verification code has been sent to your phone number.'); await userEvent.type(screen.getByLabelText('Please enter verification code. Digit 1'), '1'); await userEvent.type(screen.getByLabelText('Digit 2'), '2'); await userEvent.type(screen.getByLabelText('Digit 3'), '3'); await userEvent.type(screen.getByLabelText('Digit 4'), '4'); await userEvent.type(screen.getByLabelText('Digit 5'), '5'); await userEvent.type(screen.getByLabelText('Digit 6'), '6'); }); it('handle expired tokens', async() => { __stub(mock => { mock.onPost('/api/v1/pepe/verify_sms/confirm').reply(422, {}); }); render(); await userEvent.type(screen.getByLabelText('Phone Number'), '+1 (555) 555-5555'); await waitFor(() => { fireEvent.submit( screen.getByRole('button'), { preventDefault: () => {}, }, ); }); expect(screen.getByRole('heading')).toHaveTextContent('Verification code'); expect(screen.getByTestId('toast')).toHaveTextContent('A verification code has been sent to your phone number.'); await userEvent.type(screen.getByLabelText('Please enter verification code. Digit 1'), '1'); await userEvent.type(screen.getByLabelText('Digit 2'), '2'); await userEvent.type(screen.getByLabelText('Digit 3'), '3'); await userEvent.type(screen.getByLabelText('Digit 4'), '4'); await userEvent.type(screen.getByLabelText('Digit 5'), '5'); await userEvent.type(screen.getByLabelText('Digit 6'), '6'); expect(screen.getByTestId('toast')).toHaveTextContent('Your SMS token has expired.'); }); }); describe('with invalid data', () => { beforeEach(() => { __stub(mock => { mock.onPost('/api/v1/pepe/verify_sms/request') .reply(422, {}); }); }); it('renders errors', async() => { render(); await userEvent.type(screen.getByLabelText('Phone Number'), '+1 (555) 555-5555'); await waitFor(() => { fireEvent.submit( screen.getByRole('button'), { preventDefault: () => {}, }, ); }); expect(screen.getByTestId('toast')).toHaveTextContent('Failed to send SMS message to your phone number.'); }); }); });