import type { ShlinkApiClient } from '@shlinkio/shlink-js-sdk'; import type { RenderOptions } from '@testing-library/react'; import { render } from '@testing-library/react'; import userEvent from '@testing-library/user-event'; import { fromPartial } from '@total-typescript/shoehorn'; import type { PropsWithChildren, ReactElement } from 'react'; import { Provider } from 'react-redux'; import { ContainerProvider } from '../../src/container/context'; import type { RootState } from '../../src/store'; import { setUpStore } from '../../src/store'; export const renderWithEvents = (element: ReactElement, options?: RenderOptions) => ({ user: userEvent.setup(), ...render(element, options), }); export type RenderOptionsWithState = Omit & { /** Initial state for the redux store */ initialState?: Partial; /** * If provided, it will set this as the `buildShlinkApiClient` dependency in the `ContainerProvider`. * If more dependencies are needed, then explicitly define your own `ContainerProvider` and make sure it includes a * `buildShlinkApiClient` service. * * Defaults to vi.fn() */ buildShlinkApiClient?: () => ShlinkApiClient; }; /** * Render provided ReactElement wrapped in a redux `Provider` and a `ContainerProvider` with a single * `buildShlinkApiClient` dependency. */ export const renderWithStore = ( element: ReactElement, { initialState = {}, buildShlinkApiClient = vi.fn(), ...options }: RenderOptionsWithState = {}, ) => { const store = setUpStore(initialState); const Wrapper = ({ children }: PropsWithChildren) => ( {children} ); return { store, ...renderWithEvents(element, { ...options, wrapper: Wrapper }), }; };