import { mount } from '@vue/test-utils'; import { asyncExpect } from '@/tests/utils'; import moment from 'moment'; import DatePicker from '../'; import { setMockDate, resetMockDate } from '../../../tests/utils'; import { selectDateFromBody, $$ } from './utils'; import focusTest from '../../../tests/shared/focusTest'; const { RangePicker } = DatePicker; describe('RangePicker', () => { focusTest(RangePicker); beforeEach(() => { document.body.outerHTML = ''; setMockDate(); }); afterEach(() => { resetMockDate(); }); it('show month panel according to value', async () => { const birthday = moment('2000-01-01', 'YYYY-MM-DD').locale('zh-cn'); const wrapper = mount(RangePicker, { props: { getCalendarContainer: trigger => trigger, format: 'YYYY/MM/DD', showTime: true, open: true, }, sync: false, attachTo: 'body', }); await asyncExpect(() => { wrapper.setProps({ value: [birthday, birthday] }); }); await asyncExpect(() => { expect(document.body.innerHTML).toMatchSnapshot(); }); }); it('switch to corresponding month panel when click presetted ranges', async () => { const birthday = moment('2000-01-01', 'YYYY-MM-DD').locale('zh-cn'); const wrapper = mount( { render() { return ( trigger} format="YYYY/MM/DD" showTime open /> ); }, }, { sync: false, attachTo: 'body' }, ); await asyncExpect(() => { $$('.ant-calendar-range-quick-selector .ant-tag')[0].click(); }); await asyncExpect(() => { expect(wrapper.html()).toMatchSnapshot(); }); }); it('highlight range when hover presetted range', async () => { mount( { render() { return ( trigger} format="YYYY/MM/DD" open /> ); }, }, { sync: false, attachTo: 'body' }, ); await asyncExpect(() => { $$('.ant-calendar-range-quick-selector .ant-tag')[0].dispatchEvent( new MouseEvent('mouseenter'), ); }); await asyncExpect(() => { expect($$('.ant-calendar-selected-day').length).toBe(2); }); }); it('should trigger onCalendarChange when change value', async () => { const onCalendarChangeFn = jest.fn(); mount( { render() { return ( trigger} onCalendarChange={onCalendarChangeFn} open /> ); }, }, { sync: false, attachTo: 'body' }, ); await asyncExpect(() => { $$('.ant-calendar-cell')[15].click(); }); expect(onCalendarChangeFn).toHaveBeenCalled(); }); // issue: https://github.com/ant-design/ant-design/issues/5872 it('should not throw error when value is reset to `[]`', async () => { const birthday = moment('2000-01-01', 'YYYY-MM-DD'); const wrapper = mount(RangePicker, { props: { getCalendarContainer: trigger => trigger, value: [birthday, birthday], open: true, }, sync: false, attachTo: 'body', }); await asyncExpect(() => { wrapper.setProps({ value: [] }); }); await asyncExpect(() => { expect(() => { const cell = $$('.ant-calendar-cell')[15]; cell.click(); cell.click(); }).not.toThrow(); }); }); // issue: https://github.com/ant-design/ant-design/issues/7077 it('should not throw error when select after clear', async () => { mount(RangePicker, { props: { getCalendarContainer: trigger => trigger, open: true, }, sync: false, attachTo: 'body', }); await asyncExpect(() => { const cell = $$('.ant-calendar-cell')[15]; cell.click(); cell.click(); }); $$('.ant-calendar-picker-clear')[0].click(); $$('.ant-calendar-picker-input')[0].click(); await asyncExpect(() => { expect(() => { const cell = $$('.ant-calendar-cell')[15]; cell.click(); cell.click(); }).not.toThrow(); }); }); it('clear hover value after panel close', async () => { mount( { render() { return (
); }, }, { sync: false, attachTo: 'body' }, ); await asyncExpect(() => { $$('.ant-calendar-picker-input')[0].click(); }); await asyncExpect(() => { $$('.ant-calendar-cell')[25].click(); $$('.ant-calendar-cell')[27].dispatchEvent(new MouseEvent('mouseenter')); document.dispatchEvent(new MouseEvent('mousedown')); }, 500); await asyncExpect(() => { $$('.ant-calendar-picker-input')[0].click(); }); await asyncExpect(() => { expect($$('.ant-calendar-cell')[23].getAttribute('class').split(' ')).toContain( 'ant-calendar-in-range-cell', ); }); }); describe('preset range', () => { beforeEach(() => { document.body.outerHTML = ''; }); it('static range', async () => { const range = [moment().subtract(2, 'd'), moment()]; const format = 'YYYY-MM-DD HH:mm:ss'; const wrapper = mount(RangePicker, { props: { ranges: { 'recent two days': range }, format, }, sync: false, attachTo: 'body', }); await asyncExpect(() => { $$('.ant-calendar-picker-input')[0].click(); }); await asyncExpect(() => { $$('.ant-calendar-range-quick-selector .ant-tag')[0].click(); }, 500); await asyncExpect(() => { expect(wrapper.findAll('.ant-calendar-range-picker-input')[0].element.value).toBe( range[0].format(format), ); }); await asyncExpect(() => { const inputs = wrapper.findAll('.ant-calendar-range-picker-input'); expect(inputs[inputs.length - 1].element.value).toBe(range[1].format(format)); }); await asyncExpect(() => {}); }); it('function range', async () => { const range = [moment().subtract(2, 'd'), moment()]; const format = 'YYYY-MM-DD HH:mm:ss'; const wrapper = mount(RangePicker, { props: { ranges: { 'recent two days': () => range }, format, }, sync: false, attachTo: 'body', }); await asyncExpect(() => { $$('.ant-calendar-picker-input')[0].click(); }); await asyncExpect(() => { $$('.ant-calendar-range-quick-selector .ant-tag')[0].click(); }, 500); await asyncExpect(() => { expect(wrapper.findAll('.ant-calendar-range-picker-input')[0].element.value).toBe( range[0].format(format), ); }); await asyncExpect(() => { const inputs = wrapper.findAll('.ant-calendar-range-picker-input'); expect(inputs[inputs.length - 1].element.value).toBe(range[1].format(format)); }); }); }); // https://github.com/ant-design/ant-design/issues/6999 it('input date manually', async () => { mount(RangePicker, { props: { open: true }, sync: false, attachTo: 'body' }); const dateString = '2008-12-31'; let input = null; await asyncExpect(() => { input = $$('.ant-calendar-input')[0]; input.value = dateString; }); expect($$('.ant-calendar-input')[0].value).toBe(dateString); }); it('triggers onOk when click on preset range', async () => { const handleOk = jest.fn(); const range = [moment().subtract(2, 'd'), moment()]; const wrapper = mount(RangePicker, { props: { ranges: { 'recent two days': range }, onOk: handleOk, }, sync: false, attachTo: 'body', }); await asyncExpect(() => { wrapper.find('.ant-calendar-picker-input').trigger('click'); }); await asyncExpect(() => { $$('.ant-calendar-range-quick-selector .ant-tag')[0].click(); }, 500); await asyncExpect(() => { expect(handleOk).toBeCalledWith(range); }); }); // https://github.com/ant-design/ant-design/issues/9267 it('invali end date not throw error', async () => { const wrapper = mount(RangePicker, { sync: false, attachTo: 'body' }); await asyncExpect(() => { wrapper.find('.ant-calendar-picker-input').trigger('click'); }); await asyncExpect(() => { selectDateFromBody(moment('2017-09-18'), 0); selectDateFromBody(moment('2017-10-18'), 1); }, 500); await asyncExpect(() => { wrapper.find('.ant-calendar-picker-input').trigger('click'); }); await asyncExpect(() => { const input = $$('.ant-calendar-input')[1]; expect(() => { input.value = '2016-01-01'; }).not.toThrow(); }); }); // https://github.com/ant-design/ant-design/issues/11631 it('triggers onOpenChange when click on preset range', async () => { const handleOpenChange = jest.fn(); const range = [moment().subtract(2, 'd'), moment()]; const wrapper = mount( { render() { return ( ); }, }, { sync: false, attachTo: 'body', }, ); await asyncExpect(() => { wrapper.find('.ant-calendar-picker-input').trigger('click'); }, 0); await asyncExpect(() => { $$('.ant-calendar-range-quick-selector .ant-tag')[0].click(); }, 1000); await asyncExpect(() => { expect(handleOpenChange).toBeCalledWith(false); }); }); });