ant-design/components/layout/__tests__/index.test.js

205 lines
5.7 KiB
JavaScript
Raw Normal View History

2017-11-09 20:13:59 +08:00
import React from 'react';
import { mount, render } from 'enzyme';
2017-11-09 20:13:59 +08:00
import Layout from '..';
2019-04-08 22:20:18 +08:00
import Icon from '../../icon';
import Menu from '../../menu';
2019-08-26 22:53:20 +08:00
import mountTest from '../../../tests/shared/mountTest';
2017-11-09 20:13:59 +08:00
const { Sider, Content } = Layout;
describe('Layout', () => {
2019-08-26 22:53:20 +08:00
mountTest(Layout);
mountTest(Content);
mountTest(Sider);
2017-11-09 20:13:59 +08:00
it('detect the sider as children', async () => {
const wrapper = mount(
<Layout>
<Sider>Sider</Sider>
<Content>Content</Content>
2018-12-07 16:17:45 +08:00
</Layout>,
2017-11-09 20:13:59 +08:00
);
expect(wrapper.find('.ant-layout').hasClass('ant-layout-has-sider')).toBe(true);
});
it('detect the sider inside the children', async () => {
const wrapper = mount(
<Layout>
2018-12-07 16:17:45 +08:00
<div>
<Sider>Sider</Sider>
</div>
2017-11-09 20:13:59 +08:00
<Content>Content</Content>
2018-12-07 16:17:45 +08:00
</Layout>,
2017-11-09 20:13:59 +08:00
);
expect(wrapper.find('.ant-layout').hasClass('ant-layout-has-sider')).toBe(true);
});
it('detect ant-layout-sider-has-trigger class in sider when ant-layout-sider-trigger div tag exists', async () => {
const wrapper = mount(
<Layout>
2018-12-07 16:17:45 +08:00
<div>
<Sider collapsible>Sider</Sider>
</div>
<Content>Content</Content>
2018-12-07 16:17:45 +08:00
</Layout>,
);
expect(wrapper.find('.ant-layout-sider').hasClass('ant-layout-sider-has-trigger')).toBe(true);
});
it('should have 50% width of sidebar', async () => {
const wrapper = mount(
<Layout>
2018-12-07 16:17:45 +08:00
<div>
<Sider width="50%">Sider</Sider>
</div>
<Content>Content</Content>
2018-12-07 16:17:45 +08:00
</Layout>,
);
2018-12-07 16:17:45 +08:00
expect(
wrapper
.find('.ant-layout-sider')
.at(0)
.prop('style').width,
).toBe('50%');
expect(
wrapper
.find('.ant-layout-sider')
.at(0)
.prop('style').flex,
).toBe('0 0 50%');
});
it('detect ant-layout-sider-zero-width class in sider when its width is 0%', async () => {
const wrapper = mount(
<Layout>
2018-12-07 16:17:45 +08:00
<div>
<Sider width="0%">Sider</Sider>
</div>
<Content>Content</Content>
2018-12-07 16:17:45 +08:00
</Layout>,
);
expect(wrapper.find('.ant-layout-sider').hasClass('ant-layout-sider-zero-width')).toBe(true);
});
it('detect ant-layout-sider-dark as default theme', async () => {
2018-12-07 16:17:45 +08:00
const wrapper = mount(<Sider>Sider</Sider>);
expect(wrapper.find('.ant-layout-sider').hasClass('ant-layout-sider-dark')).toBe(true);
});
it('detect ant-layout-sider-light when set light theme', async () => {
2018-12-07 16:17:45 +08:00
const wrapper = mount(<Sider theme="light">Sider</Sider>);
expect(wrapper.find('.ant-layout-sider').hasClass('ant-layout-sider-light')).toBe(true);
});
it('renders string width correctly', () => {
2018-12-07 16:17:45 +08:00
const wrapper = render(<Sider width="200">Sider</Sider>);
expect(wrapper).toMatchSnapshot();
});
it('should be controlled by collapsed', () => {
2018-12-07 16:17:45 +08:00
const wrapper = mount(<Sider>Sider</Sider>);
expect(wrapper.find('InternalSider').instance().state.collapsed).toBe(false);
wrapper.setProps({ collapsed: true });
expect(wrapper.find('InternalSider').instance().state.collapsed).toBe(true);
});
it('should not add ant-layout-has-sider when `hasSider` is `false`', () => {
const wrapper = mount(
<Layout hasSider={false}>
<Sider>Sider</Sider>
</Layout>,
);
expect(wrapper.find('.ant-layout').hasClass('ant-layout-has-sider')).toBe(false);
});
2019-04-08 22:20:18 +08:00
it('render correct with Tooltip', () => {
jest.useFakeTimers();
const wrapper = mount(
<Sider collapsible collapsed={false}>
<Menu mode="inline">
<Menu.Item key="1">
<Icon type="user" />
<span>Light</span>
</Menu.Item>
</Menu>
</Sider>,
);
wrapper.find('.ant-menu-item').simulate('mouseenter');
jest.runAllTimers();
wrapper.update();
expect(wrapper.find('.ant-tooltip-inner').length).toBeFalsy();
wrapper.find('.ant-menu-item').simulate('mouseout');
jest.runAllTimers();
wrapper.update();
wrapper.setProps({ collapsed: true });
wrapper.find('.ant-menu-item').simulate('mouseenter');
jest.runAllTimers();
wrapper.update();
expect(wrapper.find('.ant-tooltip-inner').length).toBeTruthy();
jest.useRealTimers();
});
2017-11-09 20:13:59 +08:00
});
describe('Sider', () => {
const errorSpy = jest.spyOn(console, 'error').mockImplementation(() => {});
afterEach(() => {
errorSpy.mockReset();
});
afterAll(() => {
errorSpy.mockRestore();
});
beforeAll(() => {
Object.defineProperty(window, 'matchMedia', {
2018-11-28 15:00:03 +08:00
value: jest.fn(() => ({
matches: true,
addListener: () => {},
removeListener: () => {},
})),
});
});
it('should trigger onBreakpoint', async () => {
const onBreakpoint = jest.fn();
mount(
2018-12-07 16:17:45 +08:00
<Sider breakpoint="md" onBreakpoint={onBreakpoint}>
Sider
</Sider>,
);
expect(onBreakpoint).toHaveBeenCalledWith(true);
});
it('should warning if use `inlineCollapsed` with menu', () => {
mount(
<Sider collapsible>
<Menu mode="inline" inlineCollapsed />
</Sider>,
);
expect(errorSpy).toHaveBeenCalledWith(
'Warning: [antd: Menu] `inlineCollapsed` not control Menu under Sider. Should set `collapsed` on Sider instead.',
);
});
2019-10-02 11:46:24 +08:00
it('zeroWidthTriggerStyle should work', () => {
2019-10-02 11:46:24 +08:00
const wrapper = mount(
<Sider collapsedWidth={0} collapsible zeroWidthTriggerStyle={{ background: '#F96' }}>
2019-10-02 11:46:24 +08:00
<Menu theme="dark" mode="inline" defaultSelectedKeys={['1']}>
<Menu.Item key="1">
<Icon type="user" />
<span>nav 1</span>
</Menu.Item>
</Menu>
</Sider>,
);
expect(wrapper.find('.ant-layout-sider-zero-width-trigger').props().style).toEqual({
background: '#F96',
});
});
});