Files
iNaturalistReactNative/tests/unit/components/Camera/StandardCamera.test.js
Amanda Bullington cf896a3a17 Toolbar upload status refreshes when user returns to MyObs (#1942)
* Write some failing navigation tests for MyObs navigation

* Add one more failing test to check for empty screen after all obs are deleted

* Update what happens on blur

* Changes to focus effect

* Revert "Changes to focus effect"

This reverts commit c779504cdf.

* Test: toolbar status reset when user leaves screen

* Unmock useFocusEffect in Jest; fix tests

* Minor nav mocking updates

* Fix import
2024-08-09 11:21:25 -07:00

94 lines
2.5 KiB
JavaScript

import {
fireEvent, render, screen, waitFor
} from "@testing-library/react-native";
import StandardCamera from "components/Camera/StandardCamera/StandardCamera";
import React from "react";
import useStore from "stores/useStore";
import factory from "tests/factory";
import { wrapInNavigationContainer } from "tests/helpers/render";
jest.mock( "components/MediaViewer/MediaViewerModal", ( ) => jest.fn( ( ) => null ) );
const initialStoreState = useStore.getState( );
const mockPhotoUris = [
"https://inaturalist-open-data.s3.amazonaws.com/photos/1/large.jpeg",
"https://inaturalist-open-data.s3.amazonaws.com/photos/2/large.jpeg",
"https://inaturalist-open-data.s3.amazonaws.com/photos/3/large.jpeg"
];
const mockObservation = factory( "RemoteObservation", {
observationPhotos: [
factory( "RemoteObservationPhoto", {
photo: factory( "RemotePhoto", {
url: mockPhotoUris[0]
} )
} ),
factory( "RemoteObservationPhoto", {
photo: factory( "RemotePhoto", {
url: mockPhotoUris[1]
} )
} ),
factory( "RemoteObservationPhoto", {
photo: factory( "RemotePhoto", {
url: mockPhotoUris[2]
} )
} )
]
} );
const renderCamera = ( ) => render(
wrapInNavigationContainer(
<StandardCamera
camera={{}}
device={{}}
/>
)
);
beforeAll( async () => {
useStore.setState( initialStoreState, true );
} );
describe( "StandardCamera", ( ) => {
beforeEach( ( ) => {
useStore.setState( {
currentObservation: mockObservation,
observations: [mockObservation]
} );
} );
it( "deletes a photo on long press", async ( ) => {
renderCamera( );
const { cameraUris } = useStore.getState( );
const photoImage = screen.getByTestId(
`PhotoCarousel.displayPhoto.${cameraUris[2]}`
);
const predeletedPhoto = screen.queryByTestId(
`PhotoCarousel.displayPhoto.${cameraUris[2]}`
);
expect( predeletedPhoto ).toBeVisible( );
fireEvent( photoImage, "onLongPress" );
const deleteMode = screen.getByTestId(
`PhotoCarousel.deletePhoto.${cameraUris[2]}`
);
await waitFor( ( ) => {
expect( deleteMode ).toBeVisible( );
} );
fireEvent.press( deleteMode );
renderCamera( );
const undeletedPhoto = screen.getByTestId(
`PhotoCarousel.displayPhoto.${cameraUris[1]}`
);
expect( undeletedPhoto ).toBeVisible( );
const deletedPhoto = screen.queryByTestId(
`PhotoCarousel.displayPhoto.${cameraUris[2]}`
);
await waitFor( ( ) => {
expect( deletedPhoto ).toBeFalsy( );
} );
} );
} );