我已经创建了一个完整的简化示例,可以复制我遇到的问题。
function TestObj() {
var self = this;
self.getStuff = function(aString, callback) {
// TODO
}
}
describe("server communications", function() {
it("it calls the server", function() {
var obj = new TestObj();
obj.getStuff = jasmine.createSpy();
// swap the above line for this and it makes no difference
// spyOn(obj, "getStuff");
var functionVar = function() {
};
obj.getStuff("hello", functionVar);
expect(obj.getStuff).toHaveBeenCalledWith(
[ "hello", jasmine.any(Function) ]);
});
});
我没有通过单元测试,而是得到以下输出:
预期的间谍被召唤: [['hello',< jasmine.any(function Function(){[native code]})> ]] 但被称为: [['你好',功能]]
为什么不能识别我传入的函数(function(){})实际上是函数?是什么原因代码的东西是什么?其他人有jasmine.any(Function)这个问题吗?三江源!
EDITED
我尝试使用spyOn而不是jasmine.createSpy(),它没有任何区别。我只尝试了一个参数并且它有效。引入第一个字符串参数会破坏jasmine.any(Function) - 任何想法?
答案 0 :(得分:34)
啊,我以为你必须将expect().toHaveBeenCalledWith
的论点括在Array[]
中。傻我。这是一个工作版本:
function TestObj() {
var self = this;
self.getStuff = function(aString, callback) {
// TODO
}
}
describe("server communications", function() {
it("it calls the server", function() {
var obj = new TestObj();
obj.getStuff = jasmine.createSpy();
// swap the above line for this and it makes no difference
// spyOn(obj, "getStuff");
var functionVar = function() {
};
obj.getStuff("hello", functionVar);
expect(obj.getStuff).toHaveBeenCalledWith("hello", jasmine.any(Function));
});
});
答案 1 :(得分:7)
问题是你创建间谍的方式,使用spyOn
似乎按预期工作:
describe("test", function() {
return it("is function", function() {
var a = {b: function(){}};
spyOn(a, 'b');
a.b(function(){});
expect(a.b).toHaveBeenCalledWith(jasmine.any(Function));
});
});
您还可以write your own Matcher来测试传递的值是否为函数:
describe('test',function(){
it('is function',function(){
this.addMatchers({
isFunction: function() {
return typeof this.actual === 'function';
}
});
expect(function(){}).isFunction();
});
});
EDITED:编写了第一个代码块