Я пытаюсь пройти шутниковый тест на заказном компоненте многоразового использования, но не могу заставить его работать. Я сократил его обратно в песочнице, используя простые компоненты Material-UI, и все еще испытываю трудности с имитацией щелчка переключателя. Я попытался
wrapper.find(Radio).first().simulate('click');
wrapper.find(Radio).first().prop('onChange', { target: { checked: true } });
wrapper.find(Radio).first().simulate('change', {target: {checked: true}});
wrapper.find(Radio).first().update();
рабочая песочница с ошибочным тестом здесь: https://codesandbox.io/s/magical-raman-7f8v7
полный файл кода здесь:
import React from "react";
import { mount } from "enzyme";
import { RadioGroup, Radio } from "@material-ui/core";
import { configure } from "enzyme";
import Adapter from "enzyme-adapter-react-16";
import FormControlLabel from "@material-ui/core/FormControlLabel";
import FormControl from "@material-ui/core/FormControl";
import FormLabel from "@material-ui/core/FormLabel";
configure({ adapter: new Adapter() });
const TestComponentRadioGroup = () => {
const [value, setValue] = React.useState("other");
const handleChange = event => {
setValue(event.target.value);
};
return (
<div>
<FormControl component="fieldset">
<FormLabel component="legend">Gender</FormLabel>
<RadioGroup
aria-label="gender"
name="gender1"
value={value}
onChange={handleChange}
>
<FormControlLabel value="female" control={<Radio />} label="Female" />
<FormControlLabel value="male" control={<Radio />} label="Male" />
<FormControlLabel value="other" control={<Radio />} label="Other" />
</RadioGroup>
</FormControl>
</div>
);
};
describe("---RadioGroup Interaction Test Suite", () => {
test("Test to check selection isupdated from the last option to the first ", () => {
const wrapper = mount(<TestComponentRadioGroup />);
const radioButtonGroup = wrapper.find(RadioGroup);
expect(radioButtonGroup).toHaveLength(1);
//check that the first item isn't checked but the third one is
const radioButtons = wrapper.find(Radio);
console.log("we found " + radioButtons.length + " radiobuttons");
expect(radioButtons).toHaveLength(3);
expect( wrapper.find(Radio).first().props().checked).toBe(false);
expect( wrapper.find(Radio).last().props().checked).toBe(true);
//Desperation - I expected the first one to work!
wrapper.find(Radio).first().simulate("click");
wrapper.find(Radio).first().prop("onChange", { target: { checked: true } });
wrapper.find(Radio).first().simulate("change", { target: { checked: true } });
wrapper.find(Radio).first().update();
//I am not sure that I need this!
wrapper.update();
expect( wrapper.find(Radio).first().props().checked).toBe(true);
expect( wrapper.find(Radio).last().props().checked).toBe(false);
});
});