MaterialUI + React 测试库:升级到版本 4 后,单元测试 Select MenuItem 中断

Vin*_*ado 6 reactjs jestjs material-ui react-testing-library

我有一个使用 Jest 和 React 测试库的单元测试来填充和提交表单。问题是在将 Material UI 升级到版本 4 后,我的单元测试无法选择一个选项。错误是:“无法找到带有文本的元素:巴西”巴西是我尝试选择的文本选项。使用 Material UI 版本 3 工作得很好。


测试代码 - 给出错误:“无法找到带有文本的元素:巴西。”


fireEvent.click(getByTestId("id-country"));
const countryOption = await waitForElement(() => getByText("Brazil"));
fireEvent.click(countryOption);
Run Code Online (Sandbox Code Playgroud)

反应组件代码


<Grid item xs={12} sm={4}>
        <TextField
            id="select-country"
            name="country"
            select
            helperText={touched.country ? errors.country : ""}
            error={touched.country && Boolean(errors.country)}
            required
            label="Country"
            onChange={handleChange}
            value={values.country}
            className={classes.selectField}
            SelectProps={{
                SelectDisplayProps: {
                    "data-testid": "id-country"
                }
            }}
        >
            {countryEnum.map(country => (
                <MenuItem key={country.type} value={country.type}>
                    {country.label}
                </MenuItem>
            ))}
        </TextField>
</Grid>
Run Code Online (Sandbox Code Playgroud)

Rya*_*ell 15

对于 v4,Select已更改为 open onmouseDown而不是click( https://github.com/mui-org/material-ui/pull/17978 )。

所以而不是:

fireEvent.click(getByTestId("id-country"));
Run Code Online (Sandbox Code Playgroud)

你应该有:

fireEvent.mouseDown(getByTestId("id-country"));
Run Code Online (Sandbox Code Playgroud)

  • 我已经找这个好几个小时了!!谢谢 (3认同)