我相信我对Javascript的理解有些根本错误。
在文件abc.js中,我有代码
export function returnBoolean() {
return true;
}
export function output() {
return returnBoolean();
}
在测试中,我做到了
import * as abc from "../abc";
it("test", () => {
abc.returnBoolean = jest.fn();
abc.returnBoolean.mockReturnValue(false);
expect(abc.returnBoolean()).toBe(false); // This is success
expect(abc.output()).toBe(false); // This failed because return is true
});
我不知道为什么abc.output()
回归是true
。
我真的很困惑。任何想法都非常感激。谢谢!
output()
和returnBoolean()
都在同一个文件中,output()
直接调用returnBoolean()
。
模拟returnBoolean()
的模块导出对output()
没有任何影响,因为它没有使用模块,它直接调用returnBoolean()
。
就像felixmosh所说的那样,将returnBoolean()
移动到另一个模块是一种能够在returnBoolean()
内模仿对output()
的调用的方法。
另一种方法是简单地将模块导入自身并使用模块在returnBoolean()
中调用output()
,如下所示:
// import the module back into itself
import * as abc from './abc';
export function returnBoolean() {
return true;
}
export function output() {
return abc.returnBoolean(); // use the module to call returnBoolean()
}
使用这种方法,您的单元测试应该可行。
想想看,无论何时导入abc
模块,都会声明该模块中的所有函数,因此,output
函数将“绑定”到原始的returnBoolean。
您的模拟不适用于原始功能。
你有2个选择:
returnBoolean
可以在一个单独的模块上,您将能够使用jest's mocking mechnisem。output
方法的接口,那么它将能够从模块外部获取returnBoolean
。然后你就可以传递给它,jest.fn()
并对它做出你的期望。