【发布时间】:2017-07-12 22:07:18
【问题描述】:
我正在通过 mocha chai-http 在 Node.js 中测试服务器响应。 我得到的响应总是空的。但是,当我在没有 mocha 测试运行器的情况下定期运行请求时,一切都很好。
这是服务器代码:
var Babble = { messages: new Array() , users: new Array(),userCount:0 }; //
var http = require('http');
var urlUtil = require('url');
var queryUtil = require('querystring');
var Babble = { messages: new Array() , users: new Array(),userCount:0 }; // Data object to save all chat logs
var server = http.createServer(function(request, response) {
var strData,name,index;
response.setHeader('Access-Control-Allow-Origin', '*');
if (request.method === 'GET') {
var url = urlUtil.parse(request.url);
var data = queryUtil.parse(url.query);
console.log(data.message);
if (!data.message) {
response.writeHead(400);
}
response.end();
} else if (request.method === 'POST') {
var requestBody = '';
request.on('data', function(chunk) {
requestBody += chunk.toString();
});
request.on('end', function() {
var data = queryUtil.parse(requestBody);
strData = JSON.stringify(data);
// Handle different requests
...
response.end(JSON.stringify(Babble));
}
});
});
module.exports = {server,Babble};
这是 mocha chai-http 测试代码:
var module = require('./testedServer');
var assert = require('assert');
var chai = require('chai')
, chaiHttp = require('chai-http');
chai.use(chaiHttp);
describe('Check receiving data from server:', function() {
beforeEach(function() {
module.server.listen(9099);
});
it('Should receive a non-null object containing the chat logs', function(done) {
chai.request('http://localhost:9099')
.post('/')
.send(
'poll0,0/Annonymous.'
).end(function(res){
console.log(res);
assert.equal(res != null,true,"Error: test has failed - server response is null");
done();
});
});
afterEach(function() {
// runs after each test in this block
module.server.close();
});
});
我认为我的请求是错误的。
【问题讨论】:
-
我认为人们可能已经被“文字墙”关闭了,因此响应时间为 4 小时。但是,在这种情况下,最小示例只是有点长。如果没有完整的示例,就不会发现问题。
标签: javascript node.js mocha.js chai chai-http