import React from 'react'; import { mount, render } from 'enzyme'; import { render as testLibRender } from '@testing-library/react'; import Radio from '..'; describe('Radio Group', () => { 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'); // controlled component wrapper.setProps({ value: 'A' }); radios.at(1).simulate('change'); expect(onChange.mock.calls.length).toBe(1); }); 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'); // controlled component wrapper.setProps({ value: 'A' }); radios.at(1).simulate('change'); expect(onChange.mock.calls.length).toBe(1); }); 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'); // controlled component wrapper.setProps({ value: 'A' }); radios.at(1).simulate('change'); expect(onChange.mock.calls.length).toBe(1); }); 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'); // 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 })); 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', style: { fontSize: 12 } }, ]; const wrapper = render(); expect(wrapper).toMatchSnapshot(); }); it('should forward ref', () => { let radioGroupRef; const { container } = testLibRender( createRadioGroupByOption({ ref: ref => { radioGroupRef = ref; }, }), ); expect(radioGroupRef).toBe(container.querySelector('.ant-radio-group')); }); it('should support data-* or aria-* props', () => { const { container } = testLibRender( createRadioGroup({ 'data-radio-group-id': 'radio-group-id', 'aria-label': 'radio-group', }), ); expect(container.firstChild.getAttribute('data-radio-group-id')).toBe('radio-group-id'); expect(container.firstChild.getAttribute('aria-label')).toBe('radio-group'); }); it('Radio type should not be override', () => { const onChange = jest.fn(); const wrapper = mount( A B C D , ); const radios = wrapper.find('input'); radios.at(1).simulate('change'); expect(onChange).toHaveBeenCalled(); expect(radios.at(1).getDOMNode().type).toBe('radio'); }); describe('value is null or undefined', () => { it('use `defaultValue` when `value` is undefined', () => { const options = [{ label: 'Bamboo', value: 'bamboo' }]; const wrapper = mount( , ); expect(wrapper.find('.ant-radio-wrapper').at(0).hasClass('ant-radio-wrapper-checked')).toBe( true, ); }); [undefined, null].forEach(newValue => { it(`should set value back when value change back to ${newValue}`, () => { const options = [{ label: 'Bamboo', value: 'bamboo' }]; const wrapper = mount(); expect(wrapper.find('.ant-radio-wrapper').at(0).hasClass('ant-radio-wrapper-checked')).toBe( true, ); wrapper.setProps({ value: newValue }); wrapper.update(); expect(wrapper.find('.ant-radio-wrapper').at(0).hasClass('ant-radio-wrapper-checked')).toBe( false, ); }); }); }); });