我尝试在 win 7 上将 mocha 与 webstorm 测试运行器一起使用。
我有这些配置参数:
节点路径:
C:\Program Files (x86)\nodejs\node.exe
工作目录:
D:\creation\software developer\projects\dev\document root\
节点应用 js 文件的路径:
C:\Users\inf3rno\node_modules\mocha\bin\_mocha
应用参数:
test
我在 webstorm 控制台中收到以下错误消息
✖ 1 of 1 test failed:
但没有关于哪个测试失败的信息。:S
如何解决?
(在 git bash 中我得到了详细的错误信息,所以 mocha 安装得很好)
尝试了不同的记者,但他们似乎都没有工作。问题出在我认为的错误对象上。其他一切都显示得很好。
编写了一个自定义报告器,发现堆栈是否显示在 webstorm 控制台上是完全随机的。最好的选择是使用 process.stderr.write 打印它,使用 console.log 或 process.stdout.write 什么都不会出现。我不知道为什么会这样。也许是某种超时,但我将超时设置为 9999999。:S :S :S 嗯,也许 webstorm runner 有超时,这取决于那个,而不是 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"));
});
}
我发现输出文本有多长并不重要,只是在显示它之前必须等待多长时间。所以我仍然认为这是一个超时问题,而不是标准输出错误。webstorm 控制台返回:“进程以退出代码 59 完成”,这意味着“发生了意外的网络错误”。
更改为 jasmine-node,它正在工作。
编辑:
我改成 jasmine2,在 windows 上也有同样的问题。最简单的解决方法是推迟process.exit
例如 1 毫秒。所以它不能在stdout.write
. (手动刷新标准输出并仅在此之后调用 exit 也可能是一个可行的解决方案。)