javascript - Jasmine:单元测试后恢复原型(prototype)方法

标签 javascript mocking jasmine

为了测试我的代码的特定部分,我需要模拟一个原型(prototype)方法以确保它被调用。代码看起来像这样。

SomeObject.prototype.foo = jasmine.createSpy()
var so = SomeObject()
so.bar()
expect(SomeObject.prototype.foo).toHaveBeenCalled()

这有效,但它改变了我不想要的 SomeObject 的状态。所以我想知道有没有办法在我完成后恢复 prototype.foo 的状态?我正在考虑制作 SomeObject 的副本。我查看了 jQuery.extend,但不确定是否可以使用它来复制构造函数。

最佳答案

两种选择。最好监视实例:

spyOn(so, 'foo');

或者,如果您坚持要验证是否调用了原型(prototype):

spyOn(SomeObject.prototype, 'foo');

Jasmine 在每个 spec 之后都会拆掉所有的 spy 。

关于javascript - Jasmine:单元测试后恢复原型(prototype)方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5937887/

相关文章:

javascript - 是否可以使用浏览器内调试器?

javascript - 如何修复在 JavaScript 中使用 ctx.lineTo 显示为奇怪形状的六边形?

javascript - 在 Canvas 上绘制临时圆

java - 是否可以重用模拟?

scala - 您可以使用 ScalaMock 捕获并检查提供给被测方法的参数吗?

angular - 如何阻止构造函数内部的异步回调进行测试?

javascript - 对 Jasmine spy 的重置调用未返回

javascript - PHP 重定向 : Chrome closes window

angularjs - 单元测试依赖注入(inject)

php - 如何在模拟对象中设置变量