我试图将JSpec Google Group发送的消息显然失败了,我试着在这里发帖。
我遇到了JSpec显然遇到某种测试的无限递归循环(下面)。有任何想法吗?我的代码有问题还是JSpec?我正在通过Ruby Gem运行JSpec 2.11.2。
错误是'RangeError:超出最大调用堆栈大小。' (Safari)和'InternalError:太多的递归'(FF / Mac)。我可以使用Firebug控制台向房间添加一个项目,没有错误。
要重现此问题,请使用“jspec init test”创建模板jspec项目。然后编辑以下文件:
yourlib.core.js
var Game = {};
Game.item = function () {
var result = {
name : 'Undefined',
room : null
}
return result;
};
Game.room = function () {
var result = {
items : [],
addItem : function (name) {
var item = Game.item();
item.name = name;
item.room = this;
this.items.push(item);
return item;
}
};
return result;
};
spec.core.js
describe 'Room'
before_each
room = Game.room()
end
describe 'addItem()'
before_each
potion = room.addItem('Potion')
key = room.addItem('Key')
end
//this is fine
it 'should return two different items'
key.should_not.be potion
end
//InternalError: too much recursion
it 'should not give recursion error'
key.should.be potion
end
end
end
答案 0 :(得分:1)
免责声明:我之前也没有听说过JSpec(虽然Jasmine是一个不错的选择,如果你正在寻找它。
我唯一能想到的是'be'功能是如何工作的。如果它沿着对象图向下移动以找出两个项目是否相等,那么它可能会遇到循环依赖性打嗝:即您在每个项目中引用您的房间,而这些项目又包含您的项目,而这些项目又包含您的房间和等等等等。这最终成为一个无限循环,be函数无法从中有效地返回堆栈,从而抛出你所看到的错误。
这样的东西(没有比较,但是:没有测试或运行此代码,将其作为伪代码来解释上面的段落):
function be(obj) {
for (var key in obj) {
if (typeof(obj[key]) === "object") {
be(obj[key]); // If you have circular dependencies, the recursion never ends
}
}
}