node.js - 添加 setupFilesAfterEnv 后模拟函数在 .test 文件中不起作用

标签 node.js typescript jestjs ts-jest

像这样在 jest.config.js 中添加 setupFilesAfterEnv 之后:

module.exports = {
    preset: 'ts-jest',
    testEnvironment: 'node',

    setupFilesAfterEnv: ["./test/setupAfterEnv.ts"]  
}

模拟函数在 .test.ts 文件中不再起作用,但在 setupFilesAfterEnv 中编写的文件中起作用,如 ./test/setupAfterEnv.ts

mock函数示例(.test.ts文件和setupAfterEnv.ts在同一个目录下):

jest.mock("../src/service/sendEmail.ts", () => ({
    send: () => {
        return "MOCK sendEmail sent"
    }
}));
  • 我没有收到任何错误,应该模拟的另一个函数运行了。当我在 mock 函数中写入错误的路径时,我得到错误 cannot find module。所以它看起来找到了应该被模拟但不运行模拟函数而是运行另一个函数的函数

  • 如果我在 jest.config.js 中注释了 setupFilesAfterEnv 配置,它会再次工作。

最佳答案

文档状态

Warning: Importing a module in a setup file
(as specified by setupTestFrameworkScriptFile)
will prevent mocking for the module in question, 
as well as all the modules that it imports.

如果您的 ./test/setupAfterEnv.ts 中有任何导入/要求,它们可能会导入其他文件,并且在该过程中导入的任何链都将无法模拟('../somemodule');在测试中。

我不确定为什么会有这个限制;如果您在 setupAfterEnv.ts 文件本身中调用 mock('../somemodule') ,它将在稍后的测试中被模拟。但我认为这很糟糕,因为只有一些测试可能想要模拟某些模块,而其他人则希望它们不会被模拟。可惜。就我而言,我想导入一个 typeorm 库并连接到数据库。但是创建此连接的类导入了我们所有的实体,所有实体类导入了其他类,这些类又导入了其他类等等……所以没有什么是可模拟的。由于此限制,根本无法使用。

关于node.js - 添加 setupFilesAfterEnv 后模拟函数在 .test 文件中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63157643/

相关文章:

node.js - Jest 测试失败时如何打印请求和响应?

node.js - 如何使用 JWT 将 key 从前端( Angular 4)传递到后端( Node js)

javascript - http-proxy-middleware - 访问静态文件

javascript - 如何获取数组中 objectId 的内容 - Mongoose/NodeJs

angularjs - 在 Angular 2 中,当我尝试使用双向绑定(bind)时 ngIF 不起作用

typescript - vue-router 3.5.1 : <router-link>'s tag prop is deprecated and has been removed in Vue Router 4 中的警告

node.js - Sequelize find 没有成功功能

javascript - 字符串原型(prototype)在浏览器中有效,但在 Node 中无效

javascript - 如何测试简单的中间件

jestjs - Jest 测试失败 -> 测试套件无法运行 : �PNG SyntaxError: Invalid or unexpected token