kafka-ui/kafka-ui-react-app/src/lib/testHelpers.tsx
David Bejanyan e3ee4c7fa7
FE: Redirect the user to the wizard page if no clusters (#3481)
* Redirect the user to the wizard page if no clusters

* added test case

* changed test case for redirect to new cluster config page

* replaced mockedUsedNavigate with mockedNavigate

* added ability to show dashboard if clicking on it

---------

Co-authored-by: Oleg Shur <workshur@gmail.com>
2023-04-04 07:49:05 +04:00

171 lines
4.7 KiB
TypeScript

import React, { PropsWithChildren, ReactElement, useMemo } from 'react';
import {
MemoryRouter,
MemoryRouterProps,
Route,
Routes,
} from 'react-router-dom';
import fetchMock from 'fetch-mock';
import { Provider } from 'react-redux';
import { ThemeProvider } from 'styled-components';
import { theme } from 'theme/theme';
import {
render,
renderHook,
RenderOptions,
waitFor,
} from '@testing-library/react';
import { AnyAction, Store } from 'redux';
import { RootState } from 'redux/interfaces';
import { configureStore } from '@reduxjs/toolkit';
import rootReducer from 'redux/reducers';
import {
QueryClient,
QueryClientProvider,
UseQueryResult,
} from '@tanstack/react-query';
import { ConfirmContextProvider } from 'components/contexts/ConfirmContext';
import ConfirmationModal from 'components/common/ConfirmationModal/ConfirmationModal';
import {
GlobalSettingsContext,
GlobalSettingsContextProps,
} from 'components/contexts/GlobalSettingsContext';
import { UserInfoRolesAccessContext } from 'components/contexts/UserInfoRolesAccessContext';
import { RolesType, modifyRolesData } from './permissions';
interface CustomRenderOptions extends Omit<RenderOptions, 'wrapper'> {
preloadedState?: Partial<RootState>;
store?: Store<Partial<RootState>, AnyAction>;
initialEntries?: MemoryRouterProps['initialEntries'];
globalSettings?: GlobalSettingsContextProps;
userInfo?: {
roles?: RolesType;
rbacFlag: boolean;
};
}
interface WithRouteProps {
children: React.ReactNode;
path: string;
}
export const expectQueryWorks = async (
mock: fetchMock.FetchMockStatic,
result: { current: UseQueryResult<unknown, unknown> }
) => {
await waitFor(() => expect(result.current.isFetched).toBeTruthy());
expect(mock.calls()).toHaveLength(1);
expect(result.current.data).toBeDefined();
};
export const WithRoute: React.FC<WithRouteProps> = ({ children, path }) => {
return (
<Routes>
<Route path={path} element={children} />
</Routes>
);
};
export const TestQueryClientProvider: React.FC<PropsWithChildren<unknown>> = ({
children,
}) => {
// use new QueryClient instance for each test run to avoid issues with cache
const queryClient = new QueryClient({
defaultOptions: { queries: { retry: false } },
});
return (
<QueryClientProvider client={queryClient}>{children}</QueryClientProvider>
);
};
/**
* @description it will create a UserInfo Provider that will actually
* disable the rbacFlag , to user if you can pass it as an argument
* */
const TestUserInfoProvider: React.FC<
PropsWithChildren<{ data?: { roles?: RolesType; rbacFlag: boolean } }>
> = ({ children, data }) => {
const contextValue = useMemo(() => {
const roles = modifyRolesData(data?.roles);
return {
username: 'test',
rbacFlag: !!(typeof data?.rbacFlag === 'undefined'
? false
: data?.rbacFlag),
roles,
};
}, [data]);
return (
<UserInfoRolesAccessContext.Provider value={contextValue}>
{children}
</UserInfoRolesAccessContext.Provider>
);
};
const customRender = (
ui: ReactElement,
{
preloadedState,
store = configureStore<RootState>({
reducer: rootReducer,
preloadedState,
}),
initialEntries,
globalSettings = { hasDynamicConfig: false },
userInfo,
...renderOptions
}: CustomRenderOptions = {}
) => {
// overrides @testing-library/react render.
const AllTheProviders: React.FC<PropsWithChildren<unknown>> = ({
children,
}) => (
<TestQueryClientProvider>
<GlobalSettingsContext.Provider value={globalSettings}>
<ThemeProvider theme={theme}>
<TestUserInfoProvider data={userInfo}>
<ConfirmContextProvider>
<Provider store={store}>
<MemoryRouter initialEntries={initialEntries}>
<div>
{children}
<ConfirmationModal />
</div>
</MemoryRouter>
</Provider>
</ConfirmContextProvider>
</TestUserInfoProvider>
</ThemeProvider>
</GlobalSettingsContext.Provider>
</TestQueryClientProvider>
);
return render(ui, { wrapper: AllTheProviders, ...renderOptions });
};
const customRenderHook = (hook: () => UseQueryResult<unknown, unknown>) =>
renderHook(hook, { wrapper: TestQueryClientProvider });
export { customRender as render, customRenderHook as renderQueryHook };
export class EventSourceMock {
url: string;
close: () => void;
open: () => void;
error: () => void;
onmessage: () => void;
constructor(url: string) {
this.url = url;
this.open = jest.fn();
this.error = jest.fn();
this.onmessage = jest.fn();
this.close = jest.fn();
}
}