2

我尝试在测试之前创建一些目录树并将其删除:

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");
  });
});

s的顺序console.log没问题:

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()

4

1 回答 1

7

测试完成太快。您需要使用 after 的异步版本。

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

哪个应该输出:

 after
 after_end
 rmdir!

当您从 调用它时它似乎工作的原因before()是因为发生了很多其他事情,所以 rmdir 将被调用,但稍后当 node 回到事件循环时。

于 2013-02-26T04:01:18.827 回答