我在玩誓言和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));
        }
    }
});

10-08 09:33