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

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

本篇教程是 JavaScript 测试系列实战 的第一篇教程,首先介绍了测试的类型,然后主要通过一个 React 项目教会你如何使用 Jest 编写第一个测试,然后使用 Enzyme 对 React 组件进行浅层渲染...因此这里建议直接使用 npx jest 执行测试。 编写第一组测试 每个测试文件通常有多个测试用例。Jest 允许我们通过 describe 函数对测试用例进行分组,它创建了一个可以组合多个测试的块。...函数不同,测试一个 React 组件还需要两个关键的问题:1)怎么渲染待测试组件;2)怎么测试渲染出来的组件。...Jest 测试文件中使用它。...配置 jest-enzyme 你应该还记得,在刚才的测试代码中,我们还是使用Jest 自带的 Matcher(toEqual)。

2.9K10

react生态下jest单元测试

一:jest框架搭建 1.在本地创建一个目录jest_practice 2.使用编辑器VScode打开目录,紧接着在终端中打开,执行npm init 图片 3.执行以下命令: 注意:这里我们使用cnpm...a.建议使用npm install –g jest(不需要单个去安装依赖),修改package.json文件即可。...后面每次再运行快照测试时,都会和第一次的比较,若组件代码有所改变,则快照测试会失败,如果组件代码是最新的,优化过得代码,则需要更新快照,免得每次执行报错。...更新快照命令:jest --updateSnapshot 被测组件代码如下: //被测组件 import React from 'react'; const STATUS = { HOVERED...、断言或是进行 snapshot 测试 //React 组件的 render 结果是一个组件树,并且整个树最终会被解析成一个纯粹由 HTML 元素构成的树形结构 it("renders correctly

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

React单元测试Jest + Enzyme(一)

但如果涉及到以下几个方面,你就要考虑是否有必要引入单测了: 业务比较复杂,前端参与的人员超过3人 公司非常注重代码质量,想尽一切办法杜绝线上出bug 你是跨项目组件的提供方 你在做一个开源项目 React...项目如何做单测 目前比较流行的React单测组合是Jest+Enzyme,下面我们先对它们做一个简单的了解。...Jest是Facebook开发的一个测试框架,它集成了测试执行器、断言库、spy、mock、snapshot和测试覆盖率报告等功能。...React项目本身也是使用Jest进行单测的,因此它们俩的契合度相当高。 Enzyme是由airbnb开发的React单测工具。...在下一篇文章中,我将会详细介绍如何使用Jest来mock方法和数据,敬请期待。

1.4K20

React单元测试Jest + Enzyme(二)

前言 在上一篇教程中,我们成功搭建了基于Jest和Enzyme的单元测试框架并成功地跑起来第一个单元测试,可以点击这里回顾一下。今天,我们重点讨论如何通过Jest来mock数据。...,在加载的时候会发送api请求获取数据: import React, {PureComponent} from 'react' import dataApi from 'common/api/data'...: import React from 'react' import {mount} from 'enzyme' import BossTask from 'src/setting/reward/boss_task...这里,我们使用了enzyme的mout方法来渲染组件,这个方法会执行组件对应的生命周期方法。在上面的例子中,componentDidMount方法里就包含了请求api的方法。...总结 通过上面的步骤,就可以写出一个简单的模拟网络请求的单元测试了。更多的Jest+enzyne用法,请期待下一期的文章

1.4K20

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

Jest 是一款轻量的 JavaScript 测试框架,它的卖点是简单好用,由 facebook 出品。本文就简单讲讲如何使用 JestReact 组件进行测试。 为什么需要单元测试?...Jest 基本使用 我们先写一个简单的函数,作为被测试的模块。...但 Jest 本身并不支持 React 组件测试 API,需要使用另外一个内置的 React Testing Library 库来测试 React 组件。...React Testing Library 是 以用户为角度 的测试库,能够模拟浏览器的 DOM,将 React 组件挂载上去后,我们使用其提供的一些模拟用户操作的 API 进行测试。...16,Enzyme 已死: https://dev.to/wojtekmaj/enzyme-is-dead-now-what-ekl 使用 Jest 测试 React 组件 我们先实现一个简单的 Button

2.7K20

使用Enzyme测试React(Native)组件|洞见

React组件树的测试 按理来说按照纯函数这样的思路,React组件测试应该很简单。...Enzyme理论上应该与所有TestRunner和断言库相兼容,已经集成了多种测试类库,比如Jest、Mocha&Chai、Jasmine,不过这些不是我们今天的重点。...前面我们所谈论的都是如何测试使用react-dom所构建的React组件,即最终渲染的结果是浏览器当中的DOM结构,但对于React Native来说,JavaScript代码最终会被编译并用于调用iOS...事实上,我们可以通过欺骗React Native让它返回常规的React组件而不是Native组件,然后就又能愉快地使用传统的JavaScript测试库来单独测试React Native组件逻辑。...react-native-mock这个辅助库,这是一个使用纯JavaScript将全部的React Native组件进行mock的第三方库,只需要导入这个库就可以对React Native组件进行渲染和测试

2.3K40

使用Jest测试原生TypeScript项目

通过官网的Getting started 我们可以在最下方找到 ts-jest 不难理解,我们需要配的其实就是jest加载到什么样类型的文件,使用什么预处理来处理文件。...如果是js文件我通过babel-jest处理,css则使用jest-css-modules。假如没有这些配置,那import了你的库,库里有引入了高特性的js文件,或者css文件就会编译报错。...我选择了jestjest本身是fb出的,对于react非常友好。本身也做了许多环境上的封装切换jsdom环境或者node环境非常方便。我最后选择了这个。...写完了测试,给我们的jest.config 多加一行配置,来生成我们的测试报告(Jest内置了 istanbul) javascript module.exports = { // ... collectCoverage...总结 至此,你应该对前端UI测试应该大致有一个宏观的了解。 本文没有过多得介绍Jest的用法或者语法,希望可以给不知道如何做测试的朋友们一点方向,自己去尝试找到适合自己项目的才是最好的。

2.8K60

使用jest进行单元测试

今年的不幸与坎坷使我有很长一段时间去思考人生,不想将就了,鲁棒健壮的程序,开发和测试应该是分得很开的,于是我选择jest去做单元测试这件事。...不扯犊子直接说吧,第一点,用数据、用茫茫多的测试用例去告诉使用者,你的程序是多么鲁棒健壮;第二点,把它作为一种素养去培养吧,当你按照一系列规范去做事,那么你做出来的东西,我想是有品质在的。...jest的相关配置 package.json中相关scripts 这里笔者罗列了常用的通用的一些关于jest的脚本,后面测试结果会陆续补充一些测试脚本,以上的脚本都编写在package.json文件下的.../test/caculator.test.js --watch": 单文件监视测试 "test:watchAll": "jest --watchAll": 监视所有文件改动,测试相应的测试。...大致基础类的脚本测试就总结到这里,接下来我们看下jest.config.js的相关配置。

3.5K60

React 组件测试技巧

React 组件的常见测试模式。 注意: 此页面假设你正在使用 Jest 作为测试运行器。如果你使用不同的测试运行器,你可能需要调整 API,但整体的解决方案是相同的。...在测试环境页面阅读更多关于设置测试环境的细节。 在这个页面上,我们将主要使用函数组件。然而,这些测试策略并不依赖于实现细节,它对于 class 组件也同样有效。...在上面,我们通过调用 jest.useFakeTimers() 来启用它们。它们提供的主要优势是,你的测试实际上不需要等待 5 秒来执行,而且你也不需要为了测试而使组件代码更加复杂。...--- 多渲染器 {#multiple-renderers} 在极少数情况下,你可能正在使用多个渲染器的组件上运行测试。...例如,你可能正在使用 react-test-renderer 组件上运行快照测试,该组件内部使用组件内部的 ReactDOM.render 渲染一些内容。

4.9K00

如何测试 React 异步组件

前言 本文承接上文 如何测试驱动开发 React 组件?,这次我将继续使用 @testing-library/react测试我们的 React 应用,并简要简要说明如何测试异步组件。...测试渲染 代码未动,测试先行,先确保我们的组件可以渲染。...,若在生产环境中,我推荐使用 react-hook-form 测试提交 接下来测试下 onSubmit 方法必须包含 username 和 password, 我们需要模拟用户输入,这个时候我们需要安装..., 使用react-use,首先我们先要安装这个包 import React from "react"; import { fetchPosts } from "....: 通过 mock 使组件可以获取静态假数据; 测试加载状态; 测试异步方法是否被正确调用,并且带上了正确的参数; 测试组件是否正确地渲染了数据 测试异步方法错误时,组件是是否渲染了正确的状态 文中关于登录成功后页面跳转并未测试

3.3K50

如何测试驱动开发 React 组件

本文将以创建一个 Confirmation 组件来说明,如何在 React 中如何实现测试驱动开发。...测试组件 首先使用 create-react-app 初始化一个 react 项目。目前 cra 已经内置了 @testing-library/react 作为测试框架。...npx create-react-app my-react-app 我们先从测试文件开始。先创建了组件的目录“Confirmation” 并在其中添加一个“index.test.js”文件。...确保渲染测试 第一个测试相当抽象。仅仅需要检查组件是否展现(任何东西) ,以确保这个组件是存在。但是实际上,我将测试组件还不存在。...接下来,让我们创建一个足够满足这个测试组件: import React from 'react'; const Confirmation = () => { return <div role=

2.1K10

如何测试驱动开发 React 组件

本文将以创建一个 Confirmation 组件来说明,如何在 React 中如何实现测试驱动开发。...测试组件 首先使用 create-react-app 初始化一个 react 项目。目前 cra 已经内置了 @testing-library/react 作为测试框架。...npx create-react-app my-react-app 我们先从测试文件开始。先创建了组件的目录“Confirmation” 并在其中添加一个“index.test.js”文件。...确保渲染测试 第一个测试相当抽象。仅仅需要检查组件是否展现(任何东西) ,以确保这个组件是存在。但是实际上,我将要测试组件还不存在。...expect(getByRole('button', { name: '确认' })).toBeInTheDocument() }) 在这里使用 name 选项,因为我们知道这个组件中至少还有一个按钮,

2.1K10

React入门四:React组件使用

---- 这是我参与8月更文挑战的第三天 1.组件介绍 使用React就是在使用组件 组件表示页面中的部分功能 组合多个组件实现完整的页面功能 特点:可复用、独立、可组合 2....组件的两种创建方式 2.1 使用函数创建组件 使用js的函数(箭头函数)创建的组件 约定1:函数名称必须以大写字母开头        ...Hello/>,document.getElementById('root')) 2.2 使用类创建组件组件使用ES6 的class创建的组件 约定1:类名称必须以大写字母开头 约定2:类组件继承自...React.Component父类,从而可以使用父类中提供的方法或属性 约定3:类组件必须提供render() 方法 约定4:render()方法必须有返回值 表示该组件的结构 class Hello...创建Hello.js 在Hello.js中导入React 创建组件(函数 或 类) 在Hello.js中导入该组件 在index.js中导入Hello组件 渲染组件 hello.js import React

1.3K30

精读《react-intersection-observer 源码》

1 引言 IntersectionObserver 可以轻松判断元素是否可见,在之前的 精读《用 React 做按需渲染》 中介绍了原生 API 的方法,这次刚好看到其 React 封装版本 react-intersection-observer...2 简介 react-intersection-observer 提供了 Hook useInView 判断元素是否在可视区域内,API 如下: import React from "react"; import...{ useInView } from "react-intersection-observer"; const Component = () => { const [ref, inView] =...INSTANCE_MAP.has(element), "react-intersection-observer: Trying to observe %s, but it's already being...看过 react-intersection-observer 的源码后,你觉得还有可优化的地方吗?欢迎讨论。 版权声明:自由转载-非商用-非衍生-保持署名(创意共享 3.0 许可证)

94910

使用storybook管理React组件

本文已React的UI组件为例,演示如何新建/集成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浏览器和storybook的url绑定组件特点,来渲染不同的UI组件,再进行图片快照的对比

3.2K20

React 组件进行单元测试

React 单元测试中用到的工具 III. 用测试驱动 React 组件重构 IV. React 单元测试常见案例 I....React 单元测试中用到的工具 Jest 不同于"传统的"(其实也没出现几年)的 jasmine / Mocha / Chai 等前端测试框架 -- Jest使用更简单,并且提供了更高的集成度、更丰富的功能...fs 进行预处理读写等,灵活性非常高,可以很好的兼容各种项目 babel-jest 由于是面向src目录下测试React代码,并且还使用了ES6语法,所以项目下需要存在一个.babelrc文件: {...对于一些组件和共有函数等,完善的测试也是一种最好的使用说明书。...优化依赖 让 React 组件变得 testable 合理编写组件化的 React,并将足够独立、功能专一的组件作为测试的单元,将使得单元测试变得容易; 反之,测试的过程让我们更易厘清关系,将原本的组件重构或分解成更合理的结构

4.2K40
领券