import React from 'react'; import { mount, render } from 'enzyme'; import Layout from '..'; import Icon from '../../icon'; import Menu from '../../menu'; const { Sider, Content } = Layout; describe('Layout', () => { it('detect the sider as children', async () => { const wrapper = mount( Sider Content , ); expect(wrapper.find('.ant-layout').hasClass('ant-layout-has-sider')).toBe(true); }); it('detect the sider inside the children', async () => { const wrapper = mount(
Sider
Content
, ); 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(
Sider
Content
, ); 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(
Sider
Content
, ); 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(
Sider
Content
, ); expect(wrapper.find('.ant-layout-sider').hasClass('ant-layout-sider-zero-width')).toBe(true); }); it('detect ant-layout-sider-dark as default theme', async () => { const wrapper = mount(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 () => { const wrapper = mount(Sider); expect(wrapper.find('.ant-layout-sider').hasClass('ant-layout-sider-light')).toBe(true); }); it('renders string width correctly', () => { const wrapper = render(Sider); expect(wrapper).toMatchSnapshot(); }); it('should be controlled by collapsed', () => { const wrapper = mount(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( Sider , ); expect(wrapper.find('.ant-layout').hasClass('ant-layout-has-sider')).toBe(false); }); it('render correct with Tooltip', () => { jest.useFakeTimers(); const wrapper = mount( Light , ); 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(); }); }); describe('Sider onBreakpoint', () => { beforeAll(() => { Object.defineProperty(window, 'matchMedia', { value: jest.fn(() => ({ matches: true, addListener: () => {}, removeListener: () => {}, })), }); }); it('should trigger onBreakpoint', async () => { const onBreakpoint = jest.fn(); mount( Sider , ); expect(onBreakpoint).toHaveBeenCalledWith(true); }); });