2016-10-14 00:43:20 +08:00
|
|
|
import React from 'react';
|
2018-01-24 09:35:09 +08:00
|
|
|
import { mount } from 'enzyme';
|
|
|
|
import { DateUtils } from 'mailspring-exports';
|
|
|
|
import { DatePickerPopover } from 'mailspring-component-kit';
|
2016-10-14 00:43:20 +08:00
|
|
|
|
|
|
|
const makePopover = (props = {}) => {
|
|
|
|
return mount(
|
|
|
|
<DatePickerPopover
|
|
|
|
dateOptions={{}}
|
|
|
|
header={<span className="header">my header</span>}
|
|
|
|
onSelectDate={() => {}}
|
|
|
|
{...props}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
describe('DatePickerPopover', function sendLaterPopover() {
|
|
|
|
beforeEach(() => {
|
2018-01-24 09:35:09 +08:00
|
|
|
spyOn(DateUtils, 'format').andReturn('formatted');
|
2016-10-14 00:43:20 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
describe('selectDate', () => {
|
|
|
|
it('calls props.onSelectDate', () => {
|
2018-01-24 09:35:09 +08:00
|
|
|
const onSelectDate = jasmine.createSpy('onSelectDate');
|
|
|
|
const popover = makePopover({ onSelectDate });
|
|
|
|
const fakeDate = new Date();
|
|
|
|
popover.instance().selectDate(fakeDate, 'Custom');
|
|
|
|
expect(onSelectDate).toHaveBeenCalledWith(fakeDate, 'Custom');
|
2016-10-14 00:43:20 +08:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2018-01-24 09:35:09 +08:00
|
|
|
describe('onSelectMenuOption', () => {});
|
2016-10-14 00:43:20 +08:00
|
|
|
|
2016-10-28 02:44:19 +08:00
|
|
|
describe('onCustomDateSelected', () => {
|
2016-10-14 00:43:20 +08:00
|
|
|
it('selects date', () => {
|
2018-01-24 09:35:09 +08:00
|
|
|
const popover = makePopover();
|
|
|
|
const instance = popover.instance();
|
|
|
|
spyOn(instance, 'selectDate');
|
|
|
|
const fakeDate = new Date();
|
|
|
|
instance.onCustomDateSelected(fakeDate, 'abc');
|
|
|
|
expect(instance.selectDate).toHaveBeenCalledWith(fakeDate, 'Custom');
|
2016-10-14 00:43:20 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
it('throws error if date is invalid', () => {
|
2018-01-24 09:35:09 +08:00
|
|
|
spyOn(AppEnv, 'showErrorDialog');
|
|
|
|
const popover = makePopover();
|
|
|
|
popover.instance().onCustomDateSelected(null, 'abc');
|
|
|
|
expect(AppEnv.showErrorDialog).toHaveBeenCalled();
|
2016-10-14 00:43:20 +08:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('render', () => {
|
|
|
|
it('renders the provided dateOptions', () => {
|
|
|
|
const popover = makePopover({
|
|
|
|
dateOptions: {
|
|
|
|
'label 1-': () => {},
|
|
|
|
'label 2-': () => {},
|
|
|
|
},
|
2018-01-24 09:35:09 +08:00
|
|
|
});
|
|
|
|
const items = popover.find('.item');
|
|
|
|
expect(items.at(0).text()).toEqual('label 1-formatted');
|
|
|
|
expect(items.at(1).text()).toEqual('label 2-formatted');
|
2016-10-14 00:43:20 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
it('renders header components', () => {
|
2018-01-24 09:35:09 +08:00
|
|
|
const popover = makePopover();
|
|
|
|
expect(popover.find('.header').text()).toEqual('my header');
|
|
|
|
});
|
2016-10-14 00:43:20 +08:00
|
|
|
|
|
|
|
it('renders footer components', () => {
|
|
|
|
const popover = makePopover({
|
2018-01-24 09:35:09 +08:00
|
|
|
footer: (
|
|
|
|
<span key="footer" className="footer">
|
|
|
|
footer
|
|
|
|
</span>
|
|
|
|
),
|
|
|
|
});
|
|
|
|
expect(popover.find('.footer').text()).toEqual('footer');
|
|
|
|
expect(popover.find('.date-input-section').exists()).toBe(true);
|
2016-10-14 00:43:20 +08:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|