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( );
} );
} );