即使在我的Express应用程序上运行server.close()之后,玩笑测试也会挂起

时间:2018-08-14 22:22:48

标签: node.js express jestjs

我有一个Express应用,需要从我的集成测试用例开始。

快速应用程序导出到app.js文件中,不监听任何端口。所以,我的测试用例是这样的:

const app = require('../src/app');

describe('Pact Verification', () => {
  const port = 3002;
  let server;

  beforeAll(done => {
    const server = http.createServer(app);
    server.listen({ port }, done)
  });

  afterAll(done => {
    server.close(done);
  });

  it(....

问题是,一旦使用Jest运行了测试,它就会挂起。我必须退出--forceExit^C

我什至更新到Jest 23以使用--detectOpenHandles,但终端中没有看到任何输出,它一直挂着,所以也无济于事。

由于导出的app 没有监听任何端口,并且没有任何数据库连接或此类连接,因此问题不太可能是在那里,也许是在我的beforeAll / afterAll块中。我想念什么?

更新1

这是我的app.js

的内容
var express = require('express');
var path = require('path');
var logger = require('morgan');

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

var app = express();

if (process.env.NODE_ENV !== 'test') {
  app.use(logger('dev'));
}
app.use(express.json());

app.use('/api/v1/', indexRouter); // <-- these endpoints just return faker data in JSON format (https://github.com/marak/Faker.js/)

app.use((req, res, next) => {
  const err = Error('Not Found');
  err.status = 404;
  next(err);
});

app.use((err, req, res, next) => {
  const { status, message } = err;

  const stack = status !== 404 && err.stack || undefined;

  res.status(status || 500)
    .json({
      message,
      stack,
    });
});

module.exports = app;

1 个答案:

答案 0 :(得分:3)

问题在于serverundefined中是afterAll,因为它在另一个作用域中被分配为const server = http.createServer(app)。相反,它应该是:

server = http.createServer(app);

应该有一个例外,因此done永远不会在afterAll中被调用。当前,Jest抑制来自afterAll的错误,有一个Jest open issue解决了afterAll错误。