ant-design/components/splitter/__tests__/lazy.test.tsx
Oyster Lee 67738152fe
feat(Splitter): add lazy mode (#51557)
Co-authored-by: afc163 <afc163@gmail.com>
Co-authored-by: lijianan <574980606@qq.com>
2024-11-14 09:54:20 +08:00

209 lines
5.3 KiB
TypeScript

import React from 'react';
import { createEvent, fireEvent, render } from '@testing-library/react';
import { Splitter } from 'antd';
import { spyElementPrototypes } from 'rc-util/lib/test/domHook';
import { resetWarned } from 'rc-util/lib/warning';
import { triggerResize, waitFakeTimer } from '../../../tests/utils';
import { PanelProps, SplitterProps } from '../interface';
const SplitterDemo = ({ items = [{}, {}], ...props }: { items?: PanelProps[] } & SplitterProps) => (
<Splitter {...props}>
{items?.map((item, idx) => {
const key = `panel-${idx}`;
return <Splitter.Panel key={key} {...item} />;
})}
</Splitter>
);
const resizeSplitter = async () => {
triggerResize(document.body.querySelector('.ant-splitter')!);
await waitFakeTimer();
};
describe('Splitter lazy', () => {
const errSpy = jest.spyOn(console, 'error').mockImplementation(() => {});
let containerSize = 100;
beforeAll(() => {
spyElementPrototypes(HTMLElement, {
offsetWidth: {
get: () => containerSize,
},
offsetHeight: {
get: () => containerSize,
},
});
});
beforeEach(() => {
containerSize = 100;
errSpy.mockReset();
resetWarned();
});
afterEach(() => {
jest.clearAllTimers();
jest.useRealTimers();
});
const mockDrag = (draggerEle: HTMLElement, onResize: jest.Mock, offset: number) => {
// Down
const downEvent = createEvent.mouseDown(draggerEle);
(downEvent as any).pageX = 0;
(downEvent as any).pageY = 0;
fireEvent(draggerEle, downEvent);
// Move
const moveEvent = createEvent.mouseMove(window);
(moveEvent as any).pageX = offset;
(moveEvent as any).pageY = offset;
fireEvent(window, moveEvent);
expect(onResize).not.toHaveBeenCalled();
// Up
fireEvent.mouseUp(window);
};
const mockTouchDrag = (draggerEle: HTMLElement, onResize: jest.Mock, offset: number) => {
const touchStart = createEvent.touchStart(draggerEle, {
touches: [{ pageX: 0, pageY: 0 }],
});
fireEvent(draggerEle, touchStart);
// Touch Move
const touchMove = createEvent.touchMove(window, {
touches: [{ pageX: offset, pageY: offset }],
});
fireEvent(window, touchMove);
// onResize should not be called during drag
expect(onResize).not.toHaveBeenCalled();
// Touch End
fireEvent.touchEnd(window);
};
it('should only update after mouse up when lazy is true', async () => {
const onResize = jest.fn();
const onResizeEnd = jest.fn();
const { container } = render(
<SplitterDemo
items={[
{
defaultSize: '50%',
min: '30%',
max: '70%',
},
{
defaultSize: '50%',
min: '30%',
max: '70%',
},
]}
onResize={onResize}
onResizeEnd={onResizeEnd}
lazy
/>,
);
await resizeSplitter();
// Right
mockDrag(container.querySelector('.ant-splitter-bar-dragger')!, onResize, 1000);
expect(onResize).toHaveBeenCalledWith([70, 30]);
// Left
onResize.mockReset();
mockDrag(container.querySelector('.ant-splitter-bar-dragger')!, onResize, -1000);
expect(onResize).toHaveBeenCalledWith([30, 70]);
});
it('should work with touch events when lazy', async () => {
const onResize = jest.fn();
const onResizeEnd = jest.fn();
const { container } = render(
<SplitterDemo
items={[
{
defaultSize: '50%',
min: '20%',
max: '70%',
},
{
defaultSize: '50%',
min: '20%',
max: '70%',
},
]}
onResize={onResize}
onResizeEnd={onResizeEnd}
lazy
/>,
);
await resizeSplitter();
// Right
mockTouchDrag(container.querySelector('.ant-splitter-bar-dragger')!, onResize, 1000);
expect(onResize).toHaveBeenCalledWith([70, 30]);
// Left
onResize.mockReset();
mockTouchDrag(container.querySelector('.ant-splitter-bar-dragger')!, onResize, -1000);
expect(onResize).toHaveBeenCalledWith([30, 70]);
});
it('should work with vertical splitter', async () => {
const onResize = jest.fn();
const onResizeEnd = jest.fn();
const { container } = render(
<SplitterDemo
items={[
{
defaultSize: '50%',
min: '30%',
max: '70%',
},
{
defaultSize: '50%',
min: '30%',
max: '70%',
},
]}
onResize={onResize}
onResizeEnd={onResizeEnd}
layout="vertical"
lazy
/>,
);
await resizeSplitter();
// Drag Down
mockDrag(container.querySelector('.ant-splitter-bar-dragger')!, onResize, 1000);
expect(onResize).toHaveBeenCalledWith([70, 30]);
// Drag Up
onResize.mockReset();
mockDrag(container.querySelector('.ant-splitter-bar-dragger')!, onResize, -1000);
expect(onResize).toHaveBeenCalledWith([30, 70]);
// Touch Drag Down
onResize.mockReset();
mockTouchDrag(container.querySelector('.ant-splitter-bar-dragger')!, onResize, 1000);
expect(onResize).toHaveBeenCalledWith([70, 30]);
// Touch Drag Up
onResize.mockReset();
mockTouchDrag(container.querySelector('.ant-splitter-bar-dragger')!, onResize, -1000);
expect(onResize).toHaveBeenCalledWith([30, 70]);
});
});