Mocha不会在after()函数中调用rmdir

时间:2013-02-26 01:59:22

标签: javascript testing bdd mocha rmdir

我尝试在测试之前创建一些目录树,然后删除它:

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的顺序没问题:

mocha `find tests -name '*.js'`

  before
after_before
․after
after_end


  ✔ 1 test complete (6 ms)

但它不会调用rmdir()。相同的rmdir在before()

结束时有效
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()

1 个答案:

答案 0 :(得分:6)

测试结束得太快了。您需要使用after的异步版本。

after(function(done) {
    console.log("after");
    rmdir('tmp', function() {
        console.log("rmdir!");
        done();
    });
    console.log("after_end");
});

应该输出:

 after
 after_end
 rmdir!

当你从before()调用它时它似乎工作的原因是因为还有很多其他事情发生,所以rmdir会被调用,但稍后当节点返回到事件循环时。