监视在click事件中调用的函数
Spy on function that's called on click event
我做错了什么?试图监视在元素click事件上调用的函数,但测试总是返回false。
规范:
describe('button', function() {
before(function() {
this.spy = sinon.spy(window, 'testMethod');
});
it('Should call testMethod', function() {
$('#testBtn').click();
expect(this.spy.called).to.equal(true);
});
});
js:
$('#testBtn').on('click', testMethod);
function testMethod() {
return true;
}
问题是由于这一行:
$('#testBtn').on('click', testMethod);
在设置间谍之前获取对testMethod
的引用。所以它获取原始函数的引用,而不是间谍,然后你在window.testMethod
上设置间谍并不重要,因为在点击事件上调用的函数总是原始的testMethod
。您有几个选项可以让您的测试工作:
在后输入
$('#testBtn').on('click', testMethod);
设置间谍。例如,你可以把它放在你的before
钩子中。将
$('#testBtn').on('click', testMethod);
更改为$('#testBtn').on('click', function () { testMethod(); });
。每次处理单击事件时,匿名函数将获取对testMethod
的新引用。所以一旦你设置了它,它就会获取一个对spy的引用。
我已经通过创建一个测试来测试我在这里所说的,该测试复制了您的代码并使用了上面的两个修复。
Try
expect(this.spy).to.have.been.called();
不是expect(this.spy.called).to.equal(true);
相关文章:
- 如何从模块链中调用函数.导出到节点中
- 调用函数内部的函数
- 在javascript中调用c函数
- DropDownListFor赢得't在更改时调用函数
- Javascript页面调用函数
- 在动画结束之前调用函数
- 允许父窗口在其不同域的子iframe上调用函数
- 运行Infinite Scroll后调用函数时出现问题
- JavaScript:在调用函数的文本输入上按enter键
- 使用大括号和不使用bracs调用函数的区别
- javascript在事件上调用函数
- 从index.html调用函数,该函数无限循环
- 从带参数的字符串变量调用函数中的函数
- 为什么 JS 不在滚动时调用函数
- 是否可以在不更改上下文的情况下调用函数.apply
- 如何在ES6类中使用参数调用函数
- AngularJS:调用函数时编号不更新
- JavaScript中的立即调用函数表达式(IIFE)-传递jQuery
- 在JavaScript中调用函数时自定义此选项
- 调用函数中声明的变量