mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-23 18:04:12 +08:00
87 lines
3.6 KiB
JavaScript
87 lines
3.6 KiB
JavaScript
|
import React from 'react';
|
||
|
import { mount } from 'enzyme';
|
||
|
import DatePicker, { RangePicker } from '../';
|
||
|
|
||
|
describe('DatePicker with showTime', () => {
|
||
|
it('should trigger onChange when select value', () => {
|
||
|
const onChangeFn = jest.fn();
|
||
|
const onOpenChangeFn = jest.fn();
|
||
|
const wrapper = mount(
|
||
|
<DatePicker showTime open onChange={onChangeFn} onOpenChange={onOpenChangeFn} />
|
||
|
);
|
||
|
|
||
|
const calendarWrapper = mount(wrapper.find('Trigger').node.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(
|
||
|
<DatePicker showTime open onChange={onChangeFn} onOk={onOkFn} onOpenChange={onOpenChangeFn} />
|
||
|
);
|
||
|
|
||
|
const calendarWrapper = mount(wrapper.find('Trigger').node.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(
|
||
|
<DatePicker showTime open onChange={onChangeFn} onOpenChange={onOpenChangeFn} />
|
||
|
);
|
||
|
|
||
|
const calendarWrapper = mount(wrapper.find('Trigger').node.getComponent());
|
||
|
calendarWrapper.find('.ant-calendar-today-btn').simulate('click');
|
||
|
expect(onOpenChangeFn).toHaveBeenCalledWith(false);
|
||
|
expect(onChangeFn).toHaveBeenCalled();
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('RangePicker with showTime', () => {
|
||
|
it('should trigger onChange when select value', () => {
|
||
|
const onChangeFn = jest.fn();
|
||
|
const onOpenChangeFn = jest.fn();
|
||
|
const wrapper = mount(
|
||
|
<RangePicker showTime open onChange={onChangeFn} onOpenChange={onOpenChangeFn} />
|
||
|
);
|
||
|
|
||
|
const calendarWrapper = mount(wrapper.find('Trigger').node.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(
|
||
|
<RangePicker showTime open onOk={onOkFn} onChange={onChangeFn} onOpenChange={onOpenChangeFn} />
|
||
|
);
|
||
|
|
||
|
const calendarWrapper = mount(wrapper.find('Trigger').node.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();
|
||
|
});
|
||
|
});
|