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

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

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

2.9K10

使用jest进行单元测试

今年的不幸与坎坷使我有很长一段时间去思考人生,不想将就了,鲁棒健壮的程序,开发测试应该是分得很开的,于是我选择jest去做单元测试这件事。...不扯犊子直接说吧,第一点,用数据、用茫茫多的测试用例去告诉使用者,你的程序是多么鲁棒健壮;第二点,把它作为一种素养去培养吧,当你按照一系列规范去做事,那么你做出来的东西,我想是有品质在的。...进行语法转义。...通用写法 "test": "jest" : 这个比较傻瓜式,当执行npm run test这条命令是会去对test目录下的所有文件进行相应的jest测试。...异步 我们通过request-promise这个库去请求https://v1.hitokoto.cn去获取相应的json数据,然后进行断言。

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

使用 Jest 进行前端单元测试

Jest 默认使用 Jasmine 语法,支持直接使用 Promise async/await 进行异步测试,支持对 React 组件进行快照监控, 扩展集成 Babel 等常用工具集也很方便。...我们在写一个测试用例前,如果能对非关键的依赖进行 mock,只约定好最后的返回,就不用再先解决一堆依赖环境问题,把精力集中在要测试的单元上来编写 test case ,同时也缩短测试用例执行的时间,做到最小化测试...例如使用 jest.useFakeTimers() 把遇到的计时器挂起,在必要时再使用 jest.runOnlyPendingTimers() 执行掉已经挂起的计时器。...除此之外 Jest 也可以结合 enzyme 更好的在 React 项目中进行测试(enzyme 是 airbnb 开源的一个 React 测试工具,通过 Shallow Rendering 的实现对...要了解更多可以阅读 官方文档 [附3] enzyme [附4] 。 异步支持 如果有使用过 node-tap 之类的老测试框架,在遇到异步情况时候肯定感受过麻烦了。

5.5K90

【译】使用EnzymeReact Testing Library测试React Hooks

在本教程中,我们将了解如何通过使用带有hooks的to-do应用程序来实现这一点。我们将介绍使用EnzymeReact Testing Library编写测试,这两个库都能做到这一点。...如果你第一次使用Enzyme,我们之前发布过关于它的文章,《Enzyme如何在React应用中与Jest一起使用》。我们可以用他们来深入测试React Hooks。...getbyTestId来返回inputul元素。...React钩子应用中的其他钩子一样容易出错,你要确保你能很好地使用它们。正如我们刚才看到的,有几种方法可以做到这一点。...无论你是使用Enzyme或是enzyme与React Testing Library其中之一来写测试完全取决于你。不管怎样,试着使用linting,毫无疑问,你会很高兴你这样做了。

4K30

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

Jest 是一款轻量的 JavaScript 测试框架,它的卖点是简单好用,由 facebook 出品。本文就简单讲讲如何使用 Jest 对 React 组件进行测试。 为什么需要单元测试?...单元测试(Unit Testing),指的是对程序中的模块(最小单位)进行检查验证。比如一个函数、一个类、一个组件,它们都是模块。 使用单元测试的优点: 更好地交付高质量代码。...可以通过设置 Jest 配置文件的 testMatch 或 testRegex 选项进行修改,或者 package.json 下的 "jest" 属性。...Jest 基本使用 我们先写一个简单的函数,作为被测试的模块。...官方只支持到 React 16,Enzyme 已死: https://dev.to/wojtekmaj/enzyme-is-dead-now-what-ekl 使用 Jest 测试 React 组件

2.8K20

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

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

6K30

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

JavaScript测试教程-part 1:用 Jest 进行单元测试 2. JavaScript测试教程–part 2:引入 Enzyme 并测试 React 组件 3....JavaScript测试教程–part 4:模拟 API 调用模拟 React 组件交互 在本教程的第一篇中,我们简要介绍了单元测试的基础。这次要更进一步,使用 Enzyme 库测试 React。...我们在这里用了 Jest,不过 Enzyme 也可以与 Mocha Chai 之类的库一起使用Enzyme 基础 Enzyme 是一个库,用于在测试时处理你的 React 组件。...这里要注意一个非常重要的点:即使我们用了 Enzyme,但测试运行程序仍然是 Jest。由于我们用的是 expect 函数,因此可以使用各种可供调用的匹配器函数。我已经在课程的第一部分中提到了它们。...要将其与 Jest 一起使用,请安装 jest-enzyme 包。 1npm install jest-enzyme 最后要做的是将其导入 setupTests 文件中。

1.4K50

使用storybook管理React组件

使用storybook的插件功能 storybook的很多功能都是靠插件来实现的,大多数插件都需要提前注册,在页面中有一个单独的tab来对storybook进行增强。...测试UI组件 4.1 写测试用例的原因 找到bug 新修改没有改变已有的接口功能 将测试用例作为文档 4.2 测试结构 使用storyshots插件来实现,其核心是使用Jest,原理是每次生成一份DOM...4.3 测试交互 storybook交互性测试可以使用 Enzyme来模拟用户输入,然后使用Mocha or Jest进行结果测试,storybook又一个专门的插件帮助我们集成他们:specifications...4.4 测试样式 样式测试这里采用Puppeteer Jest来实现,其原理是利用Puppeteer的无头的chrome浏览器storybook的url绑定组件特点,来渲染不同的UI组件,再进行图片快照的对比...包管理 使用lerna进行包管理发布。 6. 参考链接 Storybook 4.0 is here!

3.3K20

原创干货:前端单元测试Jest零基础入门教学

(例如浏览器),然后运行你的代码,看代码是否按预期运行 ---- 这里为了降低文章篇幅,对于初学者更友好,于是这里使用我开源的通用脚手架,集成TypeScript+JavaScript混合开发,Jest...框架,测试React组件、Enzyme、dva、Antd按需加载等主流技术~ 推荐大家使用 我开源的脚手架在npm上叫:ykj-cli 使用步骤: npm i ykj-cli -g 或 yarn add...,测试一把看看 yarn test 发现没有反应,这是为什么?...函数作为Props 检测挂载后的树型结构中的container类名的元素长度为1 这里⚠️:如果是断言,需要判断值的,使用toBe,如果是 对象要进行比较的,使用toEqual yarn test...文件夹,进入后我们直接打开里面的index.html文件,可以看到单元测试报告 ---- 这样里面有一些像分支覆盖率、函数、代码函数覆盖等 其实像Jest用起来还是比较方便的,核心理念就是使用测试框架运行业务代码

1.1K20

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

在上一篇教程中,我们已经介绍了使用 Enzyme 测试 React 组件的基本知识。...今天,我们将更深入地挖掘并学习如何测试组件的 Props,如何(以及为什么)使用 mount 函数,以及什么是 Jest 快照测试。..._Mount 使用 DOM 实现的模拟,Jest 默认使用的是 jsdom。我们可以通过调整 testEnvironment 属性更改。 快照测试 快照测试是 Jest 的一大招牌功能。...当我们再次运行快照测试时,Jest 会将新的快照与旧的快照进行比较,如果两者不一致,测试就会失败,从而帮助我们确保用户界面不会发生意外改变。...- END - ● JavaScript 测试系列实战(一):使用 Jest Enzyme 测试 React 组件● 你不知道的 Npm(Node.js 进阶必备好文)● 用动画实战打开 React

2.1K20

Unit Testing

#配置单元测试 #安装 Jest 我们使用 yarn 来安装 Jest 包 yarn add -D jest 在 package.json 文件中加入测试命令 { "scripts": {...运行 Jest 测试代码时出现 Cannot use import statement outside a module 不能在其他模块使用 import 语句 出现这个问题的主要原因在于 Webpack...默认会忽略 node_modules 文件夹下的文件代码 无法识别 css scss 等样式文件 在我们组件当中大部分都会有 css 或者 scss 等文件,但是 Jest 并无法处理这类文件,此时需要将此类样式文件都...__/enzymeMock.js'] } /__mocks__/enzymeMock.js 文件代码 import Enzyme from 'enzyme' import Adapter...from 'enzyme-adapter-react-16' Enzyme.configure({ adapter: new Adapter() }) 其他配置可以参考官网的配置文档来进行进一步的配置

1.3K20

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

在这篇教程中,我们将学习如何测试更复杂的组件,包括用 Mock 去编写涉及外部 API 的测试,以及通过 Enzyme 来轻松模拟组件交互 初次尝试 Jest Mock 我们的应用程序通常需要从外部的...编写 axios 模块的 mock 文件 Jest 支持对整个模块进行 Mock,使得组件不会调用原始的模块,而是调用我们预设的 Mock 模块。...打开 TodoList 的测试文件,首先在最前面通过 jest.mock 配置 axios 模块的 Mock(确保要在 import TodoList 之前),在 Mock 之后,无论在测试还是组件中使用的都将是...首先通过 jest.spyOn,我们便可以监听一个函数的使用情况,然后使用配套的 toBeCalled Matcher 来判断该函数是否被调用。整体代码十分简洁,同时也保持了很好的可读性。...我们可以使用本系列前面部分介绍的 enzyme 库来解决此问题,而且使了一点小聪明,我们创建 testHook.js : // src/testHook.js import React from 'react

4.8K20

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

Jest Jasmine 具有非常相似的 API ,所以在 Jasmine 中用到的工具在 Jest 中依然可以很自然地使用。...虽然 Jest 提供了很丰富的功能,但是并没有内置 ES6 支持,所以依然需要根据不同运行时对代码进行转换,由于 Jest 主要运行在 Node 中,所以需要使用 babel-jest 将 ES Module...在真实浏览器环境下测试 目前 Jest 不支持直接在真实浏览器中进行测试,其默认的启动器只提供了一个 JSDOM 环境,在浏览器中进行单元测试目前只有 Karma 方案能做到,所以也可以使用 Karma...使用 Jest + Enzyme 对 React 进行单元测试 ?...enzyme Enzyme基础配置如下: npm install enzyme enzyme-adapter-react-16 jest-enzyme jest-environment-enzyme jest-canvas-mock

9.5K20

基于TypescriptJest刷题环境搭建与使用

写在前面 前几个月在公司用vue3 https://v3.vuejs.org/ts写项目,想巩固一下基础,于是我想起了去年基于JavaScriptJest搭建的刷题环境https://zhengjiangtao.cn.../coding,不如,给它搞个加强版,结合TypescriptJest https://jestjs.io/搞一个刷题环境https://zhengjiangtao.cn/coding-ts/,下面是我的一些使用心得...环境搭建 前期工作 这里统一用yarn https://yarnpkg.com/来进行相关的npm 包https://www.npmjs.com/安装与维护,使用其他安装管理工具的参照着这个改吧。...的开发环境依赖 yarn add jest ts-jest @types/jest -D 配置jest.config.js /** @type {import('ts-jest/dist/types'...'@babel/preset-typescript', ], }; 具体的参考这里,https://jestjs.io/docs/getting-started 安装prettier

1.2K40

JavaScript 测试教程–part 3:测试 props,挂载函数快照测试

JavaScript测试教程-part 1:用 Jest 进行单元测试 2. JavaScript测试教程–part 2:引入 Enzyme 并测试 React 组件 3....JavaScript测试教程–part 4:模拟 API 调用模拟 React 组件交互 在上一篇教程中,我介绍了使用 Enzyme 测试 React 组件的基础知识。...今天,将进行更深入的研究,并学习如何测试 props,如何(以及为什么)使用 mount 函数以及什么是快照测试。开始吧! 测试 props 在上一篇文章中,我们测试了通过一些 props 的结果。...Mount 模拟了 DOM 的实现,而 Jest 默认使用 jsdom。...使用 mount 函数可能意味着你是在进行单元测试,而现在在进行集成测试。正是由于这个事实,使用 mount 函数能够测试这些组件是否可以协同工作,而不仅仅是单独的单元测试。

1.7K20

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

/src/utils'; // 把遇到的计时器挂起,在必要时,再使用jest.runOnlyPendingTimers执行掉已经挂起的计时器 jest.useFakeTimers(); // 描述块,将多个...() 作用: 把遇到的计时器挂起,在必要时,再使用jest.runOnlyPendingTimers执行掉已经挂起的计时器 这里使用jest.useFakeTimers()的目的就是暂停正在执行的timer...测试用例 import React from 'react'; //enzyme库用来判断、操纵遍历 ReactComponents import {mount} from 'enzyme'; import...enzyme.mount()生成完整的React组件 ② mount()/shallow()/render()的区别如下: [1] mount()借助jsdom模拟浏览器环境,并提供DOM api生命周期的支持.../docs/api/mount.html 通过本文,你应该知道 ① jest.useFakeTimers()的作用及何时使用 ② 如何测试function ③ 如何测试ReactComponent ④

6.1K50

年轻时,我不写单元测试

笔者在这里试着归纳了一下解决问题的办法 样式问题需要制定相应的规范 不能使用css,只能用less来书写(大哥,都2888年了还不用less吗) 使用less的类模块化写法 命名风格采用BEM (推荐)...,关于不同测试框架的重点,这篇文章就不详细展开了,最终结合我们的项目,最终采用了facebook的jest+enzyme。...shapshot就是会对组件进行一次快照记录当前的状态,每一次run jest的时候,对比上一次,看看是否有变化。...一开始我觉得单元测试很鸡肋的原因也是没有深入了解它,这次发现就算是业务结合很紧密的组件,也能够模拟正常的操作,这里就贴一个redux结合的组件来举例 import React from 'react...'; import Enzyme from 'enzyme'; import AppInput from '..

85320
领券