mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-06 19:18:03 +08:00
57 lines
1.2 KiB
TypeScript
57 lines
1.2 KiB
TypeScript
|
import React from 'react';
|
||
|
|
||
|
import { act, render } from '../../../tests/utils';
|
||
|
import useUniqueMemo from '../hooks/useUniqueMemo';
|
||
|
|
||
|
describe('Table', () => {
|
||
|
beforeEach(() => {
|
||
|
jest.useFakeTimers();
|
||
|
});
|
||
|
|
||
|
afterEach(() => {
|
||
|
jest.clearAllTimers();
|
||
|
jest.useRealTimers();
|
||
|
});
|
||
|
|
||
|
it('useSyncState', () => {
|
||
|
const sharedObjDeps1 = {};
|
||
|
const sharedObjDeps2 = {};
|
||
|
|
||
|
let calledTimes = 0;
|
||
|
|
||
|
const Test = ({ depName }: { depName: string }) => {
|
||
|
useUniqueMemo(() => {
|
||
|
calledTimes += 1;
|
||
|
return depName;
|
||
|
}, [depName, sharedObjDeps1, 'bamboo', sharedObjDeps2]);
|
||
|
return null;
|
||
|
};
|
||
|
|
||
|
// Reuse the same memo
|
||
|
const { rerender } = render(
|
||
|
<>
|
||
|
<Test depName="light" />
|
||
|
<Test depName="light" />
|
||
|
<Test depName="light" />
|
||
|
</>,
|
||
|
);
|
||
|
|
||
|
expect(calledTimes).toBe(1);
|
||
|
|
||
|
// Different deps should clean up the cache
|
||
|
act(() => {
|
||
|
jest.advanceTimersByTime(1000 * 60 * 20);
|
||
|
});
|
||
|
|
||
|
for (let i = 0; i < 20000; i += 1) {
|
||
|
rerender(<Test depName="diff" key={i} />);
|
||
|
}
|
||
|
rerender(<Test depName="clear" />);
|
||
|
calledTimes = 0;
|
||
|
|
||
|
// Back should recompute
|
||
|
rerender(<Test depName="light" />);
|
||
|
expect(calledTimes).toBe(1);
|
||
|
});
|
||
|
});
|