2020-08-31 18:38:27 +02:00
|
|
|
import { shallow, ShallowWrapper } from 'enzyme';
|
2020-12-14 22:58:15 +01:00
|
|
|
import DateRangeRow from '../../../src/utils/dates/DateRangeRow';
|
|
|
|
import DateInput from '../../../src/utils/DateInput';
|
2020-01-14 20:20:27 +01:00
|
|
|
|
|
|
|
describe('<DateRangeRow />', () => {
|
2020-08-31 18:38:27 +02:00
|
|
|
let wrapper: ShallowWrapper;
|
2020-01-14 20:20:27 +01:00
|
|
|
const onEndDateChange = jest.fn();
|
|
|
|
const onStartDateChange = jest.fn();
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
wrapper = shallow(<DateRangeRow onEndDateChange={onEndDateChange} onStartDateChange={onStartDateChange} />);
|
|
|
|
});
|
|
|
|
afterEach(() => {
|
|
|
|
wrapper.unmount();
|
|
|
|
jest.clearAllMocks();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders two date inputs', () => {
|
|
|
|
const dateInput = wrapper.find(DateInput);
|
|
|
|
|
|
|
|
expect(dateInput).toHaveLength(2);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('invokes start date callback when change event is triggered on first input', () => {
|
|
|
|
const dateInput = wrapper.find(DateInput).first();
|
|
|
|
|
|
|
|
expect(onStartDateChange).not.toHaveBeenCalled();
|
|
|
|
dateInput.simulate('change');
|
|
|
|
expect(onStartDateChange).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('invokes end date callback when change event is triggered on second input', () => {
|
|
|
|
const dateInput = wrapper.find(DateInput).last();
|
|
|
|
|
|
|
|
expect(onEndDateChange).not.toHaveBeenCalled();
|
|
|
|
dateInput.simulate('change');
|
|
|
|
expect(onEndDateChange).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
});
|