Files
iNaturalistReactNative/tests/unit/components/SharedComponents/PhotoScroll.test.js
Ken-ichi 0c7c807b56 Realm & other bugfixes (#950)
* Updated faker; fixed bug w/ DisplayTaxonName trying to modify a Realm object
* Fixed crash going from ObsDetail to ObsEdit
* Fixed bug fetching observation dates (not clear how this didn't instantly crash_
* Bugfix: MyObs observation fetch was failing on taxa w/ float rank_level
2023-12-04 13:47:00 -08:00

50 lines
1.5 KiB
JavaScript

import { faker } from "@faker-js/faker";
import { render, screen } from "@testing-library/react-native";
import PhotoScroll from "components/SharedComponents/PhotoScroll";
import _ from "lodash";
import React from "react";
import factory from "../../../factory";
const mockObservation = factory( "LocalObservation", {
created_at: "2022-11-27T19:07:41-08:00",
time_observed_at: "2023-12-14T21:07:41-09:30",
observationPhotos: [
factory( "LocalObservationPhoto", {
photo: {
id: faker.number.int( ),
attribution: faker.lorem.sentence( ),
licenseCode: "cc-by-nc",
url: faker.image.url( )
}
} )
]
} );
const mockPhotos = _.compact(
Array.from( mockObservation.observationPhotos ).map( op => op.photo )
);
describe( "PhotosScroll", () => {
it.todo( "should not have accessibility errors" );
// it( "should not have accessibility errors", async () => {
// const photoScroll = <PhotoScroll photos={mockPhotos} />;
// expect( photoScroll ).toBeAccessible( );
// } );
it( "should show the main carousel", async () => {
render( <PhotoScroll photos={mockPhotos} /> );
expect( screen.getByTestId( "photo-scroll" ) ).toBeTruthy();
} );
it( "should show photo with given url", async () => {
render( <PhotoScroll photos={mockPhotos} /> );
const photo = await screen.findByTestId( "PhotoScroll.photo" );
expect( photo.props.source ).toStrictEqual(
{
uri: mockObservation.observationPhotos[0].photo.url
}
);
} );
} );