明明单独跑某个测试是通过的,怎么全部一起跑就挂了呢

  1. 你是否遇到过单独跑test case 3是通过的,但是全部整个文件一起跑就挂了呢

  2. 你的第一反应是前面的某个依赖项影响到test case 3了

  3. 于是你在最前面写下了

    复制代码
    afterEach(() => {
       jest.clearAllMocks 
    })
  4. 重新跑测试文件,仍然是挂的

Note: clearAllMocks并不能解决所有的mock

Jest中关于清除和重置mock的方法有以下这些,他们为不同的mock做清扫工作

jest.clearAllMocks()

  • 清除存储在mock.calls,mock.instances,mock.context,mock.results.
  • 这种场景一般是同一个方法被call了几次,每次的数据或者参数都不一样
  • 注意:调用这个方法会替换掉mockFn.mock

jest.resetAllMocks()

  • 重置所有mock的状态。
  • 适用于有状态变更的测试场景

jest.restoreAllMocks()

  • 恢复所有的mock和替换属于的值为初始值
  • 注意:此方法只作用mock了jest.spyOn()方法和属性替换用了jest.replaceProperty().其他的mock需要手动恢复

jest.resetModuls()

  • 重置module的注册
复制代码
```
const sum1 = require('../sum');
jest.resetModules();
const sum2 = require('../sum');
sum1 === sum2;
// > false (Both sum modules are separate "instances" of the sum module.)
```
  • 也可以用 isolateModulesAsync

jest.clearAllTimers()

复制代码
### `移除任何待办的计时器`

   
相关推荐
彩旗工作室9 小时前
Clerk 完全指南:现代 Web 应用的用户认证革命
react·next·用户认证·clerk
全栈前端老曹1 天前
【前端权限】 权限变更热更新
前端·javascript·vue·react·ui框架·权限系统·前端权限
Dragon Wu1 天前
TanStack Query(React Query) 使用总结
前端·react.js·前端框架·react
Hao_Harrision3 天前
50天50个小项目 (React19 + Tailwindcss V4) ✨| RandomChoicePicker(标签生成)
前端·typescript·react·vite7·tailwildcss
Hao_Harrision3 天前
50天50个小项目 (React19 + Tailwindcss V4) ✨| FAQ Collapse(问题解答折叠面板)
前端·typescript·react·vite7·tailwildcss
前端不太难5 天前
RN 版本升级、第三方库兼容、Android/iOS 崩溃(实战博文 — 从 0.63 升到 0.72)
android·ios·react
前端无涯6 天前
TypeScript 完整学习指南:从基础到工程化实践
typescript·vue·react
至善迎风7 天前
React2Shell(CVE-2025-55182)漏洞服务器排查完整指南
网络安全·react·数据安全·漏洞·next·rsc·cve-2025-55182
打小就很皮...7 天前
前端 Word 导出:自定义页眉表格的实现方案
前端·word·react·页眉设置
相逢一笑与君行8 天前
css使用grid布局实现网格(表格),动态调整行高,列宽,整体缩放,插入行,列,删除行,列
前端·css·react