import { shallow } from 'enzyme'; import React from 'react'; import TimeSelectInput from './TimeSelectInput'; import TimeSelectMinute from './TimeSelectMinute'; describe('TimeSelectMinute', () => { const props = { minute: 29, time: new Date(2020, 10, 3), isDisabled: false, onChange: jest.fn(), }; let component: any; beforeEach(() => { component = shallow(); }); it('should render TimeSelectInput component with correct props', () => { expect(component.find(TimeSelectInput).props()).toEqual({ value: props.minute, name: 'Minute', onChange: expect.any(Function), disabled: props.isDisabled, step: 15, }); }); describe('when onChange prop is called on TimeSelectInput', () => { beforeEach(() => { props.onChange.mockReset(); }); describe('and next value is under 0', () => { it('should set correct minute', () => { component.find(TimeSelectInput).props().onChange('-20'); expect(props.onChange).toBeCalledWith(new Date('2020-11-02T23:45:00')); }); }); describe('and next value is over 59', () => { it('should set correct minute', () => { component.find(TimeSelectInput).props().onChange('60'); expect(props.onChange).toBeCalledWith(new Date('2020-11-03T01:00:00')); }); }); describe('and next value is 15 mins more than prior hour', () => { it('should set correct minute', () => { component = shallow(); component.find(TimeSelectInput).props().onChange('35'); expect(props.onChange).toBeCalledWith(new Date('2020-11-03T00:30:00')); }); }); describe('and next value is 15 mins less than prior hour', () => { it('should set correct minute', () => { component = shallow(); component.find(TimeSelectInput).props().onChange('5'); expect(props.onChange).toBeCalledWith(new Date('2020-11-03T00:00:00')); }); }); it('should set correct minute', () => { component.find(TimeSelectInput).props().onChange('34'); expect(props.onChange).toBeCalledWith(new Date('2020-11-03T00:34:00')); }); }); });