首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何测试驱动开发 React 组件?

什么是 TDD TDD(Test-driven development),就是测试驱动开发,是敏捷开发中的一项核心实践和技术,也是一种软件设计方法论。...本文将以创建一个 Confirmation 组件来说明,如何在 React 中如何实现测试驱动开发。...测试组件 首先使用 create-react-app 初始化一个 react 项目。目前 cra 已经内置了 @testing-library/react 作为测试框架。...例如点击的按钮,就是 role="button" ;会让这个元素可点击;也可以使用 role 属性告诉辅助设备(如屏幕阅读器)这个元素所扮演的角色。...expect(getByRole('button', { name: '确认' })).toBeInTheDocument() }) 在这里使用 name 选项,因为我们知道这个组件中至少还有一个按钮,

2.2K10

如何测试驱动开发 React 组件?

什么是TDD TDD(Test-driven development),就是测试驱动开发,是敏捷开发中的一项核心实践和技术,也是一种软件设计方法论。...本文将以创建一个 Confirmation 组件来说明,如何在 React 中如何实现测试驱动开发。...测试组件 首先使用 create-react-app 初始化一个 react 项目。目前 cra 已经内置了 @testing-library/react 作为测试框架。...例如点击的按钮,就是 role="button" ;会让这个元素可点击;也可以使用 role 属性告诉辅助设备(如屏幕阅读器)这个元素所扮演的角色。...); expect(getByRole('button', {name: '确认'})).toBeInTheDocument(); }); 在这里使用 name 选项,因为我们知道这个组件中至少还有一个按钮

2.1K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    搞懂了,React 中原来要这样测试自定义 Hooks

    React 中自定义的 Hooks 为开发者提供了重用公共方法的能力。然而,如果你是一个测试新手的话,测试这些钩子可能会很棘手。...本文中,我们将探索如何使用 React Testing Library 测试库来测试自定义钩子。 如何测试 React 组件 开始前,首先让我们回顾一下如何测试一个基本的 React 组件。...使用 screen 对象获取 DOM 元素(可以使用 ByRole 来查询元素)。 使用 @testing-library/user-event 库模拟用户事件。 对呈现的输出进行断言。...使用 renderHook() 测试自定义 Hooks 要在 React 中测试自定义钩子,我们可以使用 React Testing Library 测试库提供的 renderHook() 函数。...使用 act() 来更新 state 为了测试 useCounter() 钩子的 increment 按钮功能是否如预期的那样工作,我们可以使用 renderHook() 来渲染钩子并调用 result.current.increment

    43840

    Jest与React Testing Library:前端测试的最佳实践

    Jest 是一个功能丰富的JavaScript测试框架,而React Testing Library 是一种提倡以用户角度编写测试的库,它鼓励测试组件的行为而不是内部实现细节。...fireEvent函数触发组件上的事件,比如点击按钮或提交表单。...const button = screen.getByRole('button');fireEvent.click(button);清理和解构在每个测试之后,确保清理掉任何副作用,如添加到DOM中的元素...afterEach钩子可以用于此目的:afterEach(() => { cleanup();});异步测试使用waitFor或async/await处理异步操作,确保组件在测试中达到期望状态:it(...> jest.advanceTimersByTime(1000)); expect(screen.getByText('Loading...')).toBeInTheDocument();});组件库的测试对于复杂的组件库

    19200

    如何测试 React 异步组件?

    前言 本文承接上文 如何测试驱动开发 React 组件?,这次我将继续使用 @testing-library/react 来测试我们的 React 应用,并简要简要说明如何测试异步组件。...button type="submit">登录 ); } export default Login; 为了方便理解我们这边没有使用其他三方库...,若在生产环境中,我推荐使用 react-hook-form 测试提交 接下来测试下 onSubmit 方法必须包含 username 和 password, 我们需要模拟用户输入,这个时候我们需要安装...测试用例: 失败后文档中显示服务端的消息 失败后按钮又显示登录并且可以点击 test("onSubmit failures", async () => { const message = "账号或密码错误...,我们在来写博客列表的测试已经不难了,我们先来写下测试用例: 接口请求中页面显示 loading 请求成功显示博客列表 列表为空显示暂无数据 请求失败显示服务端错误 博客列表代码 下面的代码中, 使用了

    3.3K50

    Sentry 开发者贡献指南 - 前端(ReactJS生态)

    Typing DefaultProps 类(Class)组件 函数式(Function)组件 参考 使用 Hooks 使用库中的 hooks 使用 react 的内置 hooks 使用 context...使用库中的 hooks 如果一个库提供了 hooks,你应该使用它们。通常,这将是使用库的唯一方法。...在需要少量状态或访问 react 原语(如引用和上下文)的展示组件中,它们通常是一个不错的选择。例如,具有滑出(slide-out)或可展开状态(expandable state)的组件。...如果您需要重新设计一个组件以使用库中的 hooks,那么还可以考虑从一个类转换为一个函数组件。...我们通过 label 文本找到表单元素(就像用户一样),我们从他们的文本中找到链接和按钮(就像用户一样)。 作为此目标的一部分,我们避免测试实现细节,因此重构(更改实现但不是功能)不会破坏测试。

    6.9K30

    React 应用架构实战 0x7:测试

    在这一节中,我们将学习如何使用不同的测试方法来测试我们的应用程序。这将使我们有信心对应用程序进行重构、构建新功能和修改现有功能,而不用担心破坏当前的应用程序行为。...这是一种很好的方法,可以以用户使用应用程序的方式测试应用程序的功能。 在 src/testing/test-utils.ts 中,我们可以定义一些测试中可以使用的实用工具。...我们还应该从这里重新导出 React Testing Library 提供的所有实用工具,以便我们在测试中需要它们时可以轻松地使用它们。...函数并将 AppProvider 添加为 wrapper 需要这个函数是因为在我们的集成测试中,我们的组件依赖于 AppProvider 中定义的多个依赖项,如 React Query 上下文、通知...为了对我们的应用程序进行端到端测试,我们可以使用 Cypress,这是一个非常流行的测试框架,它通过在无头浏览器中执行测试来工作。这意味着测试将在真实的浏览器环境中运行。

    1.6K80

    《刚刚问世》系列初窥篇-Java+Playwright自动化测试-6- 元素基础定位方式-上篇 (详细教程)

    ().setName("Sign in"));locator.click();5.1按角色定位Page.getByRole()定位器反映了用户和辅助技术如何感知页面,例如,某个元素是按钮还是复选框。...(2)何时使用文本定位器:官网建议建议使用文本定位器来查找非交互式元素,如div、span、p 等。对于交互式元素(如button、a、input 等),请使用角色定位器。...您还可以按文本进行筛选,这在尝试查找列表中的特定项目时非常有用。5.5通过替代文本定位所有图像都应具有描述图像的属性alt。您可以使用 Page.getByAltText() 根据替代文本定位图像。...注意,何时使用 ALT 定位器:官网建议当您的元素支持 alt 文本(如 img 和 area)时,请使用此定位器。...Page.locator()创建一个定位器,该定位器采用描述如何在页面中查找元素的选择器。

    16130

    使用 React Testing Library 的 15 个常见错误

    以前的我(Kent)并不是很喜欢那个时候的测试环境,为此写了一个 React Testing Library。...低:一般为我的主观想法,如果你觉得使用上没啥问题可以忽略它 中:如果你不遵循,可能会出现 Bugs、低效的测试用例、还可能会做额外的工作 高:一定要用我建议的方法。...不然很有可能你会遇到大问题,而且测试用例并不怎么高效 没有使用 Testing Library 的 ESLint 插件 重要程度:中 如果你想避免这些常见的错误,那么官方的 ESLint 插件可以给你带来很多帮助...手动使用 cleanup 重要性:中 // ❌ import {render, screen, cleanup} from '@testing-library/react' afterEach(cleanup...你应该按这个页面中的顺序来使用 Query API。如果你的目标和我们的一样,都想通过测试来确保用户在使用时应用能够正常工作的话,那你就要尽量用更接近用户的使用方式来查询 DOM。

    1.3K20

    Sentry 的前端测试实践:从 Enzyme 迁移到 RTL

    什么是 RTL React Testing Library(RTL)是一个 React 组件测试库,它通过与 DOM 交互来测试组件,不像 Enzyme 那样直接使用了 React 内部的东西。...当时我们已经知道有 RTL 了,但并没有强烈的理由要将它引入到我们的代码库中。我们用来测试组件库的 Enzyme 可以满足我们的需求。...基于他们使用 RTL 库的经验,他们向我们的前端技术指导委员会(Frontend TSC)提出了将 RTL 引入到我们的代码库中的建议。...在大型组件上使用 getByRole 时性能较差 根据 RTL 的指南,测试应该像用户与组件交互的方式一样。...使用 getByRole 选择器的大型组件可能会比较慢,我们的一个解决方法是避免多次调用这个查询,将它保存到一个变量中,或者切换使用 getByText 或 getByTestId。 2.

    63710

    测试中如何处理 Http 请求?

    但在真实的测试场景中往往需要多次改变 Mock 结果,Mock fetch 或者 axios.get 就不太够用了。...这会好点,但这也会遇到第 1 点类似的问题 把所有东西都放在函数中,然后拿来做单测(这样还行),这样就避免在集成测试中再测一遍(不太好,译注:不太好是因为集成测试应该要对整个功能进行测试,这样分开测就不完整了...现在 Service Worker 还只是浏览器中的功能,不能在 Node 端使用。但是,msw 可以支持 Node 端所有测试场景。...这就可以更容易和快速地写测试了(配置好 Handler 后)。 你可能在之前会用 nock 之类的库来做这些事。...当你发现要测试的东西太复杂,或者太多干扰项时,使用集成测试会让你真正从用户的角度来写测试。这样一来,你就不会过度关注那些覆盖率指标了,而是从一个用户的角度来思考这样的用例能给我带来多少信心。

    1.3K10

    《刚刚问世》系列初窥篇-Java+Playwright自动化测试-7-元素基础定位方式-下篇 (详细教程)

    1.简介上一篇主要是讲解我们日常工作中在使用Playwright进行元素定位的一些比较常用的基础定位方式的理论基础知识以及在什么情况下推荐使用。今天这一篇讲解和分享一下剩下部分的基础定位方式。...我们可以再次使用产品定位器来获取按钮的角色并单击它,然后使用断言来确保只有一个文本为“产品 2”的产品。...("Add to cart")) .click();您还可以将两个定位器链接在一起,例如,在特定对话框中查找“保存”按钮:Locator saveButton = page.getByRole(AriaRole.BUTTON...();4.3.3通过测试id定位使用 Page.getByTestId()方法在列表中查找元素。...如果您还没有测试 ID,则可能需要修改 html 并添加测试 ID。通过测试 ID “orange”找到一个项目,然后单击它。

    13730

    使用 TypeScript 编写 React.js 应用 | 笔记

    Router 在正常工作后, 重构代码到使用 Redux 使用 React Testing Library 测试应用程序 React Testing Library | Testing Library...; import React from 'react'; 在最新版本的 React 中不是必需的,因为它使用了一个新的 JSX Transform React 17 RC and higher supports...单击项目的编辑按钮 更改窗体中的项目名称 单击表单上的保存按钮 验证卡片是否显示更新的数据 刷新浏览器 验证项目是否仍处于更新状态 注意: 更新后卡片会被排到最后, 目前没有在代码中排序 错误推断,...在测试和非浏览器环境(如 React Native)中很有用。...打开命令提示符或终端并运行以下命令,从 React 测试库后面的核心测试库中安装 user-event 。

    87990

    React 组件如何写单元测试?

    用 create-react-app 创建个 react 项目: npx create-react-app --template=typescript react-unit-test 测试 react...组件和 hooks 可以使用 @testing-library/react 这个包,然后测试用例使用 jest 来组织。...第一种方法的 screen 是 @testing-library/react 提供的 api,是从全局查找 dom,可以直接根据文本查(getByText),根据标签名和属性查(getByRole) 等...比如我点击按钮之后,过了 2s 才改状态: 这时候测试用例就报错了: 这种用 waitFor 包裹下,设置 timeout 的时间就好了: 测试通过了: 除了这些之外,还有一个 api 比较常用...主要是用 @testing-library/react 这个库,它有一些 api: render:渲染组件,返回 container 容器 dom 和其他的查询 api fireEvent:触发某个元素的某个事件

    64320

    用 Cursor 开发 10+ 项目后,我整理了10 条经验60条提示词案例

    帮我写一个 CSS 样式,给按钮添加 hover 效果。 自动生成一个常用的数据库连接函数,支持 MySQL 和 PostgreSQL。...优化以下代码,减少数组操作中的循环次数。 帮我优化查询数据库的 SQL 语句,提高查询效率。 使用缓存优化下列函数的性能,避免重复计算。 将以下递归算法改成迭代算法,减少堆栈溢出问题。...帮我找到如何在 Python 中处理异步任务的教程。 查找一下如何使用 GraphQL 创建一个简单的 API。 学习如何使用 GitLab CI/CD 设置自动化部署流程。 6....对这个数据库查询进行优化,减少查询时间。 9. 多模态开发,让产品更炫酷! ✨ 帮我在现有项目中集成语音识别功能,让用户可以通过语音控制应用。 给我一个示例,展示如何在网站中集成图像识别 API。...使用异步操作优化以下代码,减少阻塞时间。 给出一个数据库优化方案,使得查询速度提升 10 倍。 帮我提升这个图像处理程序的性能,使其在高分辨率下更流畅。

    77520

    浅谈 2022 前端工作流中全流程多层次的四款测试工具

    在测试中,断言是最为重要的概念。我们以一个简单的示例了解下是什么是断言,在 JavaScript 语言中,我们可以使用专业的断言库 chai。图片以下是为了测试 sum 求和函数的断言。...,是基于每一个断言而完成的,我们将测试同一功能的断言集合起来,使用测试框架维护所有断言进行测试。...我们可以使用 mocha 等测试框架用以维护项目的所有单元测试。以下是一个来自于 mocha 官方的测试套件,用来测试 Array.prototype.indexOf() 函数。...图片以 React 为例,在 React 中,可以使用 React Testing Library 对 React Component 进行测试。...图片小结从本篇文章中,我们知道了前端工作中的各个分层以及职责,最重要的是对于代码开发所做的测试以及几款工具软件的推荐,如下所示:单元测试:mocha/chaiComponent 测试:react-testing-library

    43130
    领券