Express 使用chai.request会导致所有测试失败

Express 使用chai.request会导致所有测试失败,express,unit-testing,mocha.js,chai,chai-http,Express,Unit Testing,Mocha.js,Chai,Chai Http,我正在尝试使用mocha、chai和chai http进行一个简单的测试。出于测试目的,我在VisualStudio2019中使用Express4TypeScript模板创建了一个简单的项目 此外,我还安装了以下软件包: 摩卡(+@types/mocha) 柴 柴http @类型/超级代理(这解决了一些缺少的名称) 然后,我更改了项目选项以使用mocha测试框架,并指向正确的测试文件夹 然后,我创建了一个typescript mocha单元测试文件,并将其内容更改为以下内容(未更改的测试文件

我正在尝试使用mocha、chai和chai http进行一个简单的测试。出于测试目的,我在VisualStudio2019中使用Express4TypeScript模板创建了一个简单的项目

此外,我还安装了以下软件包:

  • 摩卡(+@types/mocha)
  • 柴http
  • @类型/超级代理(这解决了一些缺少的名称)
然后,我更改了项目选项以使用mocha测试框架,并指向正确的测试文件夹

然后,我创建了一个typescript mocha单元测试文件,并将其内容更改为以下内容(未更改的测试文件按预期工作):

app.ts文件如下所示:

import debug = require('debug');
import express = require('express');
import path = require('path');

import routes from './routes/index';
import users from './routes/user';

const app = express();

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

app.use(express.static(path.join(__dirname, 'public')));

app.use('/', routes);
app.use('/users', users);

// catch 404 and forward to error handler
app.use((req, res, next) => {
    const 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((err, req, res, next) => { // eslint-disable-line @typescript-eslint/no-unused-vars
        res.status(err['status'] || 500);
        res.render('error', {
            message: err.message,
            error: err
        });
    });
}

// production error handler
// no stacktraces leaked to user
app.use((err, req, res, next) => { // eslint-disable-line @typescript-eslint/no-unused-vars
    res.status(err.status || 500);
    res.render('error', {
        message: err.message,
        error: {}
    });
});

app.set('port', process.env.PORT || 3000);

const server = app.listen(app.get('port'), function () {
    debug('Express server listening on port ' + server.address().port);
});

export default server;
我只添加了最后一行“导出默认服务器

当我现在运行测试时,所有测试都会失败,即使测试B应该通过。当我删除对chai.request()的调用时,测试按预期通过。另外,当我将字符串传递给chai.request()时,第二个测试通过

另一件奇怪的事情是,当我使用debug运行这些测试时,我没有得到任何关于使用chai.request()调用的测试的进一步信息,即测试A。当我使用debug运行测试B时,它通过了,但当我正常运行它时,它失败了,但在一次尝试通过,一次失败的情况下,它会运行两次。通过的尝试比失败的尝试花费4ms
import debug = require('debug');
import express = require('express');
import path = require('path');

import routes from './routes/index';
import users from './routes/user';

const app = express();

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

app.use(express.static(path.join(__dirname, 'public')));

app.use('/', routes);
app.use('/users', users);

// catch 404 and forward to error handler
app.use((req, res, next) => {
    const 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((err, req, res, next) => { // eslint-disable-line @typescript-eslint/no-unused-vars
        res.status(err['status'] || 500);
        res.render('error', {
            message: err.message,
            error: err
        });
    });
}

// production error handler
// no stacktraces leaked to user
app.use((err, req, res, next) => { // eslint-disable-line @typescript-eslint/no-unused-vars
    res.status(err.status || 500);
    res.render('error', {
        message: err.message,
        error: {}
    });
});

app.set('port', process.env.PORT || 3000);

const server = app.listen(app.get('port'), function () {
    debug('Express server listening on port ' + server.address().port);
});

export default server;