首页
学习
活动
专区
圈层
工具
发布

JavaScript 测试系列实战(一):使用 Jest 和 Enzyme 测试 React 组件

本篇教程是 JavaScript 测试系列实战 的第一篇教程,首先介绍了测试的类型,然后主要通过一个 React 项目教会你如何使用 Jest 编写第一个测试,然后使用 Enzyme 对 React 组件进行浅层渲染...,以方便对不同层次的组件进行细粒度测试,当学习了这篇教程之后,你将对基础的测试编写、组件的测试有一个比较好的了解。...Jest 测试文件中使用它。...它允许我们在运行测试时,只渲染父组件而不渲染其所有的子组件。浅层渲染十分快速,因此非常适合单元测试。...配置 jest-enzyme 你应该还记得,在刚才的测试代码中,我们还是使用了 Jest 自带的 Matcher(toEqual)。

3.6K10

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

有以下几个特点: 简单易用:易配置,自带断言库和mock库。 快照测试:能够创造一个当前组件的渲染快照,通过和上次保存的快照进行比较,如果两者不匹配说明测试失败。...1.2 Enzyme Enzyme是AirBnb开源的React测试工具库,通过一套简洁的api,可以渲染一个或多个组件,查找元素,模拟元素交互(如点击,触摸),通过和Jest相互配合可以提供完整的...(() => { console.log('每个测试用例测试完毕后运行'); }); 五、Jest Mock函数 在单元测试中,有许多对象或函数并不需要真实的引用,因此需要mock。...('InteractionManager'); 六、Jest UI快照测试 Jest提供了snapshot快照功能用于UI测试,可以创建组件的渲染快照并将其与以前保存的快照进行比较,如果两者不匹配,则测试失败..._onClear).toBeCalled();//测试组件实例上的方法是否被调用 九、Redux测试 在使用React或者React Native时通常会使用Redux进行状态的管理,需要mock store

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

    「前端架构」Grab的前端学习指南

    在React中进行测试很容易,因为组件的接口定义良好,可以通过向组件提供不同的道具和状态并比较呈现的输出来测试组件。 可维护性——以基于组件的方式编写视图可以促进可重用性。...测试- - Jest + Enzyme Jest是Facebook的一个测试库,旨在让测试过程无痛苦。与Facebook项目一样,它提供了一种开箱即用的良好开发体验。...Jest可以保存React组件和Redux状态生成的输出,并将其保存为序列化文件,这样您就不必自己手动生成预期的输出。Jest还具有内置的模拟、断言和测试覆盖率。一个图书馆来统治他们所有人!...React附带了一些测试工具,但是通过类似于jquery的API,通过Airbnb提供的酶可以更容易地生成、断言、操作和遍历React组件的输出。建议用酶测定反应组分。...Jest和酶使编写前端测试变得有趣和容易。因为定义了明确的职责和接口,所以React组件和Redux操作/缩减器相对容易测试也很有帮助。

    8.4K20

    对 React 组件进行单元测试

    这些语义化方法会返回测试的结果,要么成功、要么失败。常见的断言库有 Should.js, Chai.js 等。...这个单词的伦敦读音为 ['enzaɪm],酵素或酶的意思,Airbnb 并没有给它设计一个图标,估计就是想取用它来分解 React 组件的意思吧。...用测试驱动 React 组件重构 这里不展开讨论经典的 “测试驱动开发”(TDD - test driven development) 理论 -- 简单的说,把测试正向加诸开发,先写用例再逐步实现,就是...优化依赖 让 React 组件变得 testable 合理编写组件化的 React,并将足够独立、功能专一的组件作为测试的单元,将使得单元测试变得容易; 反之,测试的过程让我们更易厘清关系,将原本的组件重构或分解成更合理的结构...分离出的子组件往往也更容易写成stateless的无状态组件,使得性能和关注点更加优化。

    5.2K40

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

    Jest 是一个功能丰富的JavaScript测试框架,而React Testing Library 是一种提倡以用户角度编写测试的库,它鼓励测试组件的行为而不是内部实现细节。...afterEach钩子可以用于此目的:afterEach(() => { cleanup();});异步测试使用waitFor或async/await处理异步操作,确保组件在测试中达到期望状态:it(...'Loading...')).toBeInTheDocument();});组件库的测试对于复杂的组件库,可以创建一个setupTests.js文件来设置全局的模拟和配置,例如:import '@testing-library...测试组件的交互性React Testing Library 强调测试组件的行为,而不是它的实现细节。...选择性运行测试使用--findRelatedTests选项只运行与更改相关的测试,以加快测试速度:npx jest --findRelatedTests使用快照测试对于不经常更改的组件,使用快照测试可以节省时间

    1.1K00

    聊一聊 2024 年 React 生态系统

    对于无服务器数据库,PlanetScale、Neon 和 Xata 是值得考虑的替代方案。 测试 测试 React 应用的核心是使用如 Jest 这样的测试框架。...Jest 提供了测试运行器、断言库以及其他实用的功能,满足全面测试框架的需求。如果倾向于使用 Vite,Vitest 是一个值得考虑的 Jest 替代方案。...在测试框架中渲染 React 组件时,可以使用 react-test-renderer。这足以进行所谓的快照测试,这是通过 Jest 或 Vitest 进行的。...如果差异不匹配,测试框架会发出警告,可以选择接受快照或调整组件。 随着时间的推移,你可能会发现自己在测试框架环境中使用React Testing Library(RTL)。...RTL是一个全面的 React 测试库,可以在测试框架环境中使用。它能够渲染组件并模拟HTML元素上的事件。然后,可以使用测试框架进行断言。

    2.5K10

    单元测试

    代码信心的体现 测试可以确保得到预期的结果 作为现有代码行为的描述 促使开发者写可测试的代码,可测试的代码可读性会更高 如果依赖的组件有修改,受影响的组件能在测试中发现错误 测试内容 什么是细节?...交互),推荐单测之前已评审过测试用例 公共类 公共组件 公共方法 公共自定义hook 需求功能类 组件的Props(组件的入参是否在正确的场景或时机被正确的使用或调用) Render 交互(基于用户的交互判断关键节点的流程是否在正确的时机被正确执行...@testing-library/react 是一个用于测试 React 组件的 JavaScript 测试工具库,它提供了一组简单且易于使用的 API,可以帮助你编写可读性高、可维护性强的测试代码。...,会出现报错 这种情况通常是由于在一组测试用例中,前一个测试用例没有正确地清理或重置测试环境,导致后续的测试无法找到期望的元素或状态。...这样可以确保每个测试用例都在相同的初始状态下运行,并且没有残留的状态或影响。 在每个测试用例之后使用 afterEach 函数或 afterAll 函数来清理测试环境。

    1.4K10

    40道ReactJS 面试问题及答案

    :为组件编写测试涉及使用 Jest 和 React 测试库等测试库来确保组件按预期运行。...以下是测试 React 应用程序的一些常用方法: 单元测试:使用 Jest 等测试框架以及 Enzyme 或 React 测试库等工具为各个组件编写单元测试。...这些测试可以单独检查每个组件的渲染、行为和状态。 让我们使用 Jest 和 React 测试库为此 Button 组件编写一些单元测试用例。...您可以使用 Jest 和 React 测试库等工具来模拟用户交互并测试应用程序的整体行为。...使用 Jest、React 测试库、Enzyme 或 Cypress 等测试库来编写和运行测试。 遵循测试 React 组件的最佳实践,例如关注用户交互、测试边缘情况和模拟依赖项。

    5.1K10

    React + Redux Testing Library 单元测试

    跑 image.png 写不好是能力问题,不写则是态度问题。 单元测试客观上可以让开发者的工作更高效,React 应用的单元测试是一定要的。...如果你想随时整理重构代码,那么你需要写单元测试; 如果你想有自动化的测试套件来帮你快速验证提交的完整性,那么你需要写单元测试。 这个结论对我们写不写单元测试有什么影响呢?...推荐使用 mount 的方法是依赖于一个名为 jsdom的库,它本质上是一个完全在 JavaScript 中实现的 headless 浏览器。...前端 UI 组件测试的最佳实践,使得我们可以使用它来更有效地测试组件。...}); React 组件和 Redux store 的交互 前面我们讲完了 Redux 单元测试所需要的基本知识,而 React 组件需要从 Redux store 读取状态或者是发送 action

    2.7K10

    React 设计模式 0x8:测试

    # 渲染测试 渲染测试是一种测试,用于验证您的组件是否正确渲染。 # 使用 Jest 进行功能测试 Jest 是测试 React 应用程序时非常流行的测试库。...如果快照不匹配,则测试将失败。 # 使用 Cypress 进行端到端(e2e)测试 当涉及端到端测试时,Cypress 在其他框架/库中处于领先地位。...Jest 模拟函数 使用 模拟函数 来侦测(查看)我们的函数被调用的情况,或者使用它来测试单个函数或整个模块。...# React 测试最佳实践 对每个组件编写测试 为每个组件编写测试,以确保它们能够正确地渲染和响应 使用测试库 使用 Jest 和 React Testing Library 等测试库,它们提供了专门用于测试...React 组件的工具和函数 编写测试用例 编写完整的测试用例,覆盖组件的所有代码路径,包括正常情况和异常情况 使用快照测试 使用 Jest 中的快照测试功能来验证组件是否按预期呈现 使用模拟数据

    2.4K10

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

    因为有很多足够多优秀的的前端框架(比如 React,Vue 和 Angular);以及一些易用且强大的UI库(比如 Ant Design)为我们保驾护航,极大地缩短了应用构建的周期。...因此,可以从DOM测试库和其他一些有用的方法(如debug、rerender或unmount)获得大量查询。...一个特定的查询有很多变体: •getBy:返回查询的第一个匹配节点,如果没有匹配的元素或找到多个匹配,则抛出一个错误。...如果没有存储,它将创建一个新的存储,如果它没有接收初始状态或存储,它将返回一个空对象。 接下来,我们使用render()来呈现组件并将存储传递给提供者。...结语 React Testing Library 是用于测试 React 应用的一大利器。它为我们提供了访问 jest-dom 匹配器的机会,以及最佳实践,使得我们可以使用它来更有效地测试我们的组件。

    15.8K33

    Jest 单元测试快速上手指南

    , 容易上手且功能十分强大的测试框架 安装 yarn add -D jest 使用 创建 test 目录, 添加 plus.spec.js 文件 describe('example', () => {..., 结果和之前一致 执行单测时不校验 ts 类型 有时你可能会希望不校验 ts 类型, 仅执行代码测试, 比如需要在 CI 中将类型校验和单元测试分为两个任务 在 jest.config.js 中添加如下内容...globals: { 'ts-jest': { isolatedModules: true, }, } 测试 React 组件 安装 react 依赖 yarn add...react react-dom 和声明 yarn add -D @types/react安装 react 测试库 yarn add -D @testing-library/react @testing-library.../jest.setup.js'], 重新执行测试就可以了 测试交互事件 新增 Count.tsx 组件 import React, { useState } from 'react'; function

    3.8K30

    JavaScript测试教程–part 4:模拟 API 调用和模拟 React 组件交互

    JavaScript测试教程-part 1:用 Jest 进行单元测试 2. JavaScript测试教程–part 2:引入 Enzyme 并测试 React 组件 3....(例如 fs 或 path ),则需要在模拟文件中明确调用 jest.mock('moduleName') Jest 允许我们对函数进行监视:接下来测试是否调用了我们所创建的 get 函数。...('axios'),Jest 在的测试和组件中都用我们的模拟代替了 axios。...组件的交互 在之前的文章中,我们提到了阅读组件的状态或属性,但这是在实际与之交互时。...除此之外,我们还在整个 React 组件中模拟了事件,并检查了它是否产生了预期的结果,例如组件的请求或状态变化,并且了解了监视的概念。 1.

    4.4K10

    写代码无BUG,网易云前端单元测试方案总结

    我希望通过对这些工具的各自作用的掌握,了解完整的前端测试技术方案。前端单元测试的领域也很多,这里主要讲对于前端组件如何进行单元测试,最后会主要介绍下对于 React 组件的一些测试方法总结。...而我们在做单元测时往往需要断言库能够提供良好的测试报告,这样才能一目了然地看到有哪些断言通过没通过,所以使用专业的单元测试断言库还是很有必要。 chai ?...有了断言库之后我们还需要使用测试框架将我们的断言更好地组织起来。 mocha 和 Jasmine ?...jest Jest 是 facebook 出的一个完整的单元测试技术方案,集 测试框架, 断言库, 启动器, 快照,沙箱,mock工具于一身,也是 React 官方使用的测试工具。...另外测试 React组件除了 Enzyme 提供的操作, Jest 中还有很多其他有用的特性,比如可以 mock 一个 npm 组件的实现,调整 setTimeout 时钟等,真正进行单元测试时,这些工具也是必不可少的

    10.6K20

    如何测试 React 异步组件?

    前言 本文承接上文 如何测试驱动开发 React 组件?,这次我将继续使用 @testing-library/react 来测试我们的 React 应用,并简要简要说明如何测试异步组件。...如何测试(鼠标)事件发出的异步请求 ? ---- 对于异步组件,有两件步骤需要进行测试: 第一:测试异步方法本身有没有被调用,并且传了正确的参数。 第二:在调用之后,应用程序应该做出响应。...假设你有一个用 React 编写的小型博客应用程序。有一个登录页面,还有有一个文章列表页面,内容就跟我的博客一样。...get*By* 函数获取dom 中的元素, 这里使用 getByPlaceholderText 以上测试用例只测试了登录函数,但是我们并未写登录成功或者失败的逻辑,接下来来我们通过 jest 的 mock...: 通过 mock 使组件可以获取静态假数据; 测试加载状态; 测试异步方法是否被正确调用,并且带上了正确的参数; 测试组件是否正确地渲染了数据 测试异步方法错误时,组件是是否渲染了正确的状态 文中关于登录成功后页面跳转并未测试

    4K50

    React 组件测试技巧

    React 组件的常见测试模式。 注意: 此页面假设你正在使用 Jest 作为测试运行器。如果你使用不同的测试运行器,你可能需要调整 API,但整体的解决方案是相同的。...这些示例的其余部分使用 act() 来作出这些保证。 你可能会发现直接使用 act() 有点过于冗长。为了避免一些样板代码,你可以使用 React 测试库,它的助手是用 act() 封装的。...注意: React 测试库为触发事件提供了一个更简洁的助手。 --- 计时器 {#timers} 你的代码可能会使用基于计时器的函数(如 setTimeout)来安排将来更多的工作。...的计时器 mock 为这个组件编写测试,并测试它可能处于的不同状态。...有了这些,我们可以“保存”渲染的组件输出,并确保对它的更新作为对快照的更新显式提交。

    5.3K00

    JavaScript 测试系列实战(三):使用 Mock 模拟模块并处理组件交互

    打开 TodoList 的测试文件,首先在最前面通过 jest.mock 配置 axios 模块的 Mock(确保要在 import TodoList 之前),在 Mock 之后,无论在测试还是组件中使用的都将是...React 组件的交互 在上面迭代的 TodoList 中,我们使用了 axios.post。...由于没有发起实际的 post 请求,我们的测试可以更可靠,更快。除此之外,我们还在整个 React 组件中模拟了事件。我们检查了它是否产生了预期的结果,例如组件的请求或状态变化。...让测试通过 React文档[3] 里面提到:我们只能从函数式组件或其他 Hooks 中调用 Hooks。...我们可以使用本系列前面部分介绍的 enzyme 库来解决此问题,而且使了一点小聪明,我们创建 testHook.js : // src/testHook.js import React from 'react

    5.5K20
    领券