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

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

本篇教程是 JavaScript 测试系列实战 第一篇教程,首先介绍了测试类型,然后主要通过一个 React 项目教会你如何使用 Jest 编写第一个测试,然后使用 Enzyme 对 React 组件进行浅层渲染...E2E 测试重点是在我们正在运行应用程序中模拟实际用户(例如模拟滚动、单击键入等行为),并检查我们应用程序是否从实际用户角度运行良好。...初识 Enzyme:编写第一个 React 组件测试 很显然,我们不会仅仅满足于测试像 divide 那样简单函数,我们希望能够测试一个 React 组件,但是一个普通 JavaScript...Jest 测试文件中使用它。...小结 在过去两个小节中,我们了解、安装配置了 Enzyme,并且接触了 shallow 浅层渲染这个单元测试利器,并且循序渐进测试了两个 React 组件

2.9K10

React 组件进行单元测试

React 单元测试中用到工具 Jest 不同于"传统"(其实也没出现几年) jasmine / Mocha / Chai 等前端测试框架 -- Jest使用更简单,并且提供了更高集成度、更丰富功能...实际使用中,适当自定义配置一下,会得到更适合我们测试场景: //jest.config.jsmodule.exports = { modulePaths: [ "<rootDir...这个单词伦敦读音为 ['enzaɪm],酵素或意思,Airbnb 并没有给它设计一个图标,估计就是想取用它来分解 React 组件意思吧。...它模拟了 jQuery API,非常直观并且易于使用学习,提供了一些与众不同接口几个方法来减少测试样板代码,方便判断、操纵遍历 React Components 输出,并且减少了测试代码实现代码之间耦合...对于一些组件共有函数等,完善测试也是一种最好使用说明书。

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

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

Jest可以保存React组件Redux状态生成输出,并将其保存为序列化文件,这样您就不必自己手动生成预期输出。Jest还具有内置模拟、断言和测试覆盖率。一个图书馆来统治他们所有人!...React附带了一些测试工具,但是通过类似于jqueryAPI,通过Airbnb提供可以更容易地生成、断言、操作和遍历React组件输出。建议用测定反应组分。...Jest使编写前端测试变得有趣容易。因为定义了明确职责接口,所以React组件Redux操作/缩减器相对容易测试也很有帮助。...对于React组件,我们可以测试给定一些道具,呈现所需DOM,并在某些模拟用户交互时触发回调。对于Redux还原器,我们可以测试给定一个先验状态一个动作,会产生一个结果状态。...Jestase文档非常简洁,通过阅读它们应该就足够了。 预计持续时间:2-3天。尝试为你React + Redux应用程序编写Jest +Enzyme!

7.4K20

React使用 Storybook,构建强大自定义 UI 组件

虽然像React这样基于组件UI库简化了web开发,但它们也引入了测试调试等新复杂性。...该工具有一个广泛插件生态系统,可以帮助扩展调整您应用程序。此外,它还集成了最流行JavaScript框架,如React、Vue甚至Ruby。 你应该在React使用Storybook吗?...与React一样,Storybook是记录UI组件设计系统一种引人注目的可视化方式。 除此之外,它还是呈现技术文档演示实现细节优秀工具。它还有助于在用户有机会与新配置进行交互之前测试它们。...构建第一个 Storybook 组件 Storybook使用组件驱动开发(CDD)方法来创建UI组件。按照这种方法,您可以模块化地构建,从基本组件开始,逐步将它们组合成复杂屏幕应用程序。...当然,你可以使用Vue、Angular其他框架,但为了简单起见,我们将使用React。 1.

8.9K10

JavaScript测试教程-part 2:引入 Enzyme 并测试 React 组件

JavaScript测试教程–part 4:模拟 API 调用模拟 React 组件交互 在本教程第一篇中,我们简要介绍了单元测试基础。这次要更进一步,使用 Enzyme 库测试 React。...这样可以使你程序将更加可靠,并且更加容易避免回归。我们在这里用了 Jest,不过 Enzyme 也可以与 Mocha Chai 之类库一起使用。...在第一个测试中,我们使用了 toContainReact 函数,这是一个自定义匹配器函数。它是 enzyme-matchers 库一部分。...总结 本文中我们已经了解了使用 Enzyme 测试 React 组件基本知识。我们已经介绍了安装 Enzyme 并运行第一个简单测试。使用渲染类型称为“浅渲染”。...之所以这样称呼,是因为它不渲染任何子组件。在编写单元测试时,它工作得很好。在本教程后续部分中,我将介绍其他类型渲染,并学习如何测试程序不同部分。它将包括快照测试模拟数据之类技术。下次见!

1.4K50

React 设计模式 0x8:测试

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

1.8K10

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

在较大规模前端项目中,测试对于保证代码质量十分重要,而React组件函数式编程, 这种相同输入一定返回相同输出幂等特性特别适合单元测试。...一、技术选型: Jest + Enzyme + react-hooks-testing-library 1.1 jest Jest是FaceBook出品前端测试框架,适合用于ReactReact...1.2 Enzyme Enzyme是AirBnb开源React测试工具库,通过一套简洁api,可以渲染一个或多个组件,查找元素,模拟元素交互(如点击,触摸),通过Jest相互配合可以提供完整...因为渲染了真实DOM节点,可以用来测试DOM API交互组件生命周期。 render:静态渲染,渲染为静态HTML字符串,包括子组件,不能访问生命周期,不能模拟交互。..._onClear).toBeCalled();//测试组件实例上方法是否被调用 九、Redux测试 在使用React或者React Native时通常会使用Redux进行状态管理,需要mock store

5.9K30

单元测试

交互),推荐单测之前已评审过测试用例 公共类 公共组件 公共方法 公共自定义hook 需求功能类 组件Props(组件入参是否在正确场景或时机被正确使用或调用) Render 交互(基于用户交互判断关键节点流程是否在正确时机被正确执行...它主要作用是使你能够在测试代码中模拟修改访问window.location行为,而无需实际在浏览器环境中执行。...如果测试用例依赖于某些外部资源(例如网络请求),请确保在测试之前之后进行适当管理清理,以确保资源正确使用释放。...act } from '@testing-library/react'; act 是一个用于处理 React 组件异步更新和副作用工具函数,它主要作用是确保在测试中正确地触发等待组件更新。...act 使用场景如下: 当你在测试中进行与 React 组件交互(例如模拟用户点击、输入等)时,可以使用 act 来确保组件在更新后进行正确断言。

16610

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

JavaScript测试教程–part 4:模拟 API 调用模拟 React 组件交互 今天,我们进一步测试 React 组件。它涉及模拟组件交互模拟 API 调用。你将学到两种方法,开始吧!...('axios'),Jest测试组件中都用我们模拟代替了 axios。...有关其功能完整列表,请阅读文档。我们测试检查组件在渲染运行之后是否从模拟中调用 get函数,并成功执行。...React 组件交互 在之前文章中,我们提到了阅读组件状态或属性,但这是在实际与之交互时。...除此之外,我们还在整个 React 组件模拟了事件,并检查了它是否产生了预期结果,例如组件请求或状态变化,并且了解了监视概念。 1.

3.7K10

使用storybook管理React组件

本文已ReactUI组件为例,演示如何新建/集成Storybook到项目中,并对UI组件进行全方位管理,包括发布、demo文档、测试等。 1....测试UI组件 4.1 写测试用例原因 找到bug 新修改没有改变已有的接口功能 将测试用例作为文档 4.2 测试结构 使用storyshots插件来实现,其核心是使用Jest,原理是每次生成一份DOM...4.3 测试交互 storybook交互性测试可以使用 Enzyme来模拟用户输入,然后使用Mocha or Jest来进行结果测试,storybook又一个专门插件帮助我们集成他们:specifications...,通过断言来测试UI组件属性,更多使用方法可以参考specifications插件使用。...4.4 测试样式 样式测试这里采用Puppeteer Jest来实现,其原理是利用Puppeteer无头chrome浏览器storybookurl绑定组件特点,来渲染不同UI组件,再进行图片快照对比

3.3K20

2020 年你应该知道 React

当我从 Angular 切换到 React,我绝对经历了它作为 React 优势。 只有通过 React,您才能使用函数组件 props 构建组件驱动用户界面。...这些特性远远超出了 React,因为后端应用程序为您管理这些事情。 通常方法是使用自定义身份验证实现自己自定义后端应用程序。...至少,您可以使用 React-test-renderer 在 Jest 测试中渲染 React 组件。这已经足以用 jest 来执行所谓快照测试了。...这两个库使得在 HTML 元素上呈现组件模拟事件成为可能。然后,Jest 用于 DOM 节点上断言。...Node.js 服务 Ui 库: UI 组件库或者您自己 UI 组件 表单库: none 或者 Formik 或者 React Hook Form 测试库: Jest with React Testing

14.4K40

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 学习指南 那些年错过 React 组件单元测试 使用 Jest 测试 JavaScript (Mock 篇) 3、React Testing Library testing...3.1 render & debug 在测试用例中渲染内容,可以使用 RTL 库中 render,render 函数可以为我们在测试用例中渲染 React 组件

4.5K20

如何测试 React 异步组件

前言 本文承接上文 如何测试驱动开发 React 组件?,这次我将继续使用 @testing-library/react 来测试我们 React 应用,并简要简要说明如何测试异步组件。...异步组件测试内容 我们知道异步请求主要用于从服务器上获取数据,这个异步请求可能是主动触发,也可能是(鼠标)事件响应,本文主要包含 2 方面内容: 如何测试在 componentDidMount 生命周期中发出异步请求...,若在生产环境中,我推荐使用 react-hook-form 测试提交 接下来测试下 onSubmit 方法必须包含 username password, 我们需要模拟用户输入,这个时候我们需要安装...get*By* 函数获取dom 中元素, 这里使用 getByPlaceholderText 以上测试用例只测试了登录函数,但是我们并未写登录成功或者失败逻辑,接下来来我们通过 jest mock...请关注我,我会尽快出 React test 系列下文。 希望这篇文章对大家有所帮助,也可以参考我往期文章或者在评论区交流你想法心得,欢迎一起探索前端。

3.3K50

jest 单元测试改善老旧 Backbone.js 项目

本文将尝试用一个重构实例来抛砖引玉,讲解如何对其应用较新 jest 测试框架,并用 ES6 class 等新手段升级 Backbone.View 视图组件改善页面结构,希望能对类似项目的改善起到开启思路作用...、绑定事件等视图组件 在我们实际项目中,视图层同时支持了 Backbone.View 早期 react@13,这也正体现了其灵活之处。...通常 Backbone 项目也可以忽略文中涉及 react 部分。 升级测试框架 之前文章中例子相同,本次依然采用 Jest 作为测试框架。...单元测试并不严谨,依赖了提供 mock 数据 php 服务器环境 三是由于视图层没有很好组件化,从而缺乏对视图组件测试 jest for Backbone 实践 jest 是比较新测试框架...jest.doMock() 方法,其缺点是用了这个就不能用 ES6 import 语法了,配置使用简要说明如下: // jest.config.jsmoduleNameMapper: { "

3.4K10

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

在这篇教程中,我们将学习如何测试更复杂组件,包括用 Mock 去编写涉及外部 API 测试,以及通过 Enzyme 来轻松模拟组件交互 初次尝试 Jest Mock 我们应用程序通常需要从外部...我们希望我们测试是可靠独立,而最常见解决方案就是 Mock。 改写 TodoList 组件 首先让我们改造组件,使其能够通过 API 获取数据。...React 组件交互 在上面迭代 TodoList 中,我们使用了 axios.post。...它第一个参数是事件类型(由于我们在输入中使用onChange,因此我们应该在此处使用change),第二个参数是模拟事件对象(event)。...由于没有发起实际 post 请求,我们测试可以更可靠,更快。除此之外,我们还在整个 React 组件模拟了事件。我们检查了它是否产生了预期结果,例如组件请求或状态变化。

4.7K20

从工程化角度讨论如何快速构建可靠React组件

这里分别是 webpack 配合 `webpack 开发静态资源服务两份配置: webpack & server。 但是发布组件这个过程跟开发项目却又很不同。...而 React 组件测试还有一个更好选择,就是官方推荐 jest + enzyme。... jsdom 能够模拟浏览器环境,结合 airbnb 写 react 测试库 enzyme, 基本能满足大部份 React 测试需求。...但这里举例子, react-list-scroll 组件,一个 React 滚动列表组件,碰巧遇到一种比较难模拟情况,就是对 scroll 事件模拟。这里想展开说一下。...通过 jest-environment-jsdom,它能够将 jsdom 注入到 node 运行环境中,因此你可以在测试文件中直接使用 window 对象进行模拟

1.9K60

JavaScript 测试系列实战(二):深层渲染快照测试

在上一篇教程中,我们已经介绍了使用 Enzyme 测试 React 组件基本知识。...今天,我们将更深入地挖掘并学习如何测试组件 Props,如何(以及为什么)使用 mount 函数,以及什么是 Jest 快照测试。...在测试与 DOM 交互或者在处理高阶组件时,mount 函数也可以派上用场。_Mount 使用 DOM 实现模拟Jest 默认使用是 jsdom。...除此之外,我们还介绍了 Jest 快照测试,这是一个非常强大工具,可以追踪组件渲染方式变化。在接下来文章中,我们还将介绍测试中常见 Mock 技巧——与组件模拟交互,不见不散!...- END - ● JavaScript 测试系列实战(一):使用 Jest Enzyme 测试 React 组件● 你不知道 Npm(Node.js 进阶必备好文)● 用动画实战打开 React

2.1K20

从echarts-for-react源码中学习如何写单元测试

() 作用: 把遇到计时器挂起,在必要时,再使用jest.runOnlyPendingTimers执行掉已经挂起计时器 这里使用jest.useFakeTimers()目的就是暂停正在执行timer...=> { // mount()借助jsdom模拟浏览器环境,并提供DOM api生命周期支持,方便测试HOC(高阶组件) // shallow()浅渲染,将组件渲染成虚拟DOM对象,...()/shallow()/render()区别如下: [1] mount()借助jsdom模拟浏览器环境,并提供DOM api生命周期支持,方便测试HOC(高阶组件) [2] shallow()...浅渲染,将组件渲染成虚拟DOM对象,它不会渲染内部子组件,也无法与子组件互动 [3] render()用于将React组件渲染成静态HTML并分析生成HTML结构 ③ toEqual()toBe...④ mount()/shallow()/render()区别 ⑤ toEqual()toBe()区别 ⑥ 如何测试DOM节点上属性 ⑦ 如何测试React组件实例上属性 ⑧ 如何测试组件

6.1K50

React单元测试:Jest + Enzyme(二)

前言 在上一篇教程中,我们成功搭建了基于JestEnzyme单元测试框架并成功地跑起来第一个单元测试,可以点击这里回顾一下。今天,我们重点讨论如何通过Jest来mock数据。...什么是Mock Mock简单翻译就是模拟。既可以模拟数据,也可以模拟行为。在上一篇文章中,就用到了mock功能来忽略对多媒体文件字体文件等请求: "jest": { ....../api/data文件夹: 单测实例 假设有以下组件,在加载时候会发送api请求获取数据: import React, {PureComponent} from 'react' import dataApi...这里,我们使用了enzymemout方法来渲染组件,这个方法会执行组件对应生命周期方法。在上面的例子中,componentDidMount方法里就包含了请求api方法。...总结 通过上面的步骤,就可以写出一个简单模拟网络请求单元测试了。更多Jest+enzyne用法,请期待下一期文章

1.4K20
领券