0

0

如何在 Jest 中动态修改模拟类方法的返回值

霞舞

霞舞

发布时间:2026-02-22 18:46:07

|

929人浏览过

|

来源于php中文网

原创

如何在 Jest 中动态修改模拟类方法的返回值

本文介绍在 Jest 测试中,如何在不重复调用 jest.mock() 的前提下,灵活地为模拟类(ES6 class)的方法设置不同返回值,适用于多场景单元测试需求。

本文介绍在 jest 测试中,如何在不重复调用 `jest.mock()` 的前提下,灵活地为模拟类(es6 class)的方法设置不同返回值,适用于多场景单元测试需求。

在 Jest 中,对 ES6 类进行模拟时,若需在不同测试用例中让同一方法返回不同值(例如 methodOne 返回 "ABC" 或 "XYZ"),直接在 jest.mock() 工厂函数中硬编码返回值是不可行的——因为 jest.mock() 会被提升(hoisted)至文件顶部执行,无法按测试用例动态变更。

正确的做法是:先通过 jest.mock('./module') 创建自动模拟(auto-mock),再利用 mockImplementation() 或 mockImplementationOnce() 在具体测试块中动态重写类的构造行为。该方式不仅避免了重复 mock 的语法错误,还支持跨 it() 块独立定制返回逻辑。

✅ 推荐实现方式(基于自动模拟)

假设原始模块 ./some-module.js 定义如下:

Wand AI
Wand AI

一个无代码AI平台,帮助组织快速创建基于AI的业务解决方案

下载
export class Abc {
  constructor(config) {}

  async methodOne(params) {
    return {
      message: { content: 'This text I need to change' },
    };
  }
}

主逻辑 main.js 调用该类:

import { Abc } from './some-module';

export async function main() {
  const abc = new Abc();
  const res = await abc.methodOne();
  return res.message.content;
}

对应测试 main.test.js 应这样编写:

import { main } from './main';
import { Abc } from './some-module';

// ✅ 启用自动模拟(不传工厂函数)
jest.mock('./some-module');

describe('动态修改模拟类方法返回值', () => {
  test('用例一:methodOne 应返回 "ABC"', async () => {
    // ✅ 动态覆盖 Abc 类的实例行为
    Abc.mockImplementation(() => ({
      methodOne: async () => ({ message: { content: 'ABC' } }),
    }));

    expect(await main()).toBe('ABC');
  });

  test('用例二:methodOne 应返回 "XYZ"', async () => {
    // ✅ 每个测试可独立配置,互不影响
    Abc.mockImplementation(() => ({
      methodOne: async () => ({ message: { content: 'XYZ' } }),
    }));

    expect(await main()).toBe('XYZ');
  });

  test('进阶:单次生效(仅本次调用)', async () => {
    Abc.mockImplementationOnce(() => ({
      methodOne: async () => ({ message: { content: 'ONCE' } }),
    }));

    expect(await main()).toBe('ONCE');
    // 后续调用将回退到默认 auto-mock 行为(如返回 undefined 或空对象)
  });
});

⚠️ 关键注意事项

  • 不要混用 jest.mock(..., factory) 和 mockImplementation():一旦使用带工厂函数的 jest.mock(),Jest 将锁定该实现,后续 mockImplementation() 不会生效;
  • mockImplementation() 影响所有后续 new Abc() 实例,适合整个 it() 块统一行为;
  • mockImplementationOnce() 更适合链式调用或多次实例化场景中的精准控制
  • 若被测代码中 Abc 是默认导出(export default class Abc {...}),则需通过 Abc.default.mockImplementation(...) 访问;
  • 所有 mockImplementation* 调用必须在 jest.mock() 之后、实际 new Abc() 之前执行。

通过这种模式,你可以在保持测试隔离性的同时,精准控制模拟类的行为,显著提升测试覆盖率与可维护性。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
es6新特性
es6新特性

es6新特性有:1、块级作用域变量;2、箭头函数;3、模板字符串;4、解构赋值;5、默认参数;6、 扩展运算符;7、 类和继承;8、Promise。本专题为大家提供es6新特性的相关的文章、下载、课程内容,供大家免费下载体验。

106

2023.07.17

es6新特性有哪些
es6新特性有哪些

es6的新特性有:1、块级作用域;2、箭头函数;3、解构赋值;4、默认参数;5、扩展运算符;6、模板字符串;7、类和模块;8、迭代器和生成器;9、Promise对象;10、模块化导入和导出等等。本专题为大家提供es6新特性的相关的文章、下载、课程内容,供大家免费下载体验。

196

2023.08.04

JavaScript ES6新特性
JavaScript ES6新特性

ES6是JavaScript的根本性升级,引入let/const实现块级作用域、箭头函数解决this绑定问题、解构赋值与模板字符串简化数据处理、对象简写与模块化提升代码可读性与组织性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

229

2025.12.24

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

686

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

22

2025.12.06

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

524

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

454

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

616

2023.08.03

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1030

2026.02.13

热门下载

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

精品课程

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

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