【问题标题】:mocha + webstorm - error message brokenmocha + webstorm - 错误信息损坏
【发布时间】:2012-10-31 05:49:09
【问题描述】:

我尝试在 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 控制台返回:“Process finished with exit code 59”表示“发生了意外的网络错误。”

改成 jasmine-node,它可以工作了。

编辑:

我换成了 jasmine2,在 windows 上也有同样的问题。最简单的解决方法是延迟process.exit,例如延迟 1 毫秒。所以它不能在stdout.write 结束之前退出。 (手动刷新标准输出并仅在此之后调用 exit 也可能是一个可行的解决方案。)

【问题讨论】:

    标签: windows node.js phpstorm mocha.js


    【解决方案1】:

    虽然较大的权力是debating on the hows and the whys to fix this,但较小的凡人可以诉诸此解决方法:

    • 创建一个名为 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');
    
    });
    

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

    【讨论】:

    • @RefaelAckermann:不错!我想它可以被调整为一次运行一个文件,因为经常,我不想在调试时等待其他测试完成。
    【解决方案2】:

    【讨论】:

    • 很好,谢谢!知道为什么它在 git bash 中运行良好,为什么在 webstorm 控制台中运行良好?
    • 哈哈我知道了,git bash 是一个仿真的 linux,这是一个 windows 问题。 :P
    • 我在 webstorm 控制台中得到了这个:“进程以退出代码 59 完成”,这意味着:“59 发生了意外的网络错误。”
    • 根据链接,它将在 Node.js v0.11.12 中修复。在那之前你唯一能做的就是只发送一次报告,所以它可能会到达。
    • 我只是确认:node.exe 0.12.2 x64 没有更多错误输出问题
    【解决方案3】:

    即使在实施了 Mrchief 的回答之后,我仍然会在输出中收到混乱的报告。我最终在终端窗口中运行测试。作为参考;

    确保 mocha 已全局安装。

    npm install -g mocha
    

    打开终端窗口(Alt-Minus)并切换到测试脚本所在的目录

    运行摩卡

    mocha -R 规范 *.js

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2015-07-19
      • 1970-01-01
      相关资源
      最近更新 更多