0

0

Jest中异步函数异常测试的正确姿势:expect().rejects用法详解

霞舞

霞舞

发布时间:2025-09-15 13:29:01

|

223人浏览过

|

来源于php中文网

原创

Jest中异步函数异常测试的正确姿势:expect().rejects用法详解

在Jest中测试异步函数抛出异常时,理解expect().rejects的正确用法至关重要。本文将详细阐述如何正确使用rejects断言一个Promise被拒绝并抛出特定错误,并指出常见的错误模式:将异步函数包裹在另一个函数中传递给expect,强调rejects旨在直接作用于Promise对象,而非函数。

理解Jest中的异步错误测试

javascript的异步编程中,promise是处理异步操作结果的核心机制。当异步操作失败时,promise会进入拒绝(rejected)状态,并通常伴随一个错误对象。jest提供了.rejects匹配器,专门用于测试promise是否被拒绝,并结合.tothrowerror()来验证拒绝的原因是否是预期的错误。

与同步函数的错误测试不同,同步函数使用expect(() => syncFun()).toThrowError(),需要将可能抛出错误的函数包裹在一个匿名函数中。然而,对于异步函数,.rejects的工作方式有所不同。

expect().rejects 的核心原理

expect().rejects旨在直接作用于一个Promise对象。当expect接收到一个Promise时,它会等待该Promise解析(resolve)或拒绝(reject)。如果Promise被拒绝,rejects链上的匹配器(如.toThrowError())将对拒绝值进行验证。

正确的异步错误测试方式

测试一个预期会抛出错误的异步函数asyncFun()的正确方式是直接将asyncFun()的调用结果(即一个Promise)传递给expect。

示例代码:

// 假设有一个异步函数,它会返回一个被拒绝的Promise
async function asyncFunThatThrows() {
  return new Promise((resolve, reject) => {
    // 模拟异步操作后抛出错误
    setTimeout(() => {
      reject(new Error('Async operation failed!'));
    }, 100);
  });
}

// 或者一个async函数直接抛出错误
async function anotherAsyncFunThatThrows() {
  await new Promise(r => setTimeout(r, 50)); // 模拟一些异步工作
  throw new Error('Another async error!');
}

describe('Testing async functions that throw errors', () => {
  test('should correctly catch an error from a rejected promise', async () => {
    const errorObj = new Error('Async operation failed!');
    // 直接将Promise传递给expect
    await expect(asyncFunThatThrows()).rejects.toThrowError(errorObj);
  });

  test('should correctly catch an error from an async function that throws', async () => {
    const errorObj = new Error('Another async error!');
    // 直接将Promise(async函数的返回值)传递给expect
    await expect(anotherAsyncFunThatThrows()).rejects.toThrowError(errorObj);
  });
});

在这种模式下,asyncFunThatThrows()或anotherAsyncFunThatThrows()被调用后会立即返回一个Promise。await expect(...)会等待这个Promise完成,如果它被拒绝,rejects.toThrowError()就会对拒绝值进行匹配。

常见的误区与原因分析

一个常见的错误是将异步函数再次包裹在一个匿名异步函数中,然后将其传递给expect。

奇布塔
奇布塔

基于AI生成技术的一站式有声绘本创作平台

下载

错误示例:

// 假设 asyncFun() 是一个会返回被拒绝Promise的异步函数
await expect(async () => {
  await asyncFun();
}).rejects.toThrowError(errorObj);

为什么这是错误的或不被推荐的:

  1. expect接收的是函数而非Promise: 在这个例子中,expect接收到的是一个匿名异步函数 async () => { await asyncFun() },而不是asyncFun()返回的Promise。尽管Jest在内部可能对传入的函数进行了某种处理,但这不是rejects设计的初衷和推荐用法。
  2. rejects期望Promise: .rejects匹配器是为Promise设计的。当它接收到一个函数时,其行为可能不符合预期,或者在未来的Jest版本中可能不再支持。Jest的官方文档明确指出.rejects应该用于Promise。
  3. 不必要的复杂性: 将一个异步函数包裹在另一个异步函数中,增加了不必要的嵌套和复杂性,同时也模糊了测试的意图。

这种写法在某些情况下可能“看似有效”,但它不是Jest官方文档推荐或保证的行为。正确的做法是始终将异步函数执行后返回的Promise直接传递给expect。

注意事项

  • await的重要性: 在使用expect().rejects时,必须在expect调用前使用await。这是因为expect().rejects本身返回一个Promise,你需要等待这个Promise解析,以确保断言逻辑能够执行。
  • Promise的拒绝状态: 只有当Promise进入拒绝状态时,.rejects才能捕获到错误。如果异步函数在执行过程中抛出异常,但没有被try...catch捕获并导致Promise拒绝,那么测试可能无法按预期工作。确保你的异步函数在失败时返回一个被拒绝的Promise。

总结

在Jest中测试异步函数抛出异常时,请牢记expect().rejects是为Promise设计的。正确的做法是直接将异步函数调用后返回的Promise传递给expect,例如 await expect(asyncFunctionCall()).rejects.toThrowError(error)。避免将异步函数包裹在另一个匿名函数中传递给expect,以确保测试的准确性、可读性以及与Jest最佳实践的一致性。遵循这一原则,你的异步错误测试将更加健壮和可靠。

相关专题

更多
js获取数组长度的方法
js获取数组长度的方法

在js中,可以利用array对象的length属性来获取数组长度,该属性可设置或返回数组中元素的数目,只需要使用“array.length”语句即可返回表示数组对象的元素个数的数值,也就是长度值。php中文网还提供JavaScript数组的相关下载、相关课程等内容,供大家免费下载使用。

557

2023.06.20

js刷新当前页面
js刷新当前页面

js刷新当前页面的方法:1、reload方法,该方法强迫浏览器刷新当前页面,语法为“location.reload([bForceGet]) ”;2、replace方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,不能通过“前进”和“后退”来访问已经被替换的URL,语法为“location.replace(URL) ”。php中文网为大家带来了js刷新当前页面的相关知识、以及相关文章等内容

395

2023.07.04

js四舍五入
js四舍五入

js四舍五入的方法:1、tofixed方法,可把 Number 四舍五入为指定小数位数的数字;2、round() 方法,可把一个数字舍入为最接近的整数。php中文网为大家带来了js四舍五入的相关知识、以及相关文章等内容

756

2023.07.04

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

478

2023.09.01

JavaScript转义字符
JavaScript转义字符

JavaScript中的转义字符是反斜杠和引号,可以在字符串中表示特殊字符或改变字符的含义。本专题为大家提供转义字符相关的文章、下载、课程内容,供大家免费下载体验。

474

2023.09.04

js生成随机数的方法
js生成随机数的方法

js生成随机数的方法有:1、使用random函数生成0-1之间的随机数;2、使用random函数和特定范围来生成随机整数;3、使用random函数和round函数生成0-99之间的随机整数;4、使用random函数和其他函数生成更复杂的随机数;5、使用random函数和其他函数生成范围内的随机小数;6、使用random函数和其他函数生成范围内的随机整数或小数。

1051

2023.09.04

如何启用JavaScript
如何启用JavaScript

JavaScript启用方法有内联脚本、内部脚本、外部脚本和异步加载。详细介绍:1、内联脚本是将JavaScript代码直接嵌入到HTML标签中;2、内部脚本是将JavaScript代码放置在HTML文件的`<script>`标签中;3、外部脚本是将JavaScript代码放置在一个独立的文件;4、外部脚本是将JavaScript代码放置在一个独立的文件。

659

2023.09.12

Js中Symbol类详解
Js中Symbol类详解

javascript中的Symbol数据类型是一种基本数据类型,用于表示独一无二的值。Symbol的特点:1、独一无二,每个Symbol值都是唯一的,不会与其他任何值相等;2、不可变性,Symbol值一旦创建,就不能修改或者重新赋值;3、隐藏性,Symbol值不会被隐式转换为其他类型;4、无法枚举,Symbol值作为对象的属性名时,默认是不可枚举的。

554

2023.09.20

菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

0

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.4万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号