【问题标题】:Mocha tests running foreverMocha 测试永远运行
【发布时间】:2017-10-06 21:54:43
【问题描述】:

大家好,感谢关注。

我正在尝试使用 mocha 和 supertest 运行测试,即使一切正常,测试也会永远运行。为了避免这种情况,我在 after() 方法中添加了一个“process.exit(0)”,因此它可以正确构建,但这对于“隔离”来说似乎真的是错误的(此外,它看起来很糟糕:-))

我的 package.json:

{
  "name": "application-name",
  "version": "0.0.1",
  "private": true,
  "scripts": {
    "start": "nodejs ./bin/www",
    "test": "mocha"
  },
  "dependencies": {
    "body-parser": "~1.0.0",
    "cookie-parser": "~1.0.1",
    "debug": "~0.7.4",
    "ejs": "~0.8.5",
    "express": "~4.0.0",
    "is-my-json-valid": "^2.16.1",
    "knex": "^0.13.0",
    "morgan": "~1.0.0",
    "mysql": "^2.14.1",
    "static-favicon": "~1.0.0"
  },
  "devDependencies": {
    "mocha": "^4.0.0",
    "supertest": "^3.0.0",
    "chai": "^4.1.2",
    "util": "^0.10.3"
  }
}

我的测试:

var request = require('supertest');
var util    = require('util');

describe('Endpoints', function () {
  var server;

  beforeEach(function() {
    server = require('../app').listen(3000);
  });

  afterEach(function(done) {
    server.close(done);
  });

  after(function(done){
    process.exit(0); // <-- THIS LOOKS REALLY BAD
  });

  it('Success ', function(done) {
    var deputy = {name:"Meu Nome", uf:"SP", site_id:"1", secondary_site_id:"2"}
    request(server)
      .post('/api/deputy')
      .send(deputy)
      .expect(200, done);
  });

  it('Bad request ', function(done) {
    var deputy = {naonome:"Nao deve funcionar"}
    request(server)
      .post('/api/deputy')
      .send(deputy)
      .expect(400, done);
  });

});

任何想法为什么测试永远不会结束?

谢谢大家

编辑:关注我的 app.js,由 express 生成器生成

var express = require('express');
var path = require('path');
var favicon = require('static-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');

var routes = require('./routes/index');
var deputy = require('./routes/deputy');

var db  = require('./server/db');
var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');

app.use(favicon());
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded());
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

app.use('/', routes);
app.use('/api/deputy', deputy);

/// catch 404 and forwarding to error handler
app.use(function(req, res, next) {
    var err = new Error('Not Found');
    err.status = 404;
    next(err);
});

/// error handlers

// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
    app.use(function(err, req, res, next) {
        res.status(err.status || 500);
        res.render('error', {
            message: err.message,
            error: err
        });
    });
}

// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
    res.status(err.status || 500);
    res.render('error', {
        message: err.message,
        error: {}
    });
});


module.exports = app;

【问题讨论】:

  • 显示app.js模块的代码。
  • 完成,添加到问题中

标签: node.js mocha.js supertest


【解决方案1】:

--exit 传递给mocha 进程。

mocha --exit

在 4.0.0 版本中,Mocha 将默认行为从测试完成后退出更改为不退出。从那时起,如果您希望 mocha 在运行测试时停止,则必须添加 --exit 标志。

https://github.com/mochajs/mocha/blob/d69bf14a860235e7ceb50a50c2072dddd1ef8520/CHANGELOG.md#400--2017-10-02

请注意,如果没有退出标志,一些持续集成系统可能会永远运行;如果您为 CI 分钟数付费,这可能是不可取的。

【讨论】:

  • 感谢您的回答!我建议对 为什么 给出一个简单的解释,这可以解决问题,以及 OP 对他的代码做错了什么。一两句话通常就足够了。
【解决方案2】:

听起来数据库连接仍在运行。你可以用

关闭它
connection.end(function(err) {
  // The connection is terminated now
});

我假设您可以从 /server/db 文件获取连接。如果您还没有这样做,请导出它。

我自己不使用 mysql,但这是我使用 MongoDB 时的 after 函数:

after(function (done) {
    server.close(function () {
      mongoose.connection.close(done)
    })
})

如果我不关闭数据库连接,测试将一直运行到最后,但永远不会完成并退出到 shell。

【讨论】:

  • 你是对的。我使用的是 knex 而不是猫鼬,所以在“之后”位中,它是 knex.destroy(),而不是 mongoose.connection.close()。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2020-08-26
  • 1970-01-01
  • 1970-01-01
  • 2015-12-27
  • 1970-01-01
相关资源
最近更新 更多