import { mount } from '@vue/test-utils'
import { asyncExpect } from '@/tests/utils'
import moment from 'moment'
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()
})
})