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

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

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

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

    |-------|--------------------------------------------------|
    | 1 2 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的注册
复制代码
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 | `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()

复制代码
#### `移除任何待办的计时器`
相关推荐
HtwHUAT几秒前
五、web自动化测试01
前端·css·chrome·python·功能测试·selenium·html
86Eric4 分钟前
Vue 中 使用 Mixins 解决 多页面共用相同组件的相关问题
前端·javascript·vue.js·mixins·公用组件
qq_252496399615 分钟前
react 子组件暴露,父组件接收
前端·javascript·react.js
fakaifa19 分钟前
【最新版】西陆健身系统源码全开源+uniapp前端
前端·小程序·uni-app·开源·php·约课小程序·健身小程序
南囝coding24 分钟前
关于我的第一个产品!
前端·后端·产品
iOS阿玮31 分钟前
别等了,今天是Xcode15时代的最后一天。
前端·app·apple
沙尘暴炒饭37 分钟前
vuex持久化vuex-persistedstate,存储的数据刷新页面后导致数据丢失
开发语言·前端·javascript
2401_8370885039 分钟前
CSS清楚默认样式
前端·javascript·css
zwjapple1 小时前
React 的 useEffect 清理函数详解
前端·react.js·前端框架
Jewel1051 小时前
如何配置Telegram Mini-App?
前端·vue.js·app