我正在用玩笑编写单元测试,并且必须测试一个从第三方库调用构造函数的函数(测试的目标是检查调用是否使用了良好的参数)
第 3 方库是 Popper.js
我做了一个jest.spyOn(Popper.prototype, 'constructor').mockImplementation( () => {})
但它抛出来自构造函数内部的错误(因此它不是被调用的模拟函数)
这是我的测试代码
import Popper from 'popper.js';
it('should call Popper constructor with correct argument', () => {
// Arrange
jest.mockImplementation(Popper.prototype, 'constructor', () => {});
const refElem = document.createElement('div');
const popElem = document.createElement('div');
const placement = 'top';
const container = document.createElement('div');
// Act
popup.create(refElem, popElem, placement, container);
// Assert
expect(Popper.prototype.constructor).toHaveBeenCalled();
});
我终于设法为此做点什么。
我手动创建了一个模拟模块(因为jest.genmockfromModule
似乎不起作用)
jest.mock ('popper.js', () =>
{
class Popper {
constructor(a,b,c){
this.spy(a,b,c);
}
spy(a,b,c) {}
destroy() {}
}
return Popper;
});
当您想知道是否已使用正确的参数调用构造函数时,可以使用间谍函数进行“监视”
(这里你有 3 个参数,因为popper.js
)
因此我在我的规范文件中像这样使用它:
import Popper from 'popper.js';
...
jest.spyOn(Popper.prototype, 'spy');
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)