import React from 'react'; import { mount, render } from 'enzyme'; import Radio from '../radio'; import RadioGroup from '../group'; import RadioButton from '../radioButton'; 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 = mount( , ); wrapper .find('div') .at(0) .simulate('mouseenter'); expect(onMouseEnter).toHaveBeenCalled(); wrapper .find('div') .at(0) .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('both of radio and radioGroup will trigger onchange event when they exists', () => { const onChange = jest.fn(); const onChangeRadioGroup = jest.fn(); const wrapper = mount( A B C , ); const radios = wrapper.find('input'); // uncontrolled component wrapper.setState({ value: 'B' }); radios.at(0).simulate('change'); expect(onChange.mock.calls.length).toBe(1); expect(onChangeRadioGroup.mock.calls.length).toBe(1); // controlled component wrapper.setProps({ value: 'A' }); radios.at(1).simulate('change'); expect(onChange.mock.calls.length).toBe(2); }); it('Trigger onChange when both of radioButton and radioGroup exists', () => { const onChange = jest.fn(); const wrapper = mount( A B C , ); 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('should only trigger once when in group with options', () => { const onChange = jest.fn(); const options = [{ label: 'Bamboo', value: 'Bamboo' }]; const wrapper = mount(); wrapper.find('input').simulate('change'); expect(onChange).toHaveBeenCalledTimes(1); }); 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); }), ); }); it('passes prefixCls down to radio', () => { const options = [{ label: 'Apple', value: 'Apple' }, { label: 'Orange', value: 'Orange' }]; const wrapper = render(); expect(wrapper).toMatchSnapshot(); }); });