summaryrefslogtreecommitdiffstats
path: root/test/react/RadioGroup.spec.js
blob: 638b9c4dbce2747f2a9e39f87132ee091a9384cb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
import React from 'react';
import RadioGroup from '../../src/react/RadioGroup.js';

import renderer from 'react-test-renderer';
import {mount} from 'enzyme';

class RadioGroupForm extends React.Component {
	constructor(props) {
		super(props);
		this.state = {value: undefined};
		this.handleChange = this.handleChange.bind(this);
	}

	handleChange(val) {
		this.setState({value: val});
	}

	getValue() {
		return this.grp.getValue();
	}

	render() {
		return (
			<form >
				<RadioGroup name='grp1' title='Group A' value={this.state.value} ref={(grp) => { this.grp = grp;}} onChange={this.handleChange} data-test-id='grp1'
					options={[{value: '1', label: 'option 1'}, {value: '2', label: 'option 2'}]} />
			</form>
		);
	}
}

describe('RadioGroup', () => {
	test('RadioGroup - basic rendering', () => {
		const radio = renderer.create(<RadioGroup name='grp1' defaultValue='2' value='1' title='Group A'
			onChange={()=>{}} data-test-id='grp1'
			options={[{value: '1', label: 'option 1'}, {value: '2', label: 'option 2'}]} />).toJSON();
		expect(radio).toMatchSnapshot();
	});

	test('RadioGroup - value overrides default value', () => {
		const radio = mount(<RadioGroup name='grp1' defaultValue='2' value='1' title='Group A'
			onChange={()=>{}} data-test-id='grp1'
			options={[{value: '1', label: 'option 1'}, {value: '2', label: 'option 2'}]} />);
		expect(radio.instance().getValue()).toEqual('1');
	});

	test('RadioGroup - can have no value', () => {
		const radio = mount(<RadioGroup name='grp1' title='Group A'
			onChange={()=>{}} data-test-id='grp1'
			options={[{value: '1', label: 'option 1'}, {value: '2', label: 'option 2'}]} />);
		expect(radio.instance().getValue()).toEqual(undefined);
	});

	test('RadioGroup - can be rendered without title', () => {
		const radio = mount(<RadioGroup name='grp1'
			onChange={()=>{}} data-test-id='grp1'
			options={[{value: '1', label: 'option 1'}, {value: '2', label: 'option 2'}]} />);
		expect(radio.find('.sdc-radio-group__legend').length).toEqual(0);
	});

	test('RadioGroup - value changes', () => {
		const radio = mount(<RadioGroupForm  />);
		expect(radio.instance().getValue()).toEqual(undefined);
		radio.find('input[value="1"]').simulate('change', { target : { checked: true }});
		expect(radio.instance().getValue()).toEqual('1');
		radio.find('input[value="2"]').simulate('change', { target : { checked: true }});
		expect(radio.instance().getValue()).toEqual('2');
	});
});