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