node.js - Chai & Mocha:测试阻止快递服务器监听
问题描述
我使用 chai 编写了测试。这里只是三个示例测试:
(实际上还有更多的测试,请查看repl链接)
文件:tests/2_functional-tests.js
const chaiHttp = require('chai-http');
const chai = require('chai');
const assert = chai.assert;
const app = require('../app');
chai.use(chaiHttp);
const request = chai.request;
let id1;
let id2;
suite('Functional Tests', function() {
test("Create an issue with every field: POST request to /api/issues/{project}", async () => {
const res = await request(app)
.post("/api/issues/testproject")
.set('content-type', 'application/x-www-form-urlencoded')
.send({
issue_title: "Test issue",
issue_text: "Test issue text",
created_by: "Chai func test nr 1",
assigned_to: "nobody :P",
status_text: "didn't even start"
});
assert.equal(res.status, 200);
let responseObj = JSON.parse(res.res.text);
assert.equal(responseObj.issue_title, "Test issue");
assert.equal(responseObj.issue_text, "Test issue text");
assert.equal(responseObj.created_by, "Chai func test nr 1");
assert.equal(responseObj.assigned_to, "nobody :P");
assert.equal(responseObj.status_text, "didn't even start");
assert.isTrue(responseObj.open);
id1 = responseObj._id;
});
test("Create an issue with missing required fields: POST request to /api/issues/{project}", async () => {
const res = await request(app)
.post("/api/issues/testproject")
.set('content-type', 'application/x-www-form-urlencoded')
.send({
issue_title: "Test issue 3", //no issue_text
created_by: "Chai func test nr 3"
});
assert.equal(res.status, 200);
let responseObj = JSON.parse(res.res.text);
assert.equal(responseObj.error, "required field(s) missing")
});
test("View issues on a project with multiple filters: GET request to /api/issues/{project}", async () => {
const res = await request(app)
.get("/api/issues/testproject?open=true&created_by=Chai+func+test+nr+1")
assert.equal(res.status, 200);
let responseObj = JSON.parse(res.res.text);
assert.equal(responseObj.length, 1);
assert.equal(responseObj[0].issue_text, "Test issue text");
assert.equal(responseObj[0].status_text, "didn't even start");
assert.equal(responseObj[0].created_by, "Chai func test nr 1");
assert.equal(responseObj[0].open, true);
});
});
这些测试都按预期工作。我没有收到任何错误。尽管如此,这些测试阻止我的快递服务器收听。
在这里我正在听,然后启动测试运行器:(在server.js
文件中)
const listener = app.listen(process.env.PORT || 3000, function () {
console.log('Your app is listening on port ' + listener.address().port);
if (process.env.NODE_ENV === 'test') {
console.log('Running Tests...');
setTimeout(function () {
try {
runner.run();
} catch (e) {
console.log('Tests are not valid:');
console.error(e);
}
}, 5000);
}
});
当我启动服务器时,它会侦听并且所有路由都可用。但是,在测试运行程序启动后,服务器停止侦听并且路由停止工作。但有趣的是,如果我删除测试并只运行空套件,如下所示:
const chaiHttp = require('chai-http');
const chai = require('chai');
const assert = chai.assert;
const app = require('../app');
chai.use(chaiHttp);
const request = chai.request;
let id1;
let id2;
suite('Functional Tests', function() {
});
...一切正常,服务器一直在监听。
runner.run
是test-runner.js
文件中的函数emitter.run
。
const analyser = require('./assertion-analyser');
const EventEmitter = require('events').EventEmitter;
const Mocha = require('mocha'),
fs = require('fs'),
path = require('path');
const mocha = new Mocha();
let testDir = './tests'
// Add each .js file to the mocha instance
fs.readdirSync(testDir).filter(function(file){
// Only keep the .js files
return file.substr(-3) === '.js';
}).forEach(function(file){
mocha.addFile(
path.join(testDir, file)
);
});
let emitter = new EventEmitter();
emitter.run = function() {
let tests = [];
let context = "";
let separator = ' -> ';
// Run the tests.
try {
let runner = mocha.ui('tdd').run()
.on('test end', function(test) {
// remove comments
let body = test.body.replace(/\/\/.*\n|\/\*.*\*\//g, '');
// collapse spaces
body = body.replace(/\s+/g,' ');
let obj = {
title: test.title,
context: context.slice(0, -separator.length),
state: test.state,
// body: body,
assertions: analyser(body)
};
tests.push(obj);
})
.on('end', function() {
emitter.report = tests;
emitter.emit('done', tests)
})
.on('suite', function(s) {
context += (s.title + separator);
})
.on('suite end', function(s) {
context = context.slice(0, -(s.title.length + separator.length))
})
} catch(e) {
throw(e);
}
};
module.exports = emitter;
这是 freecodecamp.org 课程的一个项目,并且test-runner.js
只是从入门项目开始,所以我没有接触它,我认为它没有任何问题。
可能是什么问题呢?会不会是代码结构有严重问题?
这是 replit 上项目的链接 - 随意分叉
- 测试前:
- 测试后:
解决方案
看起来这是一个replit问题,如果我下载文件并在本地运行服务器,一切都会无缝运行。
对于 replit 免费层服务器来说,这些测试可能太难处理了。但如果我等待(5-10 分钟),服务器将再次开始监听。
不幸的是,我对问题中的链接进行了一些编辑,因此您现在可能无法重现该错误。(这些编辑以某种方式大大减少了等待时间)
然而,这里是一个旧版本的项目,它仍然有错误,但它有不同的结构。以防万一有人想看看。
推荐阅读
- javascript - 在 Vue.js 中使用反向地理编码
- ios - 如何将 Linphone SDK 与现有的 Swift 项目集成?
- python - Scikit 图像 otsu 阈值处理产生零阈值
- html - 使用 tel 协议调用微软团队
- pyspark - 计算文档相关性的余弦相似度
- python - 无法从 Python 导入模块
- android - wasabeef 的 Blurry 库不影响 TextView
- c# - iOS 13:Flurry Unity SDK 启动时应用程序崩溃
- azure-functions - 在逻辑应用中将多个相同结构的 XML 文件合并为单个 xml
- arrays - 获取数组AngularJS中的最后一项