Reaction测试库如何使用waitFor

编程入门 行业动态 更新时间:2024-10-28 03:18:57
本文介绍了Reaction测试库如何使用waitFor的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧! 问题描述

我正在跟踪a tutorial的反应测试。本教程有一个如下所示的简单组件,用于展示如何测试异步操作:

import React from 'react' const TestAsync = () => { const [counter, setCounter] = React.useState(0) const delayCount = () => ( setTimeout(() => { setCounter(counter + 1) }, 500) ) return ( <> <h1 data-testid="counter">{ counter }</h1> <button data-testid="button-up" onClick={delayCount}> Up</button> <button data-testid="button-down" onClick={() => setCounter(counter - 1)}>Down</button> </> ) } export default TestAsync

测试文件如下:

import React from 'react'; import { render, cleanup, fireEvent, waitForElement } from '@testing-library/react'; import TestAsync from './TestAsync' afterEach(cleanup); it('increments counter after 0.5s', async () => { const { getByTestId, getByText } = render(<TestAsync />); fireEvent.click(getByTestId('button-up')) const counter = await waitForElement(() => getByText('1')) expect(counter).toHaveTextContent('1') });

终端显示waitForElement已弃用,请改用waitFor。

如何在此测试文件中使用waitFor?

推荐答案

如果您是waiting for appearance,可以这样使用:

it('increments counter after 0.5s', async() => { const { getByTestId, getByText } = render(<TestAsync />); fireEvent.click(getByTestId('button-up')); await waitFor(() => { expect(getByText('1')).toBeInTheDocument(); }); });

使用getByText('1')获取该元素时,检查.toHaveTextContent('1')有点奇怪,因此我将其替换为.toBeInTheDocument()。

更多推荐

Reaction测试库如何使用waitFor

本文发布于:2023-10-30 03:01:23,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1541569.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:如何使用   测试   Reaction   waitFor

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!