bigbuffet-rw/app/soapbox/test_helpers.js

62 lines
1.7 KiB
JavaScript
Raw Normal View History

'use strict';
2022-03-21 11:09:01 -07:00
import { mount } from 'enzyme';
import { Map as ImmutableMap } from 'immutable';
import React from 'react';
import { IntlProvider } from 'react-intl';
import { Provider } from 'react-redux';
2022-03-21 11:09:01 -07:00
import { BrowserRouter, MemoryRouter } from 'react-router-dom';
import renderer from 'react-test-renderer';
import configureMockStore from 'redux-mock-store';
import thunk from 'redux-thunk';
2021-01-18 12:14:08 -08:00
import rootReducer from 'soapbox/reducers';
2022-03-18 10:20:03 -07:00
export const rootState = rootReducer(undefined, {});
export const getState = () => rootState;
// Mock Redux
// https://redux.js.org/recipes/writing-tests/
const middlewares = [thunk];
export const mockStore = configureMockStore(middlewares);
2020-06-09 20:14:48 -07:00
// Create test component with i18n and Redux store, etc
export const createComponent = (children, props = {}) => {
props = ImmutableMap({
locale: 'en',
2022-03-18 10:20:03 -07:00
store: mockStore(rootState),
}).merge(props);
2020-06-09 20:14:48 -07:00
return renderer.create(
<Provider store={props.get('store')}>
<IntlProvider locale={props.get('locale')}>
2020-06-09 20:14:48 -07:00
<BrowserRouter>
{children}
</BrowserRouter>
</IntlProvider>
</Provider>,
2020-06-09 20:14:48 -07:00
);
};
2022-03-21 11:09:01 -07:00
export const createShallowComponent = (children, props = {}, routerProps = {}) => {
props = ImmutableMap({
locale: 'en',
store: mockStore(rootReducer(ImmutableMap(), {})),
}).merge(props);
return mount(
<Provider store={props.get('store')}>
<IntlProvider locale={props.get('locale')}>
<MemoryRouter {...routerProps}>
{children}
</MemoryRouter>
</IntlProvider>
</Provider>,
);
};
// Apply actions to the state, one at a time
export const applyActions = (state, actions, reducer) => {
return actions.reduce((state, action) => reducer(state, action), state);
};