ant-design/components/space/__tests__/space-compact.test.tsx
Yuki Zhang 0495be222c
fix: styling issues with the Popover component within the Space.Compa… (#41707)
* fix: styling issues with the Popover component within the Space.Compact wrapper

* fix: styling issues with the Tooltip based  component within the Space.Compact wrapper

* test: update snapshots

* test: update snapshots

* refactor: memoOverlay

* test: update snapshot

* Revert "test: update snapshot"

This reverts commit 85d8142498.

* test: adjust check logic

* test: add test case for popover content

* test: update tooltip case

* fix: test coverage

* fix: lint

---------

Co-authored-by: 二货机器人 <smith3816@gmail.com>
2023-04-11 22:26:21 +08:00

315 lines
8.5 KiB
TypeScript

/* eslint-disable no-console */
import React from 'react';
import Space from '..';
import mountTest from '../../../tests/shared/mountTest';
import rtlTest from '../../../tests/shared/rtlTest';
import { render } from '../../../tests/utils';
import AutoComplete from '../../auto-complete';
import Button from '../../button';
import Cascader from '../../cascader';
import DatePicker from '../../date-picker';
import Drawer from '../../drawer';
import Dropdown from '../../dropdown';
import Input from '../../input';
import Modal from '../../modal';
import Select from '../../select';
import TimePicker from '../../time-picker';
import Tooltip from '../../tooltip';
import TreeSelect from '../../tree-select';
describe('Space.Compact', () => {
mountTest(Space.Compact);
mountTest(() => (
<Space.Compact>
<Button type="primary">Submit</Button>
</Space.Compact>
));
rtlTest(Space.Compact);
rtlTest(() => (
<Space.Compact>
<Button type="primary">Submit</Button>
</Space.Compact>
));
it('should render width empty children', () => {
const { container } = render(<Space.Compact />);
expect(container.children.length).toBe(0);
});
it('block className', () => {
const { container } = render(
<Space.Compact block>
<Input defaultValue="https://ant.design" />
<Button type="primary">Submit</Button>
</Space.Compact>,
);
expect(
container.querySelector('.ant-space-compact')?.classList.contains('ant-space-compact-block'),
).toBe(true);
});
it('compact-item className', () => {
const { container } = render(
<Space.Compact>
<Input defaultValue="https://ant.design" />
<Input.Search />
<Button type="primary">Submit</Button>
</Space.Compact>,
);
expect(
container.querySelector('.ant-input')?.classList.contains('ant-input-compact-item'),
).toBe(true);
expect(
container.querySelector('.ant-input-search')?.classList.contains('ant-input-compact-item'),
).toBe(true);
expect(
container.querySelector('.ant-input')?.classList.contains('ant-input-compact-first-item'),
).toBe(true);
expect(
container
.querySelector('.ant-btn-compact-item')
?.classList.contains('ant-btn-compact-last-item'),
).toBe(true);
});
[
{
name: 'Button',
component: Button,
targetCls: 'ant-btn',
expectClsPrefix: 'ant-btn',
},
{
name: 'AutoComplete',
component: AutoComplete,
targetCls: 'ant-select',
expectClsPrefix: 'ant-select',
},
{
name: 'Cascader',
component: Cascader,
targetCls: 'ant-cascader',
expectClsPrefix: 'ant-select',
},
{
name: 'DatePicker',
component: DatePicker,
targetCls: 'ant-picker',
expectClsPrefix: 'ant-picker',
},
{
name: 'Input',
component: Input,
targetCls: 'ant-input',
expectClsPrefix: 'ant-input',
},
{
name: 'Input.Search',
component: Input.Search,
targetCls: 'ant-input-search',
expectClsPrefix: 'ant-input',
},
{
name: 'Select',
component: Select,
targetCls: 'ant-select',
expectClsPrefix: 'ant-select',
},
{
name: 'TimePicker',
component: TimePicker,
targetCls: 'ant-picker',
expectClsPrefix: 'ant-picker',
},
{
name: 'TreeSelect',
component: TreeSelect,
targetCls: 'ant-select',
expectClsPrefix: 'ant-select',
},
].forEach(({ component, name, targetCls, expectClsPrefix }) => {
it(`compact-item for ${name}`, () => {
const { container } = render(
<Space.Compact>{React.createElement(component as any)}</Space.Compact>,
);
expect(container.querySelectorAll(`.${targetCls}`).length).toBe(1);
['compact-item', 'compact-first-item', 'compact-last-item'].forEach((suffix) => {
expect(
container
.querySelector(`.${targetCls}`)
?.classList.contains([expectClsPrefix, suffix].join('-')),
).toBe(true);
});
});
});
it('size', () => {
const { container } = render(
<Space.Compact size="small">
<Input defaultValue="https://ant.design" />
<Button type="primary">Submit</Button>
</Space.Compact>,
);
expect(container.querySelector('.ant-input')?.classList.contains('ant-input-sm')).toBe(true);
expect(container.querySelector('.ant-btn')?.classList.contains('ant-btn-sm')).toBe(true);
});
it('direction=vertical', () => {
const { container } = render(
<Space.Compact size="small" direction="vertical">
<Button type="primary">Button 1</Button>
<Button type="primary">Button 2</Button>
<Button type="primary">Button 3</Button>
<Button type="primary">Button 4</Button>
</Space.Compact>,
);
expect(
container
.querySelector('.ant-space-compact')
?.classList.contains('ant-space-compact-vertical'),
).toBe(true);
expect(
container.querySelector('.ant-btn')?.classList.contains('ant-btn-compact-vertical-item'),
).toBe(true);
expect(
container
.querySelectorAll('.ant-btn')[0]
?.classList.contains('ant-btn-compact-vertical-first-item'),
).toBe(true);
expect(
container
.querySelectorAll('.ant-btn')[3]
?.classList.contains('ant-btn-compact-vertical-last-item'),
).toBe(true);
});
it('context for Modal', () => {
render(
<Space.Compact size="small">
<Modal title="Basic Modal" open>
<Button>normal button A</Button>
<Input />
</Modal>
</Space.Compact>,
);
expect(
document.body
.querySelectorAll('.ant-modal')[0]
.querySelector('.ant-btn')
?.classList.contains('ant-btn-compact-item'),
).toBe(false);
expect(
document.body
.querySelectorAll('.ant-modal')[0]
.querySelector('.ant-input')
?.classList.contains('ant-input-compact-item'),
).toBe(false);
});
it('context for Dropdown', () => {
render(
<Space.Compact size="small">
<Dropdown.Button
open
menu={{
items: [
{
key: '1',
label: <Button>menu button</Button>,
},
],
}}
>
debug Dropdown.Button context
</Dropdown.Button>
</Space.Compact>,
);
expect(
document.body
.querySelector('.ant-dropdown')
?.querySelector('.ant-btn')
?.classList.contains('ant-btn-compact-item'),
).toBe(false);
});
it('context for Drawer', () => {
render(
<Space.Compact size="small">
<Drawer title="Basic Drawer" open>
<Button>normal button A</Button>
</Drawer>
</Space.Compact>,
);
expect(
document.body
.querySelector('.ant-drawer')
?.querySelector('.ant-btn')
?.classList.contains('ant-btn-compact-item'),
).toBe(false);
});
it('context for Tooltip', () => {
render(
<Space.Compact>
<Input placeholder="Debug Popover context" />
<Tooltip
open
overlay={
<>
<Input placeholder="Left Border" />
<DatePicker />
</>
}
trigger={['click']}
placement="bottom"
>
<Button>Settings</Button>
</Tooltip>
</Space.Compact>,
);
expect(
document.body
.querySelector('.ant-tooltip')
?.querySelector('.ant-input')
?.classList.contains('ant-input-compact-item'),
).toBe(false);
expect(
document.body
.querySelector('.ant-tooltip')
?.querySelector('.ant-picker')
?.classList.contains('ant-picker-compact-item'),
).toBe(false);
});
it('Tooltip content supports function', () => {
render(
<Space.Compact>
<Input placeholder="Debug Popover context" />
<Tooltip
open
overlay={() => (
<>
<Input placeholder="Left Border" />
<DatePicker />
</>
)}
>
<span>Tooltip will show on mouse enter.</span>
</Tooltip>
</Space.Compact>,
);
expect(
document.body
.querySelector('.ant-tooltip')
?.querySelector('.ant-input')
?.classList.contains('ant-input-compact-item'),
).toBe(false);
expect(
document.body
.querySelector('.ant-tooltip')
?.querySelector('.ant-picker')
?.classList.contains('ant-picker-compact-item'),
).toBe(false);
});
});