import React from 'react'; import { mount } from 'enzyme'; import Table from '..'; import mountTest from '../../../tests/shared/mountTest'; import rtlTest from '../../../tests/shared/rtlTest'; import { sleep } from '../../../tests/utils'; const { Column, ColumnGroup } = Table; describe('Table', () => { mountTest(Table); rtlTest(Table); const warnSpy = jest.spyOn(console, 'error').mockImplementation(() => {}); afterAll(() => { warnSpy.mockRestore(); }); it('renders JSX correctly', () => { const data = [ { key: '1', firstName: 'John', lastName: 'Brown', age: 32, }, { key: '2', firstName: 'Jim', lastName: 'Green', age: 42, }, ]; const wrapper = mount( {/* eslint-disable-next-line react/jsx-curly-brace-presence */} {'invalid child'}
, ); expect(wrapper.render()).toMatchSnapshot(); }); it('updates columns when receiving props', () => { const columns = [ { title: 'Name', key: 'name', dataIndex: 'name', }, ]; const wrapper = mount(); const newColumns = [ { title: 'Title', key: 'title', dataIndex: 'title', }, ]; wrapper.setProps({ columns: newColumns }); expect(wrapper.find('th').text()).toEqual('Title'); }); it('loading with Spin', async () => { const loading = { spinning: false, delay: 500, }; const wrapper = mount(
); expect(wrapper.find('.ant-spin')).toHaveLength(0); expect( wrapper .find('.ant-table-placeholder') .hostNodes() .text(), ).not.toEqual(''); loading.spinning = true; wrapper.setProps({ loading }); expect(wrapper.find('.ant-spin')).toHaveLength(0); await sleep(500); wrapper.update(); expect(wrapper.find('.ant-spin')).toHaveLength(1); }); // https://github.com/ant-design/ant-design/issues/22733 it('support loading tip', async () => { const wrapper = mount(
); await sleep(500); wrapper.update(); expect(wrapper.find('.ant-spin')).toHaveLength(1); }); it('renders custom components correctly when it changes', () => { const BodyWrapper1 = props => ; const BodyWrapper2 = props => ; const wrapper = mount(
); wrapper.setProps({ components: { body: { wrapper: BodyWrapper2 } } }); expect(wrapper.find('tbody').props().id).toBe('wrapper2'); }); it('props#columnsPageRange and props#columnsPageSize do not warn anymore', () => { const data = [ { key: '1', age: 32, }, { key: '2', age: 42, }, ]; const errorSpy = jest.spyOn(console, 'error').mockImplementation(() => {}); const columnsPageRange = jest.fn(); const columnsPageSize = jest.fn(); mount(
, ); expect(errorSpy).not.toHaveBeenCalledWith( '`columnsPageRange` and `columnsPageSize` are removed, please use fixed columns instead, see: https://u.ant.design/fixed-columns.', ); expect(columnsPageRange).not.toHaveBeenCalled(); expect(columnsPageSize).not.toHaveBeenCalled(); }); it('support onHeaderCell', () => { const onClick = jest.fn(); const wrapper = mount( ({ onClick }) }]} />, ); wrapper.find('th').simulate('click'); expect(onClick).toHaveBeenCalled(); }); it('should not crash when column children is empty', () => { mount(
, ); }); it('prevent touch event', () => { const wrapper = mount(
, ); wrapper.simulate('touchmove'); }); });