node/test/parallel/test-http-set-trailers.js

92 lines
2.1 KiB
JavaScript

var common = require('../common');
var assert = require('assert');
var http = require('http');
var net = require('net');
var outstanding_reqs = 0;
var server = http.createServer(function(req, res) {
res.writeHead(200, [['content-type', 'text/plain']]);
res.addTrailers({'x-foo': 'bar'});
res.end('stuff' + '\n');
});
server.listen(common.PORT);
// first, we test an HTTP/1.0 request.
server.on('listening', function() {
var c = net.createConnection(common.PORT);
var res_buffer = '';
c.setEncoding('utf8');
c.on('connect', function() {
outstanding_reqs++;
c.write('GET / HTTP/1.0\r\n\r\n');
});
c.on('data', function(chunk) {
//console.log(chunk);
res_buffer += chunk;
});
c.on('end', function() {
c.end();
assert.ok(! /x-foo/.test(res_buffer), 'Trailer in HTTP/1.0 response.');
outstanding_reqs--;
if (outstanding_reqs == 0) {
server.close();
process.exit();
}
});
});
// now, we test an HTTP/1.1 request.
server.on('listening', function() {
var c = net.createConnection(common.PORT);
var res_buffer = '';
var tid;
c.setEncoding('utf8');
c.on('connect', function() {
outstanding_reqs++;
c.write('GET / HTTP/1.1\r\n\r\n');
tid = setTimeout(assert.fail, 2000, 'Couldn\'t find last chunk.');
});
c.on('data', function(chunk) {
//console.log(chunk);
res_buffer += chunk;
if (/0\r\n/.test(res_buffer)) { // got the end.
outstanding_reqs--;
clearTimeout(tid);
assert.ok(
/0\r\nx-foo: bar\r\n\r\n$/.test(res_buffer),
'No trailer in HTTP/1.1 response.'
);
if (outstanding_reqs == 0) {
server.close();
process.exit();
}
}
});
});
// now, see if the client sees the trailers.
server.on('listening', function() {
http.get({ port: common.PORT, path: '/hello', headers: {} }, function(res) {
res.on('end', function() {
//console.log(res.trailers);
assert.ok('x-foo' in res.trailers, 'Client doesn\'t see trailers.');
outstanding_reqs--;
if (outstanding_reqs == 0) {
server.close();
process.exit();
}
});
res.resume();
});
outstanding_reqs++;
});