import React from 'react'; import { mount } from 'enzyme'; import DatePicker from '..'; const { RangePicker } = DatePicker; describe('DatePicker with showTime', () => { it('should trigger onChange when select value', () => { const onChangeFn = jest.fn(); const onOpenChangeFn = jest.fn(); const wrapper = mount( , ); const calendarWrapper = mount( wrapper .find('Trigger') .instance() .getComponent(), ); calendarWrapper .find('.ant-calendar-date') .at(0) .simulate('click'); expect(onChangeFn).toHaveBeenCalled(); expect(onOpenChangeFn).not.toHaveBeenCalled(); }); it('should trigger onOk when press ok button', () => { const onOkFn = jest.fn(); const onOpenChangeFn = jest.fn(); const onChangeFn = jest.fn(); const wrapper = mount( , ); const calendarWrapper = mount( wrapper .find('Trigger') .instance() .getComponent(), ); calendarWrapper.find('.ant-calendar-ok-btn').simulate('click'); expect(onOkFn).toHaveBeenCalled(); expect(onOpenChangeFn).toHaveBeenCalledWith(false); expect(onChangeFn).not.toHaveBeenCalled(); }); it('should trigger onChange when click Now link', () => { const onOpenChangeFn = jest.fn(); const onChangeFn = jest.fn(); const wrapper = mount( , ); const calendarWrapper = mount( wrapper .find('Trigger') .instance() .getComponent(), ); calendarWrapper.find('.ant-calendar-today-btn').simulate('click'); expect(onOpenChangeFn).toHaveBeenCalledWith(false); expect(onChangeFn).toHaveBeenCalled(); }); it('should have correct className when use12Hours is true', () => { const wrapper = mount(); const calendarWrapper = mount( wrapper .find('Trigger') .instance() .getComponent(), ); expect(calendarWrapper.find('.ant-calendar-time-picker-column-4').length).toBe(0); calendarWrapper .find('.ant-calendar-time-picker-btn') .at(0) .simulate('click'); expect(calendarWrapper.find('.ant-calendar-time-picker-column-4').hostNodes().length).toBe(1); }); }); describe('RangePicker with showTime', () => { it('should trigger onChange when select value', () => { const onChangeFn = jest.fn(); const onOpenChangeFn = jest.fn(); const wrapper = mount( , ); const calendarWrapper = mount( wrapper .find('Trigger') .instance() .getComponent(), ); expect( calendarWrapper .find('.ant-calendar-time-picker-btn') .hasClass('ant-calendar-time-picker-btn-disabled'), ).toBe(true); expect( calendarWrapper.find('.ant-calendar-ok-btn').hasClass('ant-calendar-ok-btn-disabled'), ).toBe(true); calendarWrapper .find('.ant-calendar-date') .at(10) .simulate('click'); calendarWrapper .find('.ant-calendar-date') .at(11) .simulate('click'); expect( calendarWrapper .find('.ant-calendar-time-picker-btn') .hasClass('ant-calendar-time-picker-btn-disabled'), ).toBe(false); expect( calendarWrapper.find('.ant-calendar-ok-btn').hasClass('ant-calendar-ok-btn-disabled'), ).toBe(false); expect(onChangeFn).toHaveBeenCalled(); expect(onOpenChangeFn).not.toHaveBeenCalled(); }); it('hould trigger onOk when press ok button', () => { const onOkFn = jest.fn(); const onChangeFn = jest.fn(); const onOpenChangeFn = jest.fn(); const wrapper = mount( , ); const calendarWrapper = mount( wrapper .find('Trigger') .instance() .getComponent(), ); calendarWrapper .find('.ant-calendar-date') .at(10) .simulate('click'); calendarWrapper .find('.ant-calendar-date') .at(11) .simulate('click'); onChangeFn.mockClear(); calendarWrapper.find('.ant-calendar-ok-btn').simulate('click'); expect(onOkFn).toHaveBeenCalled(); expect(onOpenChangeFn).toHaveBeenCalledWith(false); expect(onChangeFn).not.toHaveBeenCalled(); }); });