2022-04-04 08:53:47 -07:00
|
|
|
import { fireEvent, render, screen } from '@testing-library/react';
|
2022-03-21 11:09:01 -07:00
|
|
|
import React from 'react';
|
2022-04-04 08:53:47 -07:00
|
|
|
import { IntlProvider } from 'react-intl';
|
|
|
|
import { Provider } from 'react-redux';
|
|
|
|
import '@testing-library/jest-dom';
|
2023-04-27 11:20:53 -07:00
|
|
|
import { MemoryRouter } from 'react-router-dom';
|
2022-03-21 11:09:01 -07:00
|
|
|
|
|
|
|
import { MODAL_OPEN } from 'soapbox/actions/modals';
|
2022-07-06 15:22:11 -07:00
|
|
|
import { mockStore, rootState } from 'soapbox/jest/test-helpers';
|
2022-03-21 11:09:01 -07:00
|
|
|
|
|
|
|
import ComposeButton from '../compose-button';
|
|
|
|
|
2022-07-06 15:22:11 -07:00
|
|
|
const store = mockStore(rootState);
|
2022-04-04 08:53:47 -07:00
|
|
|
const renderComposeButton = () => {
|
|
|
|
render(
|
|
|
|
<Provider store={store}>
|
|
|
|
<IntlProvider locale='en'>
|
2023-04-27 11:20:53 -07:00
|
|
|
<MemoryRouter>
|
|
|
|
<ComposeButton />
|
|
|
|
</MemoryRouter>
|
2022-04-04 08:53:47 -07:00
|
|
|
</IntlProvider>
|
|
|
|
</Provider>,
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2022-03-21 11:09:01 -07:00
|
|
|
describe('<ComposeButton />', () => {
|
|
|
|
it('renders a button element', () => {
|
2022-04-04 08:53:47 -07:00
|
|
|
renderComposeButton();
|
2022-03-21 11:09:01 -07:00
|
|
|
|
2022-04-04 08:53:47 -07:00
|
|
|
expect(screen.getByRole('button')).toHaveTextContent('Compose');
|
2022-03-21 11:09:01 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
it('dispatches the MODAL_OPEN action', () => {
|
2022-04-04 08:53:47 -07:00
|
|
|
renderComposeButton();
|
2022-03-21 11:09:01 -07:00
|
|
|
|
|
|
|
expect(store.getActions().length).toEqual(0);
|
2022-04-04 08:53:47 -07:00
|
|
|
fireEvent.click(screen.getByRole('button'));
|
2022-03-21 11:09:01 -07:00
|
|
|
expect(store.getActions()[0].type).toEqual(MODAL_OPEN);
|
|
|
|
});
|
|
|
|
});
|