import { fireEvent, screen, waitFor } from "@testing-library/react-native"; import AddObsModal from "components/AddObsModal"; import i18next from "i18next"; import React from "react"; // eslint-disable-next-line import/no-unresolved import mockPlatform from "react-native/Libraries/Utilities/Platform"; import { renderComponent } from "tests/helpers/render"; const mockNavigate = jest.fn(); jest.mock( "@react-navigation/native", () => { const actualNav = jest.requireActual( "@react-navigation/native" ); return { ...actualNav, useNavigation: () => ( { navigate: mockNavigate } ) }; } ); jest.mock( "react-native/Libraries/Utilities/Platform", ( ) => ( { OS: "ios", select: jest.fn( ), Version: 11 } ) ); describe( "AddObsModal", ( ) => { afterEach( () => { jest.clearAllMocks( ); } ); it( "navigates user to obs edit with no evidence", async ( ) => { renderComponent( ); const noEvidenceButton = screen.getByLabelText( i18next.t( "Observation-with-no-evidence" ) ); expect( noEvidenceButton ).toBeTruthy( ); fireEvent.press( noEvidenceButton ); await waitFor( ( ) => { expect( mockNavigate ).toHaveBeenCalledWith( "CameraNavigator", { screen: "ObsEdit", params: { previousScreen: null } } ); } ); } ); it( "navigates user to AR camera on newer devices", async ( ) => { renderComponent( ); const arCameraButton = screen.getByLabelText( i18next.t( "AR-Camera" ) ); expect( arCameraButton ).toBeTruthy( ); fireEvent.press( arCameraButton ); expect( mockNavigate ).toHaveBeenCalledWith( "CameraNavigator", { screen: "Camera", params: { camera: "AR", previousScreen: null } } ); } ); it( "hides AR camera button on older devices", async ( ) => { mockPlatform.Version = 9; renderComponent( ); const arCameraButton = screen.queryByLabelText( i18next.t( "AR-Camera" ) ); expect( arCameraButton ).toBeFalsy( ); } ); } );