Files
iNaturalistReactNative/tests/unit/components/SharedComponents/TaxonGridItem.test.js
Ken-ichi 75d69f8c74 feat: add simplified MyObservations for logged out users with at least 1 obs (#2599)
Simplified version of MyObs for signed out users with more than 1 obs. Currently only in debug mode.

Also:

* refactor: extract TaxonGridItem into a reusable component
* chore: TypeScript cleanup

Closes MOB-317
2025-01-10 19:48:29 -08:00

55 lines
1.3 KiB
JavaScript

import {
fireEvent,
screen
} from "@testing-library/react-native";
import TaxonGridItem from "components/SharedComponents/TaxonGridItem.tsx";
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", ( ) => {
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 }
} ) );
} );
} );