2022-04-08 16:01:43 +02:00
|
|
|
import React, { FC } from 'react';
|
|
|
|
import { BrowserRouter as Router } from 'react-router-dom';
|
2022-04-08 12:26:44 +02:00
|
|
|
import { render as rtlRender, RenderOptions } from '@testing-library/react';
|
2022-04-08 15:02:06 +02:00
|
|
|
import { SWRConfig } from 'swr';
|
2022-04-08 16:01:43 +02:00
|
|
|
import { MainThemeProvider } from 'themes/MainThemeProvider';
|
2022-04-27 09:14:44 +02:00
|
|
|
import { AnnouncerProvider } from 'component/common/Announcer/AnnouncerProvider/AnnouncerProvider';
|
2022-05-02 12:52:33 +02:00
|
|
|
import { IPermission } from 'interfaces/user';
|
|
|
|
import AccessProvider from 'component/providers/AccessProvider/AccessProvider';
|
2022-04-08 12:26:44 +02:00
|
|
|
|
|
|
|
export const render = (
|
|
|
|
ui: JSX.Element,
|
|
|
|
{
|
|
|
|
route = '/',
|
2022-05-02 12:52:33 +02:00
|
|
|
permissions = [],
|
2022-04-08 12:26:44 +02:00
|
|
|
...renderOptions
|
2022-05-02 12:52:33 +02:00
|
|
|
}: { route?: string; permissions?: IPermission[] } & Omit<
|
|
|
|
RenderOptions,
|
|
|
|
'queries'
|
|
|
|
> = {}
|
2022-04-08 12:26:44 +02:00
|
|
|
) => {
|
|
|
|
window.history.pushState({}, 'Test page', route);
|
|
|
|
|
2022-05-02 12:52:33 +02:00
|
|
|
const Wrapper: FC = ({ children }) => (
|
2022-04-08 15:02:06 +02:00
|
|
|
<SWRConfig value={{ provider: () => new Map() }}>
|
2022-05-02 12:52:33 +02:00
|
|
|
<AccessProvider permissions={permissions}>
|
2022-04-27 09:14:44 +02:00
|
|
|
<AnnouncerProvider>
|
2022-05-02 12:52:33 +02:00
|
|
|
<MainThemeProvider>
|
|
|
|
<Router>{children}</Router>
|
|
|
|
</MainThemeProvider>
|
2022-04-27 09:14:44 +02:00
|
|
|
</AnnouncerProvider>
|
2022-05-02 12:52:33 +02:00
|
|
|
</AccessProvider>
|
2022-04-08 15:02:06 +02:00
|
|
|
</SWRConfig>
|
|
|
|
);
|
2022-05-02 12:52:33 +02:00
|
|
|
|
|
|
|
return rtlRender(ui, {
|
|
|
|
wrapper: Wrapper,
|
|
|
|
...renderOptions,
|
|
|
|
});
|
2022-04-08 15:02:06 +02:00
|
|
|
};
|