猫鼬查询/插入无序错误
mongoose query / insert disorder bug?
我正在写一个DB测试(由Mocha运行),在保存文档后调用findOne,发现了一个奇怪的行为:
此处为伪代码:…
test1
A.save(check('A',done));
test2
B.save(check('B',done));
test3
C.save(check('C',done));
...
check = function(name, done) {
theModel.findOne({name:name}, function(err,result) {
assert.notEqual(result,null);
result.remove(done);
});
}
然后,A测试通过了,但B测试没有通过。我查看了日志,发现了一件奇怪的事情:首先,它执行了插入,在查询之后,在移除之后(对于第一个测试,好吧,这是预期的行为)。在第一次测试之后,当我看到查询是在插入之前执行的时,我感到震惊(因此测试失败,没有删除任何内容)。第三个等等的行为是一样的!在插入之前执行查询:(
因此,唯一通过的测试是第一个测试(如果我用B改变A,那么B通过了,A没有通过)。如果我查看mongodb集合,我可以看到在查询之后执行的其他插入(由于断言失败,它们没有被删除)
我使用mongoose 2.7.2(但我使用的是以前的版本,只是更新了一下,看看它是否是一个已解决的bug)。帮助:(
我错了。。。
没有注意到我实际上是在调用save之前调用check的(因为我调用的是save方法内部的函数…我对javascript太愚蠢了,太陌生了)。
好的,所以我应该用另一种方式进行检查:
A.save(function(err, result) { check('A', done);})
我向你道歉!
相关文章:
- Node.js v6.2.0类扩展不是函数错误
- Jquery菜单操作不稳定,定位不正确,存在一般错误
- document.open/document.write没有正确地清除chrome中的文档——这是chrome的错误吗
- 试图在引导模式内动态生成图表,得到offsetWidth错误
- 为什么会出现错误;未捕获的类型错误:undefined不是函数;
- 我如何修复包含在captcha的addthis中的错误
- 同样,同样的错误'ahorcado.js:26未捕获类型错误:无法读取属性'beginPath'
- 节点是否需要模块传递带有方括号的arg?这是个错误吗
- Webpack/Rect:遵循egghead.io教程,但出现错误:您可能需要一个合适的加载程序来处理此文件类型
- CKFinder 3为所选文件返回错误的URL
- 同位素库错误:未捕获错误无布局模式包装生产线8
- 铬:“;未捕获的语法错误:意外的标记:"
- 如何通过自己获得Chrome扩展的用户反馈/错误报告
- 相位器状态未捕获参考错误
- /undefined在我的404错误日志中多次出现
- Javascript未捕获语法错误意外的标识符错误
- javascript:如何在antlr生成的Lexer中进行错误处理
- Angularjs工厂注入错误
- 可以设置“;文件名"发生错误时显示的内联脚本标记的
- 猫鼬查询/插入无序错误