mirror of
https://github.com/inaturalist/iNaturalistReactNative.git
synced 2026-05-06 14:46:20 -04:00
* Remove tab bar when sharing photos into app; closes #1645 * Make explore view sticky with species as default view; closes #1614 * Fix Explore integration test; use default species view
71 lines
2.5 KiB
JavaScript
71 lines
2.5 KiB
JavaScript
import { fireEvent, screen, userEvent } from "@testing-library/react-native";
|
|
import ExploreContainer from "components/Explore/ExploreContainer";
|
|
import inatjs from "inaturalistjs";
|
|
import React from "react";
|
|
import factory, { makeResponse } from "tests/factory";
|
|
import { renderAppWithComponent } from "tests/helpers/render";
|
|
|
|
jest.mock( "sharedHooks/useStoredLayout", () => ( {
|
|
__esModule: true,
|
|
default: ( ) => ( {
|
|
layout: "list",
|
|
writeLayoutToStorage: jest.fn( )
|
|
} )
|
|
} ) );
|
|
|
|
const mockRemoteObservation = factory( "RemoteObservation", {
|
|
taxon: factory.states( "genus" )( "RemoteTaxon" )
|
|
} );
|
|
|
|
const mockTaxon = factory( "LocalTaxon" );
|
|
|
|
const actor = userEvent.setup( );
|
|
|
|
beforeAll( ( ) => {
|
|
inatjs.observations.speciesCounts.mockResolvedValue( makeResponse( [{
|
|
count: 1,
|
|
taxon: mockTaxon
|
|
}] ) );
|
|
inatjs.observations.search.mockResolvedValue( makeResponse( [mockRemoteObservation] ) );
|
|
} );
|
|
|
|
const switchToObservationsView = async ( ) => {
|
|
const speciesViewIcon = await screen.findByLabelText( /Species View/ );
|
|
expect( speciesViewIcon ).toBeVisible( );
|
|
await actor.press( speciesViewIcon );
|
|
const observationsRadioButton = await screen.findByText( "Observations" );
|
|
await actor.press( observationsRadioButton );
|
|
const confirmButton = await screen.findByText( /EXPLORE OBSERVATIONS/ );
|
|
await actor.press( confirmButton );
|
|
const obsTaxonNameElt = await screen.findByText( mockRemoteObservation.taxon.name );
|
|
expect( obsTaxonNameElt ).toBeTruthy( );
|
|
};
|
|
|
|
describe( "Explore", ( ) => {
|
|
it( "should render species view and switch to observations view list correctly", async ( ) => {
|
|
renderAppWithComponent( <ExploreContainer /> );
|
|
await switchToObservationsView( );
|
|
expect(
|
|
await screen.findByTestId( `ObsStatus.${mockRemoteObservation.uuid}` )
|
|
).toBeTruthy( );
|
|
expect(
|
|
screen.queryByTestId( `UploadIcon.progress.${mockRemoteObservation.uuid}` )
|
|
).toBeFalsy( );
|
|
} );
|
|
|
|
it( "should display observations view grid correctly", async ( ) => {
|
|
renderAppWithComponent( <ExploreContainer /> );
|
|
await switchToObservationsView( );
|
|
expect(
|
|
await screen.findByTestId( "SegmentedButton.grid" )
|
|
).toBeTruthy( );
|
|
fireEvent.press( await screen.findByTestId( "SegmentedButton.grid" ) );
|
|
expect(
|
|
await screen.findByTestId( `ObsStatus.${mockRemoteObservation.uuid}` )
|
|
).toBeTruthy( );
|
|
expect(
|
|
screen.queryByTestId( `UploadIcon.progress.${mockRemoteObservation.uuid}` )
|
|
).toBeFalsy( );
|
|
} );
|
|
} );
|