2020-06-09 19:29:50 -07:00
|
|
|
'use strict';
|
|
|
|
|
2022-03-21 11:09:01 -07:00
|
|
|
import { mount } from 'enzyme';
|
2022-01-10 14:17:52 -08:00
|
|
|
import { Map as ImmutableMap } from 'immutable';
|
2020-06-09 19:29:50 -07:00
|
|
|
import React from 'react';
|
|
|
|
import { IntlProvider } from 'react-intl';
|
2022-01-10 14:17:52 -08:00
|
|
|
import { Provider } from 'react-redux';
|
2022-03-21 11:09:01 -07:00
|
|
|
import { BrowserRouter, MemoryRouter } from 'react-router-dom';
|
2022-01-10 14:17:52 -08:00
|
|
|
import renderer from 'react-test-renderer';
|
2020-06-09 19:29:50 -07:00
|
|
|
import configureMockStore from 'redux-mock-store';
|
2022-01-10 14:17:52 -08:00
|
|
|
import thunk from 'redux-thunk';
|
2022-01-10 14:25:06 -08:00
|
|
|
|
2021-01-18 12:14:08 -08:00
|
|
|
import rootReducer from 'soapbox/reducers';
|
2020-06-09 19:29:50 -07:00
|
|
|
|
2022-03-18 10:20:03 -07:00
|
|
|
export const rootState = rootReducer(undefined, {});
|
|
|
|
export const getState = () => rootState;
|
|
|
|
|
2020-06-09 19:29:50 -07:00
|
|
|
// 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
|
2020-06-09 20:26:05 -07:00
|
|
|
export const createComponent = (children, props = {}) => {
|
|
|
|
props = ImmutableMap({
|
|
|
|
locale: 'en',
|
2022-03-18 10:20:03 -07:00
|
|
|
store: mockStore(rootState),
|
2020-06-09 20:26:05 -07:00
|
|
|
}).merge(props);
|
|
|
|
|
2020-06-09 20:14:48 -07:00
|
|
|
return renderer.create(
|
2020-06-09 20:26:05 -07:00
|
|
|
<Provider store={props.get('store')}>
|
|
|
|
<IntlProvider locale={props.get('locale')}>
|
2020-06-09 20:14:48 -07:00
|
|
|
<BrowserRouter>
|
|
|
|
{children}
|
|
|
|
</BrowserRouter>
|
|
|
|
</IntlProvider>
|
2020-10-07 11:08:36 -07:00
|
|
|
</Provider>,
|
2020-06-09 20:14:48 -07:00
|
|
|
);
|
2020-06-09 19:29:50 -07:00
|
|
|
};
|
2022-03-11 11:55:48 -08: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>,
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2022-03-11 11:55:48 -08:00
|
|
|
// Apply actions to the state, one at a time
|
|
|
|
export const applyActions = (state, actions, reducer) => {
|
|
|
|
return actions.reduce((state, action) => reducer(state, action), state);
|
|
|
|
};
|