import React from 'react'; import { shallow, mount } from 'enzyme'; import Radio from '../radio'; import RadioGroup from '../group'; describe('Radio', () => { function createRadioGroup(props) { return ( A B C ); } function createRadioGroupByOption(props) { const options = [ { label: 'A', value: 'A' }, { label: 'B', value: 'B' }, { label: 'C', value: 'C' }, ]; return ( ); } it('responses hover events', () => { const onMouseEnter = jest.fn(); const onMouseLeave = jest.fn(); const wrapper = shallow( ); wrapper.simulate('mouseenter'); expect(onMouseEnter).toHaveBeenCalled(); wrapper.simulate('mouseleave'); expect(onMouseLeave).toHaveBeenCalled(); }); it('fire change events when value changes', () => { const onChange = jest.fn(); const wrapper = mount( createRadioGroup({ onChange, }) ); const radios = wrapper.find('input'); // uncontrolled component wrapper.setState({ value: 'B' }); radios.at(0).simulate('change'); expect(onChange.mock.calls.length).toBe(1); // controlled component wrapper.setProps({ value: 'A' }); radios.at(1).simulate('change'); expect(onChange.mock.calls.length).toBe(2); }); it('won\'t fire change events when value not changes', () => { const onChange = jest.fn(); const wrapper = mount( createRadioGroup({ onChange, }) ); const radios = wrapper.find('input'); // uncontrolled component wrapper.setState({ value: 'B' }); radios.at(1).simulate('change'); expect(onChange.mock.calls.length).toBe(0); // controlled component wrapper.setProps({ value: 'A' }); radios.at(0).simulate('change'); expect(onChange.mock.calls.length).toBe(0); }); it('optional should correct render', () => { const wrapper = mount( createRadioGroupByOption() ); const radios = wrapper.find('input'); expect(radios.length).toBe(3); }); it('all children should have a name property', () => { const GROUP_NAME = 'radiogroup'; const wrapper = mount( createRadioGroup({ name: GROUP_NAME }) ); expect(wrapper.find('input[type="radio"]').forEach((el) => { expect(el.props().name).toEqual(GROUP_NAME); })); }); });