Express 使用chai.request会导致所有测试失败
我正在尝试使用mocha、chai和chai http进行一个简单的测试。出于测试目的,我在VisualStudio2019中使用Express4TypeScript模板创建了一个简单的项目 此外,我还安装了以下软件包: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单元测试文件,并将其内容更改为以下内容(未更改的测试文件
- 摩卡(+@types/mocha)
- 柴
- 柴http
- @类型/超级代理(这解决了一些缺少的名称)
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;