- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
像这样在 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/
我正在使用 @angular-builders/jest为了在测试 Angular 项目时用 Jest 代替业力。有 2 个库我喜欢为开 Jest 获得额外的匹配器:jest-extended和 @t
在 Webstorm 中,我使用 jest 进行单元测试,并使用 expect.extend() 创建了一个扩展。此代码在 {projectDir}./tests/jest-helpers.js 和我
像这样在 jest.config.js 中添加 setupFilesAfterEnv 之后: module.exports = { preset: 'ts-jest', testEnv
像这样在 jest.config.js 中添加 setupFilesAfterEnv 之后: module.exports = { preset: 'ts-jest', testEnv
Option "setupTestFrameworkScriptFile" was replaced by configuration "setupFilesAfterEnv", which supp
我已经阅读了 Jest 文档,我认为它们按此顺序运行。我还了解到 globalSetup 在不同的进程中运行,因此不与常规测试套件共享任何范围,而是与 globalTeardown 共享任何范围,因此
我是一名优秀的程序员,十分优秀!