Files
iNaturalistReactNative/tests/unit/components/SharedComponents/TaxonGridItem.test.js
Corey Farwell a43446909c Remove the need to specify TypeScript file extensions in imports (#3094)
* Don't require TS extensions in imports

* Resolve all import extension errors

* Remove file extension from import paths used in mocks

* Remove .d of type definition file paths

* Remove .d of type definition file and import as type

---------

Co-authored-by: Johannes Klein <johannes.t.klein@gmail.com>
2025-09-07 23:41:42 +02:00

56 lines
1.4 KiB
JavaScript

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(
<TaxonGridItem taxon={mockTaxon} />
);
describe( "TaxonGridItem", ( ) => {
it( "should be accessible", ( ) => {
// Disabled during the update to RN 0.78
// expect( <TaxonGridItem taxon={mockTaxon} /> ).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 }
} ) );
} );
} );