import { mount } from '@vue/test-utils' import { asyncExpect } from '@/tests/utils' import DatePicker from '../' const { RangePicker } = DatePicker describe('DatePicker with showTime', () => { it('should trigger onChange when select value', async () => { const onChangeFn = jest.fn() const onOpenChangeFn = jest.fn() const wrapper = mount({ render () { return }, }, { sync: false }) const calendarWrapper = mount({ render () { return wrapper.find({ name: 'Trigger' }).vm.getComponent() }, }, { sync: false }) await asyncExpect(() => { calendarWrapper.findAll('.ant-calendar-date').at(0).trigger('click') }) await asyncExpect(() => { expect(onChangeFn).toHaveBeenCalled() expect(onOpenChangeFn).not.toHaveBeenCalled() }) }) it('should trigger onOk when press ok button', async () => { const onOkFn = jest.fn() const onOpenChangeFn = jest.fn() const onChangeFn = jest.fn() const wrapper = mount({ render () { return }, }, { sync: false }) const calendarWrapper = mount({ render () { return wrapper.find({ name: 'Trigger' }).vm.getComponent() }, }, { sync: false }) await asyncExpect(() => { calendarWrapper.find('.ant-calendar-ok-btn').trigger('click') }) await asyncExpect(() => { expect(onOkFn).toHaveBeenCalled() expect(onOpenChangeFn).toHaveBeenCalledWith(false) expect(onChangeFn).not.toHaveBeenCalled() }) }) it('should trigger onChange when click Now link', async () => { const onOpenChangeFn = jest.fn() const onChangeFn = jest.fn() const wrapper = mount({ render () { return }, }, { sync: false }) const calendarWrapper = mount({ render () { return wrapper.find({ name: 'Trigger' }).vm.getComponent() }, }, { sync: false }) await asyncExpect(() => { calendarWrapper.find('.ant-calendar-today-btn').trigger('click') }) await asyncExpect(() => { expect(onOpenChangeFn).toHaveBeenCalledWith(false) expect(onChangeFn).toHaveBeenCalled() }) }) it('should have correct className when use12Hours is true', async () => { const wrapper = mount( { render () { return }, }, { sync: false }) const calendarWrapper = mount({ render () { return wrapper.find({ name: 'Trigger' }).vm.getComponent() }, }, { sync: false }) await asyncExpect(() => { expect(calendarWrapper.findAll('.ant-calendar-time-picker-column-4').length).toBe(0) }) calendarWrapper.findAll('.ant-calendar-time-picker-btn').at(0).trigger('click') await asyncExpect(() => { expect(calendarWrapper.findAll('.ant-calendar-time-picker-column-4').length).toBe(1) }) }) }) describe('RangePicker with showTime', async () => { it('should trigger onChange when select value', async () => { const onChangeFn = jest.fn() const onOpenChangeFn = jest.fn() const wrapper = mount( { render () { return }, }, { sync: false }) const calendarWrapper = mount({ render () { return wrapper.find({ name: 'Trigger' }).vm.getComponent() }, }, { sync: false }) await asyncExpect(() => { expect(calendarWrapper.find('.ant-calendar-time-picker-btn').classes()).toContain('ant-calendar-time-picker-btn-disabled') expect(calendarWrapper.find('.ant-calendar-ok-btn').classes()).toContain('ant-calendar-ok-btn-disabled') }) calendarWrapper.findAll('.ant-calendar-date').at(10).trigger('click') calendarWrapper.findAll('.ant-calendar-date').at(11).trigger('click') await asyncExpect(() => { expect(calendarWrapper.find('.ant-calendar-time-picker-btn').classes()).not.toContain('ant-calendar-time-picker-btn-disabled') expect(calendarWrapper.find('.ant-calendar-ok-btn').classes()).not.toContain('ant-calendar-ok-btn-disabled') }) expect(onChangeFn).toHaveBeenCalled() expect(onOpenChangeFn).not.toHaveBeenCalled() }) it('hould trigger onOk when press ok button', async () => { const onOkFn = jest.fn() const onChangeFn = jest.fn() const onOpenChangeFn = jest.fn() const wrapper = mount({ render () { return }, }, { sync: false }) const calendarWrapper = mount({ render () { return wrapper.find({ name: 'Trigger' }).vm.getComponent() }, }, { sync: false }) await asyncExpect(() => { calendarWrapper.findAll('.ant-calendar-date').at(10).trigger('click') calendarWrapper.findAll('.ant-calendar-date').at(11).trigger('click') }) onChangeFn.mockClear() calendarWrapper.find('.ant-calendar-ok-btn').trigger('click') expect(onOkFn).toHaveBeenCalled() expect(onOpenChangeFn).toHaveBeenCalledWith(false) expect(onChangeFn).not.toHaveBeenCalled() }) })