mocha + webstorm - 错误信息已损坏

inf*_*rno 1 windows mocha.js node.js phpstorm

我尝试在win 7上使用mocha和webstorm test runner.

我有这些配置参数:

我在webstorm控制台中收到以下错误消息

? 1 of 1 test failed:
Run Code Online (Sandbox Code Playgroud)

但没有关于哪个测试失败.:S

怎么解决?

(在git bash中我得到了一条详细的错误信息,所以mocha安装得很好)

与不同的记者共同尝试,但他们似乎都没有工作.我认为问题在于Error对象.其他一切都很好.

写了一个自定义记者,发现堆栈是否出现在webstorm控制台上是完全随机的.最好的选择是使用process.stderr.write打印它,使用console.log或process.stdout.write不显示任何内容.我不知道为什么会这样.也许这是某种类型的超时,但我将超时设置为9999999.:S:S:S嗯也许webstorm运行器有超时,这取决于它,而不是mocha超时设置......

经过本报记者的测试:

exports = module.exports = WebStorm;

/**
 * Initialize a new `WebStorm` test reporter.
 *
 * @param {Runner} runner
 * @api public
 */

 //decribe -> suite
 //it -> test

function WebStorm(runner) {
  var buffer = [];
  var suites = [];
  var fails = [];

  runner.on("suite", function(suite){
     suites.push(suite.title || "''");
  });

  runner.on("suite end", function(suite){
     if (fails.length > 0)
         buffer.push("describe "+suites.join(".")+"\n"+fails.join("\n"));
     fails = [];
     suites.pop();
  });

  runner.on("fail", function(test, err){
      fails.push("  it fail "+test.fullTitle() + err.message);
  });

  runner.on("end", function (){
      process.stderr.write(buffer.length+"\n");
      //process.stderr.write(buffer.join("\n"));
  });
}
Run Code Online (Sandbox Code Playgroud)

我发现输出文本的长度并不重要,只需要在显示它之前等待多长时间.所以我仍然认为这是一个超时问题,而不是一个stdout错误.webstorm控制台返回:"进程已完成,退出代码为59",表示"发生了意外的网络错误".

改为jasmine-node,它正在运行.

编辑:

我改为jasmine2,它在Windows上有同样的问题.最简单的解决方法是延迟process.exit1ms.所以它不能在结束之前退出stdout.write.(手动刷新stdout并在此之后调用exit也可能是一个有效的解决方案.)

Mrc*_*ief 5

虽然更大的权力正在讨论如何解决这个问题,但是较小的凡人可以采用这种解决方法:

  • 创建一个名为testRunner.js(或其他)的文件
  • 添加以下代码行
  • 修改每个项目的测试文件列表
  • 在webstorm中,运行testRunner.js以运行测试

testRunner.js

var testFiles=["test/_helper.js","test/tests.js","test/tests.coffee"];

var Mocha = require('mocha');

var mocha = new Mocha;

mocha.reporter('spec').ui('bdd');

for (var i =0;i<testFiles.length;i++){
 mocha.addFile(testFiles[i]);
}

var runner = mocha.run(function(){
                console.log('finished');

});
Run Code Online (Sandbox Code Playgroud)

礼貌:http://wuntusk.blogspot.com/2012/06/using-webstorm-or-phpstorm-and-mocha.html

  • 更灵活的包装器:https://gist.github.com/refack/6864261 (2认同)