import React from 'react'; import { mount, render } from 'enzyme'; import moment from 'moment'; import DatePicker from '../'; import focusTest from '../../../tests/shared/focusTest'; const { RangePicker } = DatePicker; describe('RangePicker', () => { focusTest(RangePicker); it('show month panel according to value', () => { const birthday = moment('2000-01-01', 'YYYY-MM-DD').locale('zh-cn'); const wrapper = mount( trigger} format="YYYY/MM/DD" showTime open /> ); wrapper.setProps({ value: [birthday, birthday] }); expect(render(wrapper.find('Trigger').instance().getComponent())) .toMatchSnapshot(); }); it('switch to corresponding month panel when click presetted ranges', () => { const birthday = moment('2000-01-01', 'YYYY-MM-DD').locale('zh-cn'); const wrapper = mount( trigger} format="YYYY/MM/DD" showTime open /> ); const rangeCalendarWrapper = mount(wrapper.find('Trigger').instance().getComponent()); rangeCalendarWrapper.find('.ant-calendar-range-quick-selector a') .simulate('click'); expect(render(wrapper.find('Trigger').instance().getComponent())) .toMatchSnapshot(); }); it('highlight range when hover presetted range', () => { const wrapper = mount( trigger} format="YYYY/MM/DD" open /> ); let rangeCalendarWrapper = mount(wrapper.find('Trigger').instance().getComponent()); rangeCalendarWrapper.find('.ant-calendar-range-quick-selector a') .simulate('mouseEnter'); rangeCalendarWrapper = mount(wrapper.find('Trigger').instance().getComponent()); expect(rangeCalendarWrapper.find('.ant-calendar-selected-day').length).toBe(2); }); it('should trigger onCalendarChange when change value', () => { const onCalendarChangeFn = jest.fn(); const wrapper = mount( trigger} onCalendarChange={onCalendarChangeFn} open /> ); const rangeCalendarWrapper = mount(wrapper.find('Trigger').instance().getComponent()); rangeCalendarWrapper.find('.ant-calendar-cell').at(15).simulate('click'); expect(onCalendarChangeFn).toHaveBeenCalled(); }); // issue: https://github.com/ant-design/ant-design/issues/5872 it('should not throw error when value is reset to `[]`', () => { const birthday = moment('2000-01-01', 'YYYY-MM-DD'); const wrapper = mount( trigger} value={[birthday, birthday]} open /> ); wrapper.setProps({ value: [] }); const rangeCalendarWrapper = mount(wrapper.find('Trigger').instance().getComponent()); expect(() => rangeCalendarWrapper.find('.ant-calendar-cell').at(15).simulate('click').simulate('click')) .not.toThrow(); }); // issue: https://github.com/ant-design/ant-design/issues/7077 it('should not throw error when select after clear', () => { const wrapper = mount( trigger} open /> ); let rangeCalendarWrapper = mount(wrapper.find('Trigger').instance().getComponent()); rangeCalendarWrapper.find('.ant-calendar-cell').at(15).simulate('click').simulate('click'); wrapper.update(); wrapper.find('.ant-calendar-picker-clear').hostNodes().simulate('click'); wrapper.find('.ant-calendar-picker-input').simulate('click'); rangeCalendarWrapper = mount(wrapper.find('Trigger').instance().getComponent()); expect(() => rangeCalendarWrapper.find('.ant-calendar-cell').at(15).simulate('click').simulate('click')) .not.toThrow(); }); });