mirror of
https://github.com/inaturalist/iNaturalistReactNative.git
synced 2026-05-06 22:56:12 -04:00
* Refactor to use watchPosition
* Update useWatchPosition with permissions/retry
* Replace useUserLocation with useWatchPosition and fix tests; return userLocation from watch position hook
* Only update observation keys when there's an observation
* Improve TypeScript definitions
* Revert TypeScript commit
* Revert "Only update observation keys when there's an observation"
This reverts commit a4cd17a513.
* Code cleanup: make useWatchPosition more modular
* Code cleanup; location permission in ObsEdit instead of subcomponent
* Use correct accuracy in Camera photos
* Camera fixes
* Fixes to watching position in ObsEdit
* Fix useWatchPosition tests
* Fix tests
* Make sure state updates when renavigating to OsEdit; test fixes
91 lines
2.7 KiB
JavaScript
91 lines
2.7 KiB
JavaScript
import Geolocation from "@react-native-community/geolocation";
|
|
import { renderHook, waitFor } from "@testing-library/react-native";
|
|
import { useWatchPosition } from "sharedHooks";
|
|
|
|
const mockPositions = [
|
|
{
|
|
coords: {
|
|
latitude: 1,
|
|
longitude: 1,
|
|
accuracy: 100
|
|
}
|
|
},
|
|
{
|
|
coords: {
|
|
latitude: 2,
|
|
longitude: 2,
|
|
accuracy: 20
|
|
}
|
|
},
|
|
{
|
|
coords: {
|
|
latitude: 3,
|
|
longitude: 3,
|
|
accuracy: 8
|
|
}
|
|
}
|
|
];
|
|
|
|
describe( "useWatchPosition with inaccurate location", ( ) => {
|
|
beforeEach( ( ) => {
|
|
Geolocation.watchPosition.mockReset( );
|
|
// Mock so success gets called immediately and so that three subsequent
|
|
// calls succeed with changing coordinates and improving accuracy
|
|
Geolocation.watchPosition.mockImplementationOnce( success => success( mockPositions[0] ) );
|
|
} );
|
|
|
|
// Geolocation.watchPosition should have been called and that roughly
|
|
// marks the end of async effects, so hopefull this prevents "outside of
|
|
// act" warnings
|
|
afterEach( ( ) => waitFor( ( ) => {
|
|
expect( Geolocation.watchPosition ).toHaveBeenCalled( );
|
|
} ) );
|
|
|
|
it( "should be loading by default", async ( ) => {
|
|
const { result } = renderHook( ( ) => useWatchPosition( { shouldFetchLocation: true } ) );
|
|
await waitFor( ( ) => {
|
|
expect( result.current.isFetchingLocation ).toBeTruthy( );
|
|
} );
|
|
} );
|
|
|
|
it( "should return a user location", async ( ) => {
|
|
const { result } = renderHook( ( ) => useWatchPosition( { shouldFetchLocation: true } ) );
|
|
await waitFor( ( ) => {
|
|
expect( result.current.userLocation ).toBeDefined( );
|
|
} );
|
|
expect( result?.current?.userLocation?.latitude )
|
|
.toEqual( mockPositions[0].coords.latitude );
|
|
} );
|
|
} );
|
|
|
|
describe( "useWatchPosition with accurate location", ( ) => {
|
|
beforeEach( ( ) => {
|
|
Geolocation.watchPosition.mockReset( );
|
|
|
|
Geolocation.watchPosition
|
|
.mockImplementationOnce( success => success( mockPositions[2] ) );
|
|
} );
|
|
|
|
it( "should stop watching position when target accuracy reached", async ( ) => {
|
|
const { result } = renderHook( ( ) => useWatchPosition( { shouldFetchLocation: true } ) );
|
|
await waitFor( ( ) => {
|
|
expect( result.current.userLocation?.positional_accuracy )
|
|
.toEqual( mockPositions[2].coords.accuracy );
|
|
} );
|
|
expect( Geolocation.clearWatch ).toHaveBeenCalledTimes( 1 );
|
|
} );
|
|
} );
|
|
|
|
describe( "useWatchPosition when shouldn't fetch", ( ) => {
|
|
beforeEach( ( ) => {
|
|
Geolocation.watchPosition.mockReset( );
|
|
} );
|
|
|
|
it( "should not watch position when shouldFetchLocation is false", async ( ) => {
|
|
renderHook( ( ) => useWatchPosition( { shouldFetchLocation: false } ) );
|
|
await waitFor( ( ) => {
|
|
expect( Geolocation.watchPosition ).not.toHaveBeenCalled( );
|
|
} );
|
|
} );
|
|
} );
|