Javascript 为什么Jest仍然需要模拟模块?
我正在使用Jest模拟一个模块,因为它包含不应该在测试中运行的代码。但是,我可以从输出中看到模块中的代码正在运行Javascript 为什么Jest仍然需要模拟模块?,javascript,mocking,jestjs,node-modules,Javascript,Mocking,Jestjs,Node Modules,我正在使用Jest模拟一个模块,因为它包含不应该在测试中运行的代码。但是,我可以从输出中看到模块中的代码正在运行 // foo.js console.log('Hello') // test.js jest.mock('./foo') const foo = require('./foo') test.todo('write some tests') 控制台输出 PASS test.js ✎ todo 1 test console.log foo.js:1 Hello 这是怎么回
// foo.js
console.log('Hello')
// test.js
jest.mock('./foo')
const foo = require('./foo')
test.todo('write some tests')
控制台输出
PASS test.js
✎ todo 1 test
console.log foo.js:1
Hello
这是怎么回事?这让我有好几次绊倒了 如果不为
jest.mock
提供模拟实现,它将返回一个对象,该对象镜像模拟模块的导出,但每个函数都替换为模拟jest.fn()
。这是相当整洁的,因为它通常是你想要的。但为了确定模块的导出,它必须首先要求它。这就是导致运行控制台.log
的原因
两种可能的解决办法:
- 不要在模块的顶层运行代码:而是导出运行代码的函数
- 提供您自己的mock实现,这样它就不需要内省模块
jest.mock('./foo',()=>{})