reactjs - 如何测试 Material-UI Popover 关闭实现
问题描述
我想确保我的Popover元素与触发按钮的实现按预期工作。我无法进行工作测试来断言用户按下 esc 后 Popover 已关闭。我能够使用 Modal 进行此测试,但我必须在当前项目中使用 Popover。
组件代码:
import {
Button, Popover,
} from '@mui/material';
import React from 'react';
export default function SimpleModal() {
const [anchorEl, setAnchorEl] = React.useState<HTMLButtonElement | null>(null);
const handleClick = (event: React.MouseEvent<HTMLButtonElement>) => {
setAnchorEl(event.currentTarget);
};
const handleClose = () => {
setAnchorEl(null);
};
const open = Boolean(anchorEl);
const id = open ? 'user-menu' : undefined;
return (
<>
<Button
aria-controls={id}
aria-haspopup="true"
onClick={handleClick}
>
Open Modal
</Button>
<Popover open={open} onClose={handleClose}>
<h1>Text in Modal</h1>
</Popover>
</>
);
}
测试文件代码:
import { render, screen } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
import SimpleModal from './SimpleModal';
test('should close when esc key is pressed', async () => {
render(<SimpleModal />);
userEvent.click(screen.getByText('Open Modal'));
expect(screen.getByText('Text in Modal')).toBeInTheDocument();
userEvent.keyboard('{esc}');
await expect(screen.queryByText('Text in Modal')).not.toBeInTheDocument();
});
解决方案
正如@juliomalves 所建议的,将最后一个包装expect
在一个waitFor
更正的测试中:
await waitFor(() => expect(...));
推荐阅读
- html - PrimeNG - 订单列表
- continuous-deployment - Archer GRC 自动部署
- angular - 迭代角材料表
- c - “for”循环似乎循环了两次
- reactjs - 为什么这个 OpenLayers 地图不会显示在 ReactJS 应用程序中?
- python - [Python]如何使用循环区分字符串中的相同字母
- javascript - 是否可以在返回页面时仍然显示结果?
- php - 使用 Nesbot Carbon 将日期返回到计入营业时间的到达对象
- java - 如何在 webview 应用程序中打开深层链接
- python - 如何让我的播放器在屏幕中间左右移动