Files
iNaturalistReactNative/tests/unit/components/ObsDetailsDefaultMode/CommunityTaxon.test.js
Amanda Bullington 1d340eb558 Feat: redesigned ObsDetails screen in debug mode (#2580)
* Create ObsDetailsDefaultMode and rearrange items on top of screen

* Move activity, details, and more into three different sections instead of tabs

* Styling cleanup; change Activity name to Community

* Fix scroll to activity item from Notifications

* Add ObsDetailsDefaultMode unit tests

* Show kebab menu on other users' observations
2024-12-18 19:24:24 -08:00

76 lines
1.8 KiB
JavaScript

import { fireEvent, screen } from "@testing-library/react-native";
import CommunityTaxon from "components/ObsDetailsDefaultMode/CommunityTaxon";
import React from "react";
import factory from "tests/factory";
import faker from "tests/helpers/faker";
import { renderComponent } from "tests/helpers/render";
const mockNavigate = jest.fn();
const mockKey = faker.string.uuid( );
jest.mock( "@react-navigation/native", () => {
const actualNav = jest.requireActual( "@react-navigation/native" );
return {
...actualNav,
useRoute: () => ( {
key: mockKey
} ),
useNavigation: () => ( {
navigate: mockNavigate
} )
};
} );
const mockTaxon = factory( "RemoteTaxon", {
name: faker.person.firstName( ),
rank: "genus",
preferred_common_name: faker.person.fullName( )
} );
describe( "CommunityTaxon", () => {
it( "displays unknown text if no taxon", async ( ) => {
renderComponent(
<CommunityTaxon
observation={{
taxon: null
}}
/>
);
const unknownText = screen.getByText( /Unknown/ );
expect( unknownText ).toBeVisible( );
} );
it( "displays taxon", async ( ) => {
renderComponent(
<CommunityTaxon
observation={{
taxon: mockTaxon
}}
/>
);
const taxonName = screen.getByText( mockTaxon.name );
expect( taxonName ).toBeVisible( );
} );
it( "navigates to taxon details on button press", async () => {
renderComponent(
<CommunityTaxon
observation={{
taxon: mockTaxon
}}
/>
);
fireEvent.press(
await screen.findByTestId(
`ObsDetails.taxon.${mockTaxon.id}`
)
);
expect( mockNavigate ).toHaveBeenCalledWith( expect.objectContaining( {
name: "TaxonDetails",
params: { id: mockTaxon.id }
} ) );
} );
} );