我尝试在测试前创建一些目录树,并在测试结束后将其删除:
require('should');
var fs = require('fs');
var rmdir = require('rmdir');
describe('FsWatcher', function() {
before(function(done) {
console.log("before");
fs.mkdir('tmp');
fs.mkdir('tmp/css');
fs.mkdir('tmp/js');
fs.mkdir('tmp/lib');
fs.open('tmp/index.htm', 'w');
// (...)
console.log("after_before");
done();
});
describe('single file', function() {
it('should succed', function(done) {
(1).should.equal(1);
done();
});
});
after(function() {
console.log("after");
rmdir('tmp', function() {
console.log("rmdir!");
});
console.log("after_end");
});
});console.log%s的顺序是OK:
mocha `find tests -name '*.js'`
before
after_before
․after
after_end
✔ 1 test complete (6 ms)但是它不调用rmdir()。当rmdir位于before()的末尾时,相同的rmdir也有效
describe('FsWatcher', function() {
before(function(done) {
console.log("before");
fs.mkdir('tmp');
fs.mkdir('tmp/css');
fs.mkdir('tmp/js');
fs.mkdir('tmp/lib');
fs.open('tmp/index.htm', 'w');
// (...)
console.log("after_before");
rmdir('tmp', function(){
console.log("rmdir!");
});
done();
});
});控制台:
mocha `find tests -name '*.js'`
before
after_before
rmdir!
after
after_end为什么它不能在after()中工作
发布于 2013-02-26 12:01:19
测试结束得太快了。您需要使用after的异步版本。
after(function(done) {
console.log("after");
rmdir('tmp', function() {
console.log("rmdir!");
done();
});
console.log("after_end");
});哪一项应该输出:
after
after_end
rmdir!当你从before()调用它时,它看起来能工作的原因是因为还有很多其他的事情发生,所以rmdir将被调用,但稍后当节点返回到事件循环时。
https://stackoverflow.com/questions/15080068
复制相似问题