在node-inspector中运行supertest时,无法读取null的属性'_host'

时间:2015-07-09 00:03:01

标签: node.js debugging gruntjs mocha angular-fullstack

我是Angular世界的新手,并且一直在使用angular-fullstack生成器+ Yeoman来构建一个项目。我正在使用Sublime(不是Webstorm),并且一直在试图弄清楚如何设置项目,以便我可以从终端调试mocha测试,但是我正在撞墙。

这是使用'yo angular-fullstack'生成的默认的things.spec.js,其中添加了调试器语句。

var should = require('should');
var app = require('../../app');
var request = require('supertest');

describe('GET /api/things', function() {
   it('should respond with JSON array', function(done) {
       request(app)
          .get('/api/things')
          .expect(200)
          .expect('Content-Type', /json/)
          .end(function(err, res) {
              debugger;
              if (err) return done(err);
              res.body.should.be.instanceof(Array);
              done();
          });
   });
});

通过结合grunt-mocha-test documentation和此SO answer的建议,我更新了package.json中的测试脚本,如下所示:

"scripts": {
    "test": "node-debug <PATH TO GRUNT-CLI>\\grunt test"
}

当我运行'npm test'时,node-inspector成功启动浏览器实例并将调试会话附加到我的测试过程。但是,当我按下“继续”时,调试器断点未被命中,测试失败并显示以下堆栈。任何人都有任何关于导致这种情况的线索?

TypeError: Cannot read property '_host' of null
  at ClientRequest.http.ClientRequest.onSocket (eval at WRAPPED_BY_NODE_INSPECTOR (\node_modules\node-inspector\node_modules\v8-debug\v8-debug.js:95:15), <anonymous>:381:28)
  at new ClientRequest (http.js:1432:10)
  at Object.exports.request (http.js:1843:10)
  at Test.Request.request (\node_modules\supertest\node_modules\superagent\lib\node\index.js:615:28)
  at Test.Request.end (\node_modules\supertest\node_modules\superagent\lib\node\index.js:677:18)
  at Test.end (\node_modules\supertest\lib\test.js:123:7)
  at Context.<anonymous> (\server\api\thing\thing.spec.js:14:8)
  at Test.Runnable.run (\node_modules\grunt-mocha-test\node_modules\mocha\lib\runnable.js:196:15)
  at Runner.runTest (\node_modules\grunt-mocha-test\node_modules\mocha\lib\runner.js:374:10)
  at Runner.runTests.next (\node_modules\grunt-mocha-test\node_modules\mocha\lib\runner.js:452:12)

1 个答案:

答案 0 :(得分:0)

这看起来像Node Inspector中的一个错误。 https://github.com/node-inspector/node-inspector/issues/698