mirror of
https://github.com/streamich/react-use.git
synced 2025-12-08 18:02:14 +00:00
Also reduce max line width to 100. And remove `lint:types` step for commit sequence, it bothers when committing incomplete (wip) changes.
47 lines
1.5 KiB
TypeScript
47 lines
1.5 KiB
TypeScript
import { renderHook } from '@testing-library/react-hooks';
|
|
import { useShallowCompareEffect } from '../src';
|
|
import { useEffect } from 'react';
|
|
|
|
let options1 = { max: 10, range: { from: 0, to: 10 } };
|
|
const options2 = { max: 10, range: { from: 0, to: 10 } };
|
|
const mockEffectNormal = jest.fn();
|
|
const mockEffectShallow = jest.fn();
|
|
const mockEffectCleanup = jest.fn();
|
|
const mockEffectCallback = jest.fn().mockReturnValue(mockEffectCleanup);
|
|
|
|
it('should shallow compare dependencies', () => {
|
|
const { rerender: rerenderNormal } = renderHook(() =>
|
|
useEffect(mockEffectNormal, [options1, options2])
|
|
);
|
|
const { rerender: rerenderShallow } = renderHook(() =>
|
|
useShallowCompareEffect(mockEffectShallow, [options1, options2])
|
|
);
|
|
|
|
expect(mockEffectNormal).toHaveBeenCalledTimes(1);
|
|
expect(mockEffectShallow).toHaveBeenCalledTimes(1);
|
|
|
|
options1 = { max: 10, range: options1.range };
|
|
rerenderShallow();
|
|
rerenderNormal();
|
|
|
|
expect(mockEffectNormal).toHaveBeenCalledTimes(2);
|
|
expect(mockEffectShallow).toHaveBeenCalledTimes(1);
|
|
|
|
options1 = { max: 10, range: { from: 0, to: 10 } };
|
|
rerenderNormal();
|
|
rerenderShallow();
|
|
|
|
expect(mockEffectNormal).toHaveBeenCalledTimes(3);
|
|
expect(mockEffectShallow).toHaveBeenCalledTimes(2);
|
|
});
|
|
|
|
it('should run clean-up provided on unmount', () => {
|
|
const { unmount } = renderHook(() =>
|
|
useShallowCompareEffect(mockEffectCallback, [options1, options2])
|
|
);
|
|
expect(mockEffectCleanup).not.toHaveBeenCalled();
|
|
|
|
unmount();
|
|
expect(mockEffectCleanup).toHaveBeenCalledTimes(1);
|
|
});
|