Lon*_*ner 3 javascript mocha.js
我试图了解Mocha的异步代码(http://mochajs.org/#getting-started)是如何工作的.
describe('User', function() {
describe('#save()', function() {
it('should save without error', function(done) {
var user = new User('Luna');
user.save(function(err) {
if (err) throw err;
done();
});
});
});
});
Run Code Online (Sandbox Code Playgroud)
我想知道Mocha如何决定测试在幕后是成功还是失败.
从上面的代码我可以理解,user.save()异步会立即返回.所以Mocha在执行之后不会决定测试是成功还是失败it().当user.save()最终done()成功调用时,摩卡会认为这是一次成功的测试.
我无法理解摩卡在上述情况下如何了解测试失败.比方说,user.save()用err参数集调用它的回调,然后回调引发错误.在这种情况下,没有调用Mocha的函数.那么摩卡怎么会知道回调中发生了错误?
Mocha能够检测阻止调用回调或返回promise的失败,因为它用于process.on('uncaughtException', ...);检测未捕获的异常.由于它以串行方式运行所有测试,因此它始终知道未捕获的异常属于哪个测试.(有时人们对此感到困惑:告诉Mocha一个测试是异步的并不意味着Mocha将与其他测试并行运行.它只是告诉Mocha它应该等待回调或承诺.)
除非存在干预异常的内容,否则Mocha将知道测试失败并在检测到错误后立即报告错误.这是一个例子.由于抛出了一般异常,第一次测试失败.由于expect检查失败,第二个失败.它还引发了一个未处理的异常.
var chai = require("chai");
var expect = chai.expect;
it("failing test", function (done) {
setTimeout(function () {
throw new Error("pow!");
done();
}, 1000);
});
it("failing expect", function (done) {
setTimeout(function () {
expect(1).to.equal(2);
done();
}, 1000);
});
Run Code Online (Sandbox Code Playgroud)
这是我的控制台上的输出:
1) failing test
2) failing expect
0 passing (2s)
2 failing
1) failing test:
Uncaught Error: pow!
at null._onTimeout (test.js:6:15)
2) failing expect:
Uncaught AssertionError: expected 1 to equal 2
+ expected - actual
-1
+2
at null._onTimeout (test.js:13:22)
Run Code Online (Sandbox Code Playgroud)
堆栈跟踪指向正确的代码行.如果异常发生得更深,那么堆栈会更充分.
当Mocha无法准确报告出错时,通常是因为有干预代码吞噬了引发的异常.或者当你使用promises时,问题可能是有人忘了调用一个方法来指示是否应该完全处理promise,并且应该抛出未处理的异常.(如何执行此操作取决于您使用的promise实现.)