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

使用jest进行单元测试

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

3.5K60

使用Jest测试原生TypeScript项目

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

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

使用 Jest 进行前端单元测试

Jest 默认使用 Jasmine 语法,支持直接使用 Promise 和 async/await 进行异步测试,支持对 React 组件进行快照监控, 扩展和集成 Babel 等常用工具集也很方便。...Jest 对所有的 Timer (setTimeout, setInterval, clearTimeout, clearInterval 等)都提供了 mock 和 API,让你可以在测试反客为主,...例如使用 jest.useFakeTimers() 把遇到的计时器挂起,在必要使用 jest.runOnlyPendingTimers() 执行掉已经挂起的计时器。...异步支持 如果有使用过 node-tap 之类的老测试框架,在遇到异步情况时候肯定感受过麻烦了。现代的测试框架对异步的支持都是必需的。...我们都知道保持编写可测试的代码的习惯是非常重要的。可测试性差的代码,在写测试用例也会花费成倍的时间。例如下面这个例子: .

5.5K90

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

本篇教程是 JavaScript 测试系列实战 的第一篇教程,首先介绍了测试的类型,然后主要通过一个 React 项目教会你如何使用 Jest 编写第一个测试,然后使用 Enzyme 对 React 组件进行浅层渲染...端到端测试(E2E) 与其他类型的测试不同,E2E 测试总是在浏览器(或浏览器)环境中运行。...因此这里建议直接使用 npx jest 执行测试。 编写第一组测试 每个测试文件通常有多个测试用例。Jest 允许我们通过 describe 函数对测试用例进行分组,它创建了一个可以组合多个测试的块。...它允许我们在运行测试,只渲染父组件而不渲染其所有的子组件。浅层渲染十分快速,因此非常适合单元测试。...配置 jest-enzyme 你应该还记得,在刚才的测试代码中,我们还是使用Jest 自带的 Matcher(toEqual)。

2.9K10

自动化测试 Jest使用总结基础篇

使用 jest 的原因 随着前端的发展,web的交互越来越复杂,自动化测试是非常有必要融入到开发的流程中,而目前界内普遍通用且比较火的就是有 facebook开发的 Jest 这套工具。...他可以创建测试用例,执行测试,自身还有驱动和mock,且用起来也是很方便,正如 jest 的官网这样描述 jestJest is a delightful JavaScript Testing Framework...判断数据是否为空的情况 官方文档把这一的校验命名为 Truthiness ,也就是有效性。...jest 做回调操作测试需要注意,函数的回掉情况。...钩子函数的使用 钩子执行 再执行测试文件的时候,如果有需要对函数进行特殊处理的可以在执行前和执行后使用钩子函数,beforeEach and afterEach。

2.7K111

使用Jest测试包含setTimeout调用的函数踩坑记录

前两天给一个包含setTimeout调用的函数写单元测试,在使用fake timer的时候遇到了问题,记录一下。...在启用fake timer的时候,setTimeout、setInterval都会使用Jest提供的假实现,他们不会真正阻塞住测试用例。...相应地,Jest还提供了advanceTimersByTime函数,可以将Jest运行测试用例的假时钟向前拨动,并“按时”运行之前通过setTimeout、setInterval传入的回调。...(2); }); 我们做了以下改动: 使用jest.runAllTicks代替await delay(0)。...注意我们此时使用的是fake timer,因此是无法使用await delay(0)这个方案的,因此这会导致我们的测试用例在等待setTimeout被回调,而fake timer的setTimeout又在等待

6.6K60

工作笔记——使用Jest遇到的一些问题

最近公司想要从mocha+karma的前端单元测试方式转换到Jest,然后任务就分配给我了,好吧,在这之前连单元测试是什么都不知道。...不过在选择上,我们要选择Jest来做单元测试。   这样我们就得到了一个初始化,拥有Jest单元测试的项目了。...嗯..你的报错信息应该可能大概也许是下面这个样子:   这是我们在使用Jest遇到的第一个问题,解决的方式很简单,在test目录下的jest.config.js的配置中添加一项:   然后,再试一下...在测试环境下,我们使用jest也需要引入开发环境下的各种插件,形成一个独立的环境体系,当然,我们也可以通过其它手段来造假数据。这个我们后面再说,既然找不到BMap,那么怎么办呢?   ...实际上在使用过程中,主要有两问题,一个是环境配置的问题,要记住在写jest测试用例的时候,需要引入各依赖的文件,就像在main.js中那样。

1.3K20

工作笔记——使用Jest遇到的一些问题

最近公司想要从mocha+karma的前端单元测试方式转换到Jest,然后任务就分配给我了,好吧,在这之前连单元测试是什么都不知道。...不过在选择上,我们要选择Jest来做单元测试。 ?   这样我们就得到了一个初始化,拥有Jest单元测试的项目了。版本信息如下: ? ?    ...这是我们在使用Jest遇到的第一个问题,解决的方式很简单,在test目录下的jest.config.js的配置中添加一项: ?   然后,再试一下npm run unit,我们发现测试通过了。...在测试环境下,我们使用jest也需要引入开发环境下的各种插件,形成一个独立的环境体系,当然,我们也可以通过其它手段来造假数据。这个我们后面再说,既然找不到BMap,那么怎么办呢?   ...实际上在使用过程中,主要有两问题,一个是环境配置的问题,要记住在写jest测试用例的时候,需要引入各依赖的文件,就像在main.js中那样。

1.9K30

前端自动化测试实践01—持续集成之jest自动化测试环境搭建

,这就是持续集成;装修厨房有很多部分,每个部分都有检测手段,如地砖铺完了要测试漏水与否,线路铺完了要通电测试电路通顺,水管装好了也要测试冷水热水,如果等全部装完了再测,出现问题可能会互相影响,比如电路不行可能要把地砖给挖开...前端的自动化测试无非也是编写测试用例,在持续集成执行跑通全部测试用例。...$ npm install jest -D jest 默认不支持 es6,需要使用 babel 来支持 es6,安装 babel: $ npm install @babel/core @babel/preset-env...(multi(3, 3)).toBe(9); }) 执行测试,并在控制台观察结果 $ npm run test $ npm run coverage 3. vue-cli 中使用 jest 现实项目中,...则可以忽略指定文件,因此使用两个属性可以精确匹配到项目中所有的测试用例。

2.4K54

使用monkey测试,一个控制WiFi状态的多线程

传送门 本人在使用monkey进行手机APP性能测试的时候,经常会遇到WiFi被关闭,飞行模式被打开的问题,虽然monkey也要进行无网测试,但在无人值守使用monkey测试的时候,还是需要网络状态稳定一些...使用adb shell ifconfig wlan0拿到当前的网络状态,通过执行adb shell am命令来切换WiFi状态。...分享代码如下: 点点横点尘,公众号:龙腾测试使用monkey测试,一个控制WiFi状态的多线程 package monkeytest; import java.io.BufferedReader...一起来~FunTester 往期文章精选 java一行代码打印心形 Linux性能监控软件netdata中文汉化版 接口测试代码覆盖率(jacoco)方案分享 性能测试框架 如何在Linux命令行界面愉快进行性能测试...图解HTTP脑图 写给所有人的编程思维 测试之JVM命令脑图

74810

异步函数中的异常处理及测试方法

你将学到什么 通过后面的内容你将学到: 如何从 Javascript 的异步函数中抛出错误 如何使用 Jest 测试来自异步函数的异常 要求 要继续往下读你应该: 对 Javascript 和 ES6...有基本的了解 安装 Node.Js 和 Jest 如何从 Javascript 的常规函数中抛出错误 使用异常而不是返回码(清洁代码)。...这是对它的测试使用Jest): ? 也可以从 ES6中抛出错误。在 Javascript 中编写,我总会在构造函数中输入意外值。下面是一个例子: ? 以下是该类的测试: ?...以下是在Jest测试异常的规则: 使用 assert.throws 来测试普通函数和方法中的异常 使用 expect + rejects 来测试异步函数和异步方法中的异常 如果你对如何使用 Jest...测试 Koa 2 感兴趣,请查看使用Jest和Supertest进行测试的简绍这篇文章。

2.9K30

提高代码质量——使用Jest和Sinon给已有的代码添加单元测试

概述 在日常的功能开发中,我们的代码测试都依赖于自己或者QA进行测试。这些操作不仅费时费力,而且还依赖开发者自身的驱动。在开发一些第三方依赖的库,我们也没有办法给第三方提供完整的代码质量报告。...现在,我们可以使用单元测试来提高自己的代码质量。下面,我将自己在使用Jest和Sinon.js配置和编写单元测试中的收获的经验和踩到的坑进行总结,根据从零开始配置和编写单元测试这一条线来进行分享。...Jest配置 安装依赖包 需要使用Jest,首先你需要进行安装,执行以下命令: npm install jest -D 如果你的项目中存在.babelrc文件(使用了babel 6),不论你测试的代码是否通过...通过上面三测试,我们基本能够覆盖现有项目中的所有代码。 同步函数测试 同步函数的测试过程是这几个中最简单的一部分,我们可以测试函数返回值,也能够测试传入的高阶函数。...在本章中,我们总结了如下问题来进行介绍,希望大家再遇到相同问题能够快速解决: 如何统计Jest单元测试覆盖率 如何设置单元测试文件不使用本地的babel配置 如何设置单元测试文件使用本地的babel配置

3.7K00

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

本文将尝试用一个重构实例来抛砖引玉,讲解如何对其应用较新的 jest 测试框架,并用 ES6 class 等新手段升级 Backbone.View 视图组件和改善页面结构,希望能对类似项目的改善起到开启思路的作用...升级测试框架 和之前文章中的例子相同,本次依然采用 Jest 作为测试框架。...build 时运行测试 目标项目中,其实是用 babel 5 做的 ES6 转译;但是由于之前的源代码已经全部采用了 ES6 语法开发(部分初始 AMD 代码也做过自动转化),所以我们完全可以在测试采用较新的...jest.doMock() 方法,其缺点是用了这个就不能用 ES6 的 import 语法了,配置和使用简要说明如下: // jest.config.jsmoduleNameMapper: { "...总结 jest 灵活的配置能力,使其能方便的应用于各种类型既有项目的 TDD 开发和重构 之前的其他测试框架下的用例,可以快速迁移到 jest 中 Backbone.View 视图组件在经过 ES6 升级和合理封装后

3.4K10

React单元测试Jest + Enzyme(一)

React项目本身也是使用Jest进行单测的,因此它们俩的契合度相当高。 Enzyme是由airbnb开发的React单测工具。...Jest的安装与配置 npm install --save-dev jest jest-cli babel-jest 其中,babel-jest的作用是让单测代码支持ES6。...'; 对于css和scss文件,我们使用identity-obj-proxy来mock,它会在引用到class的地方直接返回class的名: npm install --save-dev identity-obj-proxy...我们来回顾下我们都做了些什么: 安装Jest并让其支持ES6语法 新建对应的单测文件夹并新建一个单测文件 针对项目的webpack做相应的Jest配置 配置运行测试脚本 万事开头难,你已经踏出万里长征的第一步了...在下一篇文章中,我将会详细介绍如何使用Jest来mock方法和数据,敬请期待。

1.4K20
领券