import { fireEvent, render, screen } from '@testing-library/react'; import React from 'react'; import { IntlProvider } from 'react-intl'; import { Provider } from 'react-redux'; import '@testing-library/jest-dom'; import { MODAL_OPEN } from 'soapbox/actions/modals'; import { mockStore } from 'soapbox/jest/test-helpers'; import rootReducer from 'soapbox/reducers'; import ComposeButton from '../compose-button'; const store = mockStore(rootReducer(undefined, {} as any)); const renderComposeButton = () => { render( , ); }; describe('', () => { it('renders a button element', () => { renderComposeButton(); expect(screen.getByRole('button')).toHaveTextContent('Compose'); }); it('dispatches the MODAL_OPEN action', () => { renderComposeButton(); expect(store.getActions().length).toEqual(0); fireEvent.click(screen.getByRole('button')); expect(store.getActions()[0].type).toEqual(MODAL_OPEN); }); });