import { shallow, ShallowWrapper } from 'enzyme'; import { DateRangeRow } from '../../../src/utils/dates/DateRangeRow'; import { DateInput } from '../../../src/utils/DateInput'; describe('<DateRangeRow />', () => { let wrapper: ShallowWrapper; 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(); }); });