import React from 'react'; import { render, mount } from 'enzyme'; import { renderToJson } from 'enzyme-to-json'; import Table from '..'; describe('Table.pagination', () => { const columns = [{ title: 'Name', dataIndex: 'name', }]; const data = [ { key: 0, name: 'Jack' }, { key: 1, name: 'Lucy' }, { key: 2, name: 'Tom' }, { key: 3, name: 'Jerry' }, ]; const pagination = { pageSize: 2 }; function createTable(props) { return ( ); } function renderedNames(wrapper) { return wrapper.find('TableRow').map(row => row.props().record.name); } it('renders pagination correctly', () => { const wrapper = render(createTable()); expect(renderToJson(wrapper)).toMatchSnapshot(); }); it('paginate data', () => { const wrapper = mount(createTable()); expect(renderedNames(wrapper)).toEqual(['Jack', 'Lucy']); wrapper.find('Pager').last().simulate('click'); expect(renderedNames(wrapper)).toEqual(['Tom', 'Jerry']); }); it('repaginates when pageSize change', () => { const wrapper = mount(createTable()); wrapper.setProps({ pagination: { pageSize: 1 } }); expect(renderedNames(wrapper)).toEqual(['Jack']); }); it('fires change event', () => { const handleChange = jest.fn(); const noop = () => {}; const wrapper = mount(createTable({ pagination: { ...pagination, onChange: noop, onShowSizeChange: noop }, onChange: handleChange, })); wrapper.find('Pager').last().simulate('click'); expect(handleChange).toBeCalledWith( { current: 2, onChange: noop, onShowSizeChange: noop, pageSize: 2, }, {}, {} ); }); it('should display pagination as prop pagination changed', () => { const wrapper = mount(createTable()); expect(wrapper.find('.ant-pagination')).toHaveLength(1); expect(wrapper.find('.ant-pagination-item')).toHaveLength(2); wrapper.setProps({ pagination: false }); expect(wrapper.find('.ant-pagination')).toHaveLength(0); wrapper.setProps({ pagination }); expect(wrapper.find('.ant-pagination')).toHaveLength(1); expect(wrapper.find('.ant-pagination-item')).toHaveLength(2); wrapper.find('.ant-pagination-item-2').simulate('click'); expect(renderedNames(wrapper)).toEqual(['Tom', 'Jerry']); wrapper.setProps({ pagination: false }); expect(wrapper.find('.ant-pagination')).toHaveLength(0); wrapper.setProps({ pagination: true }); expect(wrapper.find('.ant-pagination')).toHaveLength(1); expect(wrapper.find('.ant-pagination-item')).toHaveLength(1); // pageSize will be 10 expect(renderedNames(wrapper)).toEqual(['Jack', 'Lucy', 'Tom', 'Jerry']); }); });