我正在尝试使用 mocha、chai 和 chai-http 进行简单测试。出于测试目的,我使用 Express 4 typescript 模板在 Visual Studio 2019 中创建了一个简单的项目。
此外,我安装了以下软件包:
- 摩卡(+@types/摩卡)
- 柴
- 柴http
- @types/superagent(这解决了一些缺失的名字)
然后我更改了项目选项以使用 mocha 测试框架并指向正确的测试文件夹。
然后我创建了一个打字稿 mocha 单元测试文件并将其内容更改为以下内容(未更改的测试文件按预期工作):
import server from "../app";
import chai = require('chai');
import chaiHttp = require("chai-http");
chai.use(chaiHttp);
describe("Test Suite 1", () => {
it("Test A", (done) => {
chai.request(server)
.get("/")
.end((err, res) => {
done();
});
});
it("Test B", (done) => {
done();
});
});
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() 时,第二个测试通过了。
另一个奇怪的事情是,当我使用调试运行这些测试时,我没有得到任何关于使用 chai.request() 调用的测试的进一步信息,即测试 A。当我使用调试运行测试 B 时,它通过了,但是当我运行时它通常会失败,但会运行两次,一次尝试通过,一次失败。通过尝试需要 4ms 失败尝试 <1ms。
我还尝试了很多我在 google/stackoverflow 上找到的东西,但我不记得了,因为我已经尝试让它工作了很长一段时间。不过,大多数这些事情一开始就是让它运行起来的。