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

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

Jest React Testing Library (RTL) 是前端开发中用于测试 React 应用首选工具。...Jest 是一个功能丰富JavaScript测试框架,而React Testing Library 是一种提倡以用户角度编写测试库,它鼓励测试组件行为而不是内部实现细节。...jest.useFakeTimers()act函数来测试状态变化副作用,定时器或副作用函数:jest.useFakeTimers();it('displays loading state', ()...'Loading...')).toBeInTheDocument();});组件测试对于复杂组件库,可以创建一个setupTests.js文件来设置全局模拟配置,例如:import '@testing-library...测试组件交互性React Testing Library 强调测试组件行为,而不是它实现细节。

16800

单元测试

@testing-library/jest-dom 是一个用于增强 Jest 测试框架库,它提供了一组用于 DOM 断言定制化匹配器工具函数。...当需要基于DOM元素进行匹配测试,推荐引入@testing-library/jest-dom。...如果测试用例依赖于某些外部资源(例如网络请求),请确保在测试之前之后进行适当管理清理,以确保资源正确使用释放。...检查测试用例代码中是否存在任何可能导致测试环境污染或干扰因素,例如全局状态、全局变量等。尽量将测试用例代码进行封装隔离,以确保每个测试独立性。...act 使用场景如下: 当你在测试进行与 React 组件交互(例如模拟用户点击、输入等),可以使用 act 来确保组件在更新后进行正确断言。

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

    Jest来给React完成一次妙不可言~单元测试

    而对于开发者来说,重要进行测试动作。本篇文章主要围绕着React组件单元测试展开,其目的是为了让开发人员可以站在使用角度考虑问题。...技术栈选择 当我们想要为 React 应用编写单元测试时候,官方推荐是使用 React Testing Library[1] + Jest[2] 方式。...假设您希望重构组件,因为您希望能够设置任何count值。因此,您可以删除递增递减方法,然后添加一个新setCount方法。...这里,我们创建了自己助手函数 renderWithRedux() 来呈现组件,因为它将被多次使用。 renderWithRedux() 作为参数接收要呈现组件、初始状态存储。...结语 React Testing Library 是用于测试 React 应用一大利器。它为我们提供了访问 jest-dom 匹配器机会,以及最佳实践,使得我们可以使用它来更有效地测试我们组件

    14.9K33

    Jest + React Testing Library 单测总结

    1.2 测试框架 UI 组件测试工具 而说起前端测试框架工具,比较主流 JavaScript 测试框架有 Jest、Jasmine、Mocha 等等,并且还有一些 UI 组件测试工具,比如 testing-libraray...目前腾讯课堂基于 Tdesign 开发素材库组件单测,就是使用 Jest + React Testing Library 来完成。...2、Jest 使用 Jest 安装这里就不赘述了,如果使用 create-react-app 来创建项目,Jest React Testing Library(RTL) 都已经默认安装了。...运行指定文件中测试用例),就可以得到测试结果,: 当然,如果想要看到覆盖率报告,可以使用 jest --coverage,或者 jest-report。...扩展阅读材料 Jest 学习指南 那些年错过 React 组件单元测试 使用 Jest 测试 JavaScript (Mock 篇) 3、React Testing Library testing

    4.6K20

    2022年3月最新Eslint + Prettier + Husky + Stylelint + Jest + CICD 超详细前端单元测试&规范工程化工作流

    run build && npm test" 3 单元测试「可选」 单元测试中最出名的当属Jest 我这里使用则是JestReactTestingLibrary 3.1 Jest && ReactTestingLibrary...3.1.1 初始化与安装 项目中使用了ts,需要为Jest额外准备babeltypescript环境包 pnpm i jest -D pnpm i -D babel-jest @babel/core...测试用例 with 「ReactTestingLibrary」 安装依赖包 pnpm i -D @testing-library/jest-dom @testing-library/react 在jest.setup.js...写入全局配置 import '@testing-library/jest-dom'; 写第一个测试用例: // home.test.tsx import Home from ".....同时在此补上官网链接 「jestjs.io/docs/gettin… 」 「testing-library.com/docs/react-… 」 建议有问题还是啃文档吧 再补上一些有用教程 「juejin.cn

    1.9K10

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

    使用自定义 hooks 注意 hooks 规则注意事项 我们基础视图组件仍然是基于类 不要为 hooks 重写 使用 React Testing Library 查询 技巧 迁移 - grid-emotion...在需要少量状态或访问 react 原语(引用上下文)展示组件中,它们通常是一个不错选择。例如,具有滑出(slide-out)或可展开状态(expandable state)组件。...当您需要创建新共享状态,请考虑使用 context useContext 而不是 Reflux。此外,可以利用虫洞状态管理模式来公开共享状态突变函数。...使用 React Testing Library 我们正在将我们测试从 Enzyme 转换为 React Testing Library。在本指南中,您将找到遵循最佳实践避免常见陷阱技巧。...eslint-plugin-testing-library https://github.com/testing-library/eslint-plugin-testing-library 我们努力以一种与应用程序使用方式非常相似的方式编写测试

    6.9K30

    React Hook测试指南

    在讲如何对Hook进行测试之前我们先来了解一下我们要用到测试框架Jest(https://jestjs.io/)hook测试库react-hook-testing-library(https://github.com...Jest Jest是Facebook开源一个单元测试框架,它使用知名度都非常高,一些著名开源项目例如webpack, babelreact等都是使用Jest进行单元测试,由于这篇文章重点不是...),组件需要被重新渲染,而这个重渲染是需要React进行调度,因此是个异步过程,我们可以通过使用act函数将所有会更新到组件状态操作封装在它callback里面来保证act函数执行完之后我们定义组件已经完成了重新渲染...yarn add -D react-test-renderer@^16.9.0 例子 现在就让我们看一个简单同时使用Jestreact-hooks-testing-library测试hook例子...总结 在本篇文章中我给大家介绍了什么叫做单元测试,为什么我们需要在自己项目里面引入单元测试以及教大家如何使用Jestreact-hooks-testing-library测试我们自定义hook。

    1.7K10

    2020 年你应该知道 React 库

    它带有一些内置解决方案,例如,用于本地状态副作用 React Hooks。 下面的文章将向您提供一些自己总结方法,以便从补充库中进行选择,从而构建一个全面的 React 应用程序。...所有 React 内置 hooks 都非常适合本地状态管理。当涉及到远程数据状态管理,如果远程数据带有 GraphQL 端点,我建议使用 Apollo Client。...至少,您可以使用 React-test-renderer 在 Jest 测试中渲染 React 组件。这已经足以用 jest 来执行所谓快照测试了。...最终,您会发现自己在使用 Enzyme 或 React Testing Library (这两个都在 Jest 测试环境中使用)来进行更详细测试功能集。...UI 组件 表单库: none 或者 Formik 或者 React Hook Form 测试库: Jest with React Testing Library and Cypress 实用程序库:

    14.4K40

    干货 | 携程租车React Native单元测试实践

    一、技术选型: Jest + Enzyme + react-hooks-testing-library 1.1 jest Jest是FaceBook出品前端测试框架,适合用于ReactReact...有以下几个特点: 简单易用:易配置,自带断言库mock库。 快照测试:能够创造一个当前组件渲染快照,通过上次保存快照进行比较,如果两者不匹配说明测试失败。...1.2 Enzyme Enzyme是AirBnb开源React测试工具库,通过一套简洁api,可以渲染一个或多个组件,查找元素,模拟元素交互(点击,触摸),通过Jest相互配合可以提供完整...七、Jest 异步测试 Jest单元测试是同步,因此面对异步操作fetch获取数据,需要进行异步模拟测试。..._onClear).toBeCalled();//测试组件实例上方法是否被调用 九、Redux测试使用React或者React Native通常会使用Redux进行状态管理,需要mock store

    6.1K30

    React 设计模式 0x8:测试

    # 渲染测试 渲染测试是一种测试,用于验证您组件是否正确渲染。 # 使用 Jest 进行功能测试 Jest测试 React 应用程序时非常流行测试库。...Testing Library 基于 DOM Testing Library 添加了用于处理 React 组件 API。...# 使用 Jest 进行集成测试 在大多数 React 应用程序中,通常需要与外部 API 集成以在应用程序中发布获取数据。 可以使用 Jest测试 API 行为,以查看预期意外结果。...# React 测试最佳实践 对每个组件编写测试 为每个组件编写测试,以确保它们能够正确地渲染响应 使用测试使用 Jest React Testing Library测试库,它们提供了专门用于测试...React 组件工具函数 编写测试用例 编写完整测试用例,覆盖组件所有代码路径,包括正常情况异常情况 使用快照测试 使用 Jest快照测试功能来验证组件是否按预期呈现 使用模拟数据

    1.8K10

    如何测试驱动开发 React 组件

    本文将以创建一个 Confirmation 组件来说明,如何在 React 中如何实现测试驱动开发。...测试组件 首先使用 create-react-app 初始化一个 react 项目。目前 cra 已经内置了 @testing-library/react 作为测试框架。...例如点击按钮,就是 role="button" ;会让这个元素可点击;也可以使用 role 属性告诉辅助设备(屏幕阅读器)这个元素所扮演角色。...现在我们得到了我们想要组件渲染 HTML ,现在我想要确保我可以从外部传递这个组件按钮回调函数,并确保它们在单击按钮被调用。...小结 当然 @testing-library/react 还有很多方便 api。大家可以自行查阅。 未来可能会出一些文章关于测试文章。例如: 如何出测试 react hooks ?

    2.1K10

    如何测试驱动开发 React 组件

    本文将以创建一个 Confirmation 组件来说明,如何在 React 中如何实现测试驱动开发。...测试组件 首先使用 create-react-app 初始化一个 react 项目。目前 cra 已经内置了 @testing-library/react 作为测试框架。...例如点击按钮,就是 role="button" ;会让这个元素可点击;也可以使用 role 属性告诉辅助设备(屏幕阅读器)这个元素所扮演角色。...现在我们得到了我们想要组件渲染 HTML ,现在我想要确保我可以从外部传递这个组件按钮回调函数,并确保它们在单击按钮被调用。...小结 当然 @testing-library/react 还有很多方便 api。大家可以自行查阅。 image.png 未来可能会出一些文章关于测试文章。

    2.2K10

    如何测试 React 异步组件

    前言 本文承接上文 如何测试驱动开发 React 组件?,这次我将继续使用 @testing-library/react 来测试我们 React 应用,并简要简要说明如何测试异步组件。...如何测试(鼠标)事件发出异步请求 ? ---- 对于异步组件,有两件步骤需要进行测试: 第一:测试异步方法本身有没有被调用,并且传了正确参数。 第二:在调用之后,应用程序应该做出响应。... get*By* 函数获取dom 中元素, 这里使用 getByPlaceholderText 以上测试用例只测试了登录函数,但是我们并未写登录成功或者失败逻辑,接下来来我们通过 jest ...测试登录成功 由于测试登录成功例子已经包含了"测试提交""测试渲染"功能,所以,可以将前面2个单元测试删除。登录后,按钮改成 loading 状态 disabled。...: 通过 mock 使组件可以获取静态假数据; 测试加载状态; 测试异步方法是否被正确调用,并且带上了正确参数; 测试组件是否正确地渲染了数据 测试异步方法错误时,组件是是否渲染了正确状态 文中关于登录成功后页面跳转并未测试

    3.3K50

    Jest:给你 React 项目加上单元测试

    Jest 是一款轻量 JavaScript 测试框架,它卖点是简单好用,由 facebook 出品。本文就简单讲讲如何使用 Jest 对 React 组件进行测试。 为什么需要单元测试?...单元测试(Unit Testing),指的是对程序中模块(最小单位)进行检查验证。比如一个函数、一个类、一个组件,它们都是模块。 使用单元测试优点: 更好地交付高质量代码。...可以通过设置 Jest 配置文件 testMatch 或 testRegex 选项进行修改,或者 package.json 下 "jest" 属性。...但 Jest 本身并不支持 React 组件测试 API,需要使用另外一个内置 React Testing Library 库来测试 React 组件。...React Testing Library 是 以用户为角度 测试库,能够模拟浏览器 DOM,将 React 组件挂载上去后,我们使用其提供一些模拟用户操作 API 进行测试

    2.9K20

    前端测试体系建设与最佳实践总结

    Augular 默认测试框架就是 Karma + Jasmine,而 React 默认测试框架是 Jest. Jest 被各种 React 应用推荐使用。...UI 测试 UI 测试尽管有官方测试框架 ReactTestUtils Test Render,但是它们 API 比较复杂,官方文档也是推荐使用 react-testing-library 或...React Testing Library比较晚,但倾向于支持 React 新功能,这对我来说在测试 Hooks 是一个巨大好处。...Enzyme 是从代码实现角度出发进行测试,基于 state props,而 React Testing Library 是从用户体验角度出发,所以是基于 dom 进行测试。...connect 包裹后高阶组件 尽管理论上 components 里面的公共组件都应该是无状态组件,但是有时候有些公用组件写成有状态组件可能更容易被使用,开发成本更低。

    5.4K30

    【送红宝书】JavaScript 测试系列实战(四):掌握 React Hooks 测试技巧

    在这篇文章中,我们将体验强大 react-hooks-testing-library,学习如何去测试钩子同步异步逻辑,并最终通过一个完整例子去了解如何结合 Redux 框架进行测试。...开始使用 react-hooks-testing-library 在上一篇教程中,我们手工编写了非常原始 React Hooks 测试代码。...它提供了一系列专门用于测试 Hook 工具函数,能够模拟在真实组件使用 Hooks。...注意 在编写 Jest 异步测试用例,如果涉及到 Promise 使用(包括 async/await ),要确保 return 一个值,否则测试会超时。详细介绍请参考 Jest 异步测试文档。...小结 在这篇文章中,我们体验了强大 react-hooks-testing-library,先后测试了同步异步钩子,最后还结合 Redux 来测了一波。

    2.1K00
    领券