react-use/tests/createMemo.test.ts
Anton Zinovyev 8de2a3ee13 chore: move tests to top level /tests folder
chore: move all the tests to the separate directory outside of sources;

chore: remove jest.config.js (config moved to the package.json);

test: unused import in test;

test: 💍 fix tests add back x and y to useMeasure

chore: 🤖 add linter to /tests folder

ci: 🎡 limit Jest worker count for CircleCI
2019-11-08 16:55:34 -05:00

46 lines
1.3 KiB
TypeScript

import { renderHook } from '@testing-library/react-hooks';
import createMemo from '../src/createMemo';
const getDouble = jest.fn((n: number): number => n * 2);
it('should init memo hook', () => {
const useMemoGetDouble = createMemo(getDouble);
expect(useMemoGetDouble).toBeInstanceOf(Function);
});
describe('when using created memo hook', () => {
let useMemoGetDouble;
beforeEach(() => {
useMemoGetDouble = createMemo(getDouble);
});
it.each([[1], [3], [5]])('should return same result as original function for argument %d', (val: number) => {
const { result } = renderHook(() => useMemoGetDouble(val));
expect(result.current).toBe(getDouble(val));
});
it('should NOT call original function for same arguments', () => {
let initialValue = 5;
expect(getDouble).not.toHaveBeenCalled();
// it's called first time calculating for argument 5
const { rerender } = renderHook(() => useMemoGetDouble(initialValue));
expect(getDouble).toHaveBeenCalled();
getDouble.mockClear();
// it's NOT called second time calculating for argument 5
rerender();
expect(getDouble).not.toHaveBeenCalled();
getDouble.mockClear();
// it's called again calculating for different argument
initialValue = 7;
rerender();
expect(getDouble).toHaveBeenCalled();
});
});