import React from 'react'; import configureMockStore from 'redux-mock-store'; import { fireEvent, waitFor } from '@testing-library/react'; import thunk from 'redux-thunk'; import { renderWithProvider } from '../../../../../test/lib/render-helpers'; import mockState from '../../../../../test/data/mock-state.json'; import { yesLetsTry, nevermind, } from '../../../../../app/_locales/en/messages.json'; import CancelTransaction from '.'; const mockCreateCancelTransaction = jest.fn(); const mockShowModal = jest.fn(); const mockHideModal = jest.fn(); jest.mock('../../../../store/actions.ts', () => { return { createCancelTransaction: () => mockCreateCancelTransaction, showModal: () => mockShowModal, hideModal: () => mockHideModal, }; }); describe('CancelTransaction Component', () => { afterEach(() => { mockCreateCancelTransaction.mockClear(); mockShowModal.mockClear(); mockHideModal.mockClear(); }); const props = { newGasFee: '0x1319718a5000', // 21000000000000 }; it('should match snapshot', () => { const mockStore = configureMockStore()(mockState); const { container } = renderWithProvider( , mockStore, ); expect(container).toMatchSnapshot(); }); it('should call create cancel transaction and hide modal', async () => { const mockStore = configureMockStore([thunk])(mockState); const { queryByText } = renderWithProvider( , mockStore, ); fireEvent.click(queryByText(yesLetsTry.message)); await waitFor(() => { expect(mockCreateCancelTransaction).toHaveBeenCalled(); expect(mockHideModal).toHaveBeenCalled(); }); }); it('should hide modal when clicking "Nevermind" button', () => { const mockStore = configureMockStore([thunk])(mockState); const { queryByText } = renderWithProvider( , mockStore, ); fireEvent.click(queryByText(nevermind.message)); expect(mockCreateCancelTransaction).not.toHaveBeenCalled(); expect(mockHideModal).toHaveBeenCalled(); }); it('should hide modal when closing from header', () => { const mockStore = configureMockStore([thunk])(mockState); const { queryByTestId } = renderWithProvider( , mockStore, ); fireEvent.click(queryByTestId('modal-header-close')); expect(mockCreateCancelTransaction).not.toHaveBeenCalled(); expect(mockHideModal).toHaveBeenCalled(); }); });