import '@shopify/flash-list/jestSetup'; import { BottomSheetModalProvider } from '@gorhom/bottom-sheet'; import { NavigationContainer } from '@react-navigation/native'; import type { RenderOptions } from '@testing-library/react-native'; import { render, userEvent } from '@testing-library/react-native'; import type { ReactElement } from 'react'; import React from 'react'; const createAppWrapper = () => { return ({ children }: { children: React.ReactNode }) => ( {children} ); }; const customRender = ( ui: ReactElement, options?: Omit, ) => { const Wrapper = createAppWrapper(); // make sure we have a new wrapper for each render return render(ui, { wrapper: Wrapper, ...options }); }; // use this if you want to test user events export const setup = ( ui: ReactElement, options?: Omit, ) => { const Wrapper = createAppWrapper(); return { user: userEvent.setup(), ...render(ui, { wrapper: Wrapper, ...options }), }; }; export * from '@testing-library/react-native'; export { customRender as render };