import { configureMockStore } from '@jedmao/redux-mock-store'; import { QueryClientProvider } from '@tanstack/react-query'; import { render, RenderOptions } from '@testing-library/react'; import { renderHook, RenderHookOptions } from '@testing-library/react-hooks'; import { merge } from 'immutable'; import React, { FC, ReactElement } from 'react'; import { IntlProvider } from 'react-intl'; import { Provider } from 'react-redux'; import { MemoryRouter } from 'react-router-dom'; import { Action, applyMiddleware, createStore } from 'redux'; import thunk from 'redux-thunk'; import '@testing-library/jest-dom'; import { ChatProvider } from 'soapbox/contexts/chat-context'; import { StatProvider } from 'soapbox/contexts/stat-context'; import { queryClient } from 'soapbox/queries/client'; import NotificationsContainer from '../features/ui/containers/notifications_container'; import { default as rootReducer } from '../reducers'; import type { AnyAction } from 'redux'; import type { AppDispatch } from 'soapbox/store'; // Mock Redux // https://redux.js.org/recipes/writing-tests/ const rootState = rootReducer(undefined, {} as Action); const mockStore = configureMockStore([thunk]); /** Apply actions to the state, one at a time. */ const applyActions = (state: any, actions: any, reducer: any) => { return actions.reduce((state: any, action: any) => reducer(state, action), state); }; const createTestStore = (initialState: any) => createStore(rootReducer, initialState, applyMiddleware(thunk)); const TestApp: FC = ({ children, storeProps, routerProps = {} }) => { let store: ReturnType; let appState = rootState; if (storeProps && typeof storeProps.getState !== 'undefined') { // storeProps is a store store = storeProps; } else if (storeProps) { // storeProps is state appState = merge(rootState, storeProps); store = createTestStore(appState); } else { store = createTestStore(appState); } const props = { locale: 'en', store, }; return ( {children} ); }; const customRender = ( ui: ReactElement, options?: Omit, store?: any, routerProps?: any, ) => render(ui, { wrapper: () => , ...options, }); /** Like renderHook, but with access to the Redux store. */ const customRenderHook = ( callback: (props?: any) => any, options?: Omit, 'wrapper'>, store?: any, ) => { return renderHook(callback, { wrapper: ({ children }) => , ...options, }); }; const mockWindowProperty = (property: any, value: any) => { const { [property]: originalProperty } = window; delete window[property]; beforeAll(() => { Object.defineProperty(window, property, { configurable: true, writable: true, value, }); }); afterAll(() => { window[property] = originalProperty; }); }; export * from '@testing-library/react'; export { customRender as render, customRenderHook as renderHook, mockStore, applyActions, rootState, rootReducer, mockWindowProperty, createTestStore, queryClient, };