我在玩誓言和nodejs。
var vows = require('vows');
var http = require('http');
var suite = vows.describe('testing');
var host = 'www.google.com', port = '80', path = '/', method = 'GET';
suite.addBatch({
'A context': {
topic: function(){
http.get({
host: host,
port: port,
path: path,
method: method
}, this.callback);
},
"sample test": function(res, extra){//here extra is just to prevent vows error
res.on('data', function (chunk) {
console.log('BODY: ' + chunk);//It never gets logged
});
console.log('HEADERS: ' + JSON.stringify(res.headers));//it is working
}
}
});
suite.export(module);
但是我无法获得回应。我究竟做错了什么。
我正在使用nodejs v 0.6.6和vows v0.6.2
最佳答案
据我所知,当this.callback
运行时,Vows似乎并没有直接调用测试。它被processnextTick
延迟。如果我不得不猜测,那段时间可能是在发出“数据”事件。这意味着,直到所有数据事件被触发后,您才可以绑定“数据”功能。
确实,问题在于,Vows测试应该将所有这样的异步逻辑分离为topic
本身。如果您真的想检查测试中的数据块,则可以这样做。
还要注意,您可以有任意数量的块,不仅有一个data
事件。您可能需要设置流编码,并将数据作为字符串连接。您当前的代码将Buffer隐式转换为字符串,这可能会破坏多字节字符。
suite.addBatch({
'A context': {
topic: function(){
var cb = this.callback;
var req = http.get({
host: host,
port: port,
path: path,
method: method
});
// Aggregate all chunks before running callback
req.on('response', function(res) {
var chunks = []
res.on('data', function(chunk) {
chunks.push(chunk);
});
res.on('end', function() {
cb(null, res, chunks);
});
});
// Handle connection failures.
req.on('error', cb);
},
"sample test": function(err, res, chunks){
chunks.forEach(function (chunk, i) {
console.log('BODY piece ' + i + ': ' + chunk);
});
console.log('HEADERS: ' + JSON.stringify(res.headers));
}
}
});