import { fireEvent, screen, } from "@testing-library/react-native"; import TaxonGridItem from "components/SharedComponents/TaxonGridItem"; import React from "react"; import factory from "tests/factory"; import { renderComponent } from "tests/helpers/render"; const mockTaxon = factory( "RemoteTaxon" ); const mockedNavigate = jest.fn( ); jest.mock( "@react-navigation/native", () => { const actualNav = jest.requireActual( "@react-navigation/native" ); return { ...actualNav, useNavigation: () => ( { navigate: mockedNavigate, } ), useRoute: ( ) => ( { } ), useNavigationState: jest.fn( ), }; } ); jest.mock( "sharedHooks/useAuthenticatedQuery", () => ( { __esModule: true, default: ( ) => ( { data: { total_results: 0, }, } ), } ) ); const renderTaxonGridItem = ( ) => renderComponent( , ); describe( "TaxonGridItem", ( ) => { it( "should be accessible", ( ) => { // Disabled during the update to RN 0.78 // expect( ).toBeAccessible(); } ); it( "should navigate to user profile on tap", ( ) => { renderTaxonGridItem( ); fireEvent.press( screen.getByTestId( `TaxonGridItem.Pressable.${mockTaxon.id}` ) ); expect( mockedNavigate ).toHaveBeenCalledWith( expect.objectContaining( { name: "TaxonDetails", params: { id: mockTaxon.id }, } ) ); } ); } );