首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

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

前两天给一个包含setTimeout调用的函数写单元测试,在使用fake timer的时候遇到了问题,记录一下。...为了测试执行失败时有发生重试,我编写了如下的测试用例: // job-queue.test.js const MockJob = jest.fn(() => { return { id: 0...Fake timer 这样修改之后测试用例虽然可以通过了,但如果将上面的3s改成6s,我们就会遇到超时错误: [image-20210823195537643.png] 这是因为Jest每个测试用例默认只给了...相应地,Jest还提供了advanceTimersByTime函数,可以将Jest运行测试用例时的假时钟向前拨动,并“按时”运行之前通过setTimeout、setInterval传入的回调。...根据Jest的官方文档,调用这个函数后,所有队列中的“微任务”都会被立刻执行,这里的目的就是保证catch回调能被立刻调用; 使用jest.advanceTimersByTime(6000)代替await

6.6K60

前端单元测试Jest

在过程化编程中,一个单元就是单个程序、函数、过程等;对于面向对象编程,最小单元就是方法,包括基类(超类)、抽象类、或者派生类(子类)中的方法。 集成测试,也叫组装测试或联合测试。...:支持promises和async/await; 自动生成静态分析结果:不仅显示测试用例执行结果,也显示语句、分支、函数等覆盖率。...Mock函数通常会提供以下三种特性: 捕获函数调用情况; 设置函数返回值; 改变函数的内部实现; jest.fn() jest.fn()是创建Mock函数最简单的方式,如果没有定义函数内部的实现,jest.fn...)生成一个mock函数 const fn = jest.fn(); foreach([1, 2, 3], fn); //测试mock函数被调用了3次...Jest的异步测试主要分为3种: done函数 return promise async/await done的例子如下: function fetchData(call) { setTimeout

2.7K20

Jest 进行 JavaScript 测试

在技术术语中测试意味着检查我们的代码是否符合某些预期。例如:给定一些输入,一个名为“transformer”的函数应返回预期的输出。 有许多类型的测试,很快你就会被术语所淹没,让我们长话短书。...对于这两种情况,你可以通过将测试看作检查给定函数是否产生预期结果的代码来帮助自己。以下是典型测试流程的样子: 导入要测试函数函数输入 定义期望输出 检查函数是否按照预期输出 就是这样。...如果你按照这些术语思考,测试不再可怕:输入 - 预期输出 - 断言结果。接下来我们还会看到一个方便的工具,用于检查几乎确切的测试内容。现在就动手学习 Jest!...请记住,测试是关于输入、功能和预期输出的问题。..., "link"); 在 Jest 测试中,你应该将函数调用包含在 expect 中,它与匹配器(用于检查输出的Jest函数)一起进行实际测试

2.7K30

Jest实战:单元测试与服务测试

(内置无头浏览器)来模拟用户使用,监听数据变动 jest 自带覆盖率统计工具 测试过程 针对上面的步骤以及核心的 jest 配置,分别做讲解。...有时候为了方便,会把测试常用的函数、配置放在 test 目录下,如果不忽略,会被统计进去,但它不属于源码部分。...断言与函数功能 这个很简单,但是可以配合 describe 关键字,层级区分测试逻辑。还可以配合 beforeAll 等生命周期钩子函数,提高测试效率。...远程 API 测试 有一些函数需要连接云的 API 进行认证,由于安全策略,不在云厂商的服务器上无法请求。...这时候,就需要 mock 对应的请求库,返回我们构造好的数据,以让函数逻辑走下去,提高测试覆盖率。

3.3K10

使用Jest测试原生TypeScript项目

关于rootDir 在进行技术选型的过程中,我看了最新版本的vue-cli里推荐用哪些框架进行测试,一个是jest,还一个是krama+mocha。...test应该是像纯函数一样保证输入输出都是一样的,UI test一方面与Dom耦合,另一方面又用户交互耦合,那具体应该怎么写呢? 思路是:模拟用户操作,再通过Dom进行判断是否渲染正确。...写完了测试,给我们的jest.config 多加一行配置,来生成我们的测试报告(Jest内置了 istanbul) javascript module.exports = { // ... collectCoverage...% Funcs函数覆盖率(function coverage):是否每个函数都调用了? % Lines行覆盖率(line coverage):是否每一行都执行了?...总结 至此,你应该对前端UI测试应该大致有一个宏观的了解。 本文没有过多得介绍Jest的用法或者语法,希望可以给不知道如何做测试的朋友们一点方向,自己去尝试找到适合自己项目的才是最好的。

2.8K60

使用jest进行单元测试

今年的不幸与坎坷使我有很长一段时间去思考人生,不想将就了,鲁棒健壮的程序,开发和测试应该是分得很开的,于是我选择jest去做单元测试这件事。...jest的相关配置 package.json中相关scripts 这里笔者罗列了常用的通用的一些关于jest的脚本,后面测试结果会陆续补充一些测试脚本,以上的脚本都编写在package.json文件下的...通用写法 "test": "jest" : 这个比较傻瓜式,当执行npm run test这条命令是会去对test目录下的所有文件进行相应的jest测试。.../test/caculator.test.js --watch": 单文件监视测试 "test:watchAll": "jest --watchAll": 监视所有文件改动,测试相应的测试。...大致基础类的脚本测试就总结到这里,接下来我们看下jest.config.js的相关配置。

3.5K60

React单元测试Jest + Enzyme(一)

前言 前端的单元测试在很多人看来都是一个可有可无的东西,理由一般有下面几条(以下内容统一称单元测试为单测): 写单测比较费时,有这个时间不如多做几个需求 测试在验收的时候对页面的功能都会操作一遍,写单测相当于做无用功...Jest是Facebook开发的一个测试框架,它集成了测试执行器、断言库、spy、mock、snapshot和测试覆盖率报告等功能。...安装完后,在项目的根目录新建__jest__文件夹和__tests__文件夹,此时__mocks__文件夹我们暂时不管,如下图所示: mudules文件夹将存放各个模块的单测代码,而utils文件夹里面是对一些公用的函数写的测试代码...__jest__/__tests__" } 此时在命令行输入npm run test,出现以下结果,说明Jes安装成功并通过第一个测试: 总结 按照上面说的步骤,如果一切顺利,你的第一个单测用例应该成功跑起来了...我们来回顾下我们都做了些什么: 安装Jest并让其支持ES6语法 新建对应的单测文件夹并新建一个单测文件 针对项目的webpack做相应的Jest配置 配置运行测试脚本 万事开头难,你已经踏出万里长征的第一步了

1.4K20

Jest做前端单元测试

市面上比较常见的前端单元测试 Jest、Mocha,各种对比 Jest 略胜一筹,所以下面就来初体验下 Jest 吧。...Jest 安装和使用直接新建个目录用 npm 安装就可以写个 demo 了,Jest 官方文档上也有教程。...# 初始化npm init# 安装(也可以全局安装)npm install --save-dev jest#测试:注意先要在 package.json 里加上"scripts": { "test": "...jest" }npm run test求两个数字之和的 sum.jsfunction sum(a, b) { return a + b}module.exports = sum测试脚本文件 sum.test.js...通常而言,一个单元测试是用于判断某个特定条件(或者场景)下某个特定函数的行为,是针对软件的基本单元(如:函数)所做的测试,而集成测试则是以模块和子系统为单元进行的测试集成测试:Integration Test

20820

Jest单元测试之旅—实践总结

而针对与我们前端来说,我认为单测就是:UI测试和逻辑测试,逻辑测试包含:工具类/函数、业务相关代码测试。UI测试分为:公共组件和业务组件测试。 为什么要写单元测试?...下面会根据各种场景进行分析 二、异步函数 在我们实际开发中我们会遇到很多异步函数,但是因为Jest在进行测试时,默认情况下一旦到达运行上下文底部当前测试立即结束,这样意味着测试将不能按照我们的预期进行,...好在Jest在针对异步函数测试也提供了我们多种方法。...每个方法都有不同的使用场景,每个API都会生成一个mock模拟函数Jest对模拟函数提供了很多方法给予我们模拟方法的返回、实现等等,可移至文档参考 jest.fn jest.fn主要是创建一个模拟函数...原因是如果依赖被测试功能的实现逻辑意味着修改实现逻辑但是输入输出没有变化也需要去更新测试代码。

10.2K20

在 ts + Jest 单元测试中 debugging

2、步骤 在认为可能失败并输入测试中插入一个 debugger。...Jest运行测试用例的特点是多进程并发运行不同测试案例,达到快速的效果。但是这样对调试来说是没法进行的。这个参数保证了使用一个进程运行所有代码。 接下来就可以开心的 debug 了: ?...的配置项教程,涵盖了 debug 全部测试文件 和 debug 单个测试文件 这两种场景,足够了 Debugging TypeScript Jest Tests With Visual Studio...Code:文中给出针对 ts + jest 的 launch.json 的配置项,可以借鉴一下 使用jest+enzyme进行react项目测试 - debug篇:虽说是 2017 年的文章,仍旧有可借鉴性...Debugging with TypeScript, Jest, ts-jest and Visual Studio Code:对新手友好的单元测试 debugger 入门文章,一步步教你;

3.9K30

Jest测试语法系列之Matchers

关于Jest测试的基础内容,可以参考之前的博客:前端单元测试Jest 本文主要讲的是匹配器(Matchers),匹配器(Matchers)是Jest中非常重要的一个概念,它可以提供很多种方式来让你去验证你所测试的返回值...+ 2) 将返回我们期望的结果,通常情况下我们只需要调用expect就可以,括号中的可以是一个具有返回值的函数,也可以是表达式。...后面的 toBe 就是一个matcher,当Jest运行的时候它会记录所有失败的matcher的详细信息并且输出给用户,让维护者清楚的知道failed的原因,如果我们改成 toBe(5),将会输出错误的提示...,如下图: toBe 是测试具体的某一个值,如果需要测试对象,需要用到toEqual。...,有时需要区分undefined、null和false,这些可以使用Jest的真实性匹配。

52120
领券