All files / test-utils render.tsx

100% Statements 7/7
75% Branches 3/4
100% Functions 3/3
100% Lines 7/7

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37            21x                             21x 21x   21x 31x   31x             21x    
import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
import { render as testingLibraryRender, type RenderOptions } from '@testing-library/react';
import { MantineProvider } from '@mantine/core';
import { mantineTheme } from '../src/theme/mantineTheme';
 
function createTestQueryClient() {
  return new QueryClient({
    defaultOptions: {
      queries: {
        retry: false, // Don't retry in tests
        gcTime: Infinity, // Keep cache for test duration
      },
    },
  });
}
 
interface WrapperProps {
  children: React.ReactNode;
}
 
export function render(ui: React.ReactElement, options?: RenderOptions) {
  const testQueryClient = createTestQueryClient();
  const { wrapper: UserWrapper, ...rest } = options ?? {};
 
  const CombinedWrapper = ({ children }: WrapperProps) => {
    const content = UserWrapper ? <UserWrapper>{children}</UserWrapper> : children;
 
    return (
      <QueryClientProvider client={testQueryClient}>
        <MantineProvider theme={mantineTheme}>{content}</MantineProvider>
      </QueryClientProvider>
    );
  };
 
  return testingLibraryRender(ui, { wrapper: CombinedWrapper, ...rest });
}