ant-design-vue/components/table/__tests__/Table.test.js

100 lines
2.2 KiB
JavaScript
Raw Normal View History

2019-01-12 03:33:27 +00:00
import { shallowMount as shallow, mount } from '@vue/test-utils';
import Table from '..';
import Vue from 'vue';
2018-05-26 14:48:16 +00:00
2019-01-12 03:33:27 +00:00
const { Column, ColumnGroup } = Table;
2018-05-26 14:48:16 +00:00
describe('Table', () => {
2019-01-12 03:33:27 +00:00
it('renders JSX correctly', done => {
const data = [
{
key: '1',
firstName: 'John',
lastName: 'Brown',
age: 32,
},
{
key: '2',
firstName: 'Jim',
lastName: 'Green',
age: 42,
},
];
2018-05-26 14:48:16 +00:00
2019-01-12 03:33:27 +00:00
const wrapper = mount(
{
render() {
return (
<Table dataSource={data} pagination={false}>
<ColumnGroup title="Name">
<Column title="First Name" dataIndex="firstName" key="firstName" />
<Column title="Last Name" dataIndex="lastName" key="lastName" />
</ColumnGroup>
<Column title="Age" dataIndex="age" key="age" />
</Table>
);
},
2018-05-26 14:48:16 +00:00
},
2019-01-12 03:33:27 +00:00
{ sync: false },
);
2018-05-26 14:48:16 +00:00
Vue.nextTick(() => {
2019-01-12 03:33:27 +00:00
expect(wrapper.html()).toMatchSnapshot();
done();
});
});
2018-05-26 14:48:16 +00:00
2019-01-12 03:33:27 +00:00
it('updates columns when receiving props', done => {
const columns = [
{
title: 'Name',
key: 'name',
dataIndex: 'name',
},
];
2018-05-26 14:48:16 +00:00
const wrapper = shallow(Table, {
propsData: {
columns,
},
sync: false,
2019-01-12 03:33:27 +00:00
});
const newColumns = [
{
title: 'Title',
key: 'title',
dataIndex: 'title',
},
];
wrapper.setProps({ columns: newColumns });
2018-05-26 14:48:16 +00:00
Vue.nextTick(() => {
2019-01-12 03:33:27 +00:00
expect(wrapper.vm.columns).toBe(newColumns);
done();
});
});
2018-05-26 14:48:16 +00:00
2019-01-12 03:33:27 +00:00
it('loading with Spin', done => {
2018-05-26 14:48:16 +00:00
const loading = {
spinning: false,
delay: 500,
2019-01-12 03:33:27 +00:00
};
2018-05-26 14:48:16 +00:00
const wrapper = mount(Table, {
propsData: {
loading,
},
sync: false,
2019-01-12 03:33:27 +00:00
});
2018-05-26 14:48:16 +00:00
Vue.nextTick(async () => {
2019-01-12 03:33:27 +00:00
expect(wrapper.findAll('.ant-spin')).toHaveLength(0);
expect(wrapper.find('.ant-table-placeholder').text()).not.toEqual('');
2018-05-26 14:48:16 +00:00
2019-01-12 03:33:27 +00:00
loading.spinning = true;
wrapper.setProps({ loading });
expect(wrapper.findAll('.ant-spin')).toHaveLength(0);
2018-05-26 14:48:16 +00:00
2019-01-12 03:33:27 +00:00
await new Promise(resolve => setTimeout(resolve, 1000));
expect(wrapper.findAll('.ant-spin')).toHaveLength(1);
done();
});
});
});