2010-12-05 07:20:34 +08:00
|
|
|
var common = require('../common');
|
|
|
|
var assert = require('assert');
|
|
|
|
var http = require('http');
|
|
|
|
var net = require('net');
|
2010-09-09 14:29:35 +08:00
|
|
|
|
2010-12-05 07:20:34 +08:00
|
|
|
var outstanding_reqs = 0;
|
2010-09-09 14:29:35 +08:00
|
|
|
|
|
|
|
var server = http.createServer(function(req, res) {
|
2010-12-06 06:33:52 +08:00
|
|
|
res.writeHead(200, [['content-type', 'text/plain']]);
|
|
|
|
res.addTrailers({'x-foo': 'bar'});
|
|
|
|
res.end('stuff' + '\n');
|
2010-09-09 14:29:35 +08:00
|
|
|
});
|
|
|
|
server.listen(common.PORT);
|
|
|
|
|
|
|
|
|
|
|
|
// first, we test an HTTP/1.0 request.
|
2010-12-06 06:33:52 +08:00
|
|
|
server.addListener('listening', function() {
|
2010-09-09 14:29:35 +08:00
|
|
|
var c = net.createConnection(common.PORT);
|
2010-12-06 06:33:52 +08:00
|
|
|
var res_buffer = '';
|
2010-09-09 14:29:35 +08:00
|
|
|
|
2010-12-06 06:33:52 +08:00
|
|
|
c.setEncoding('utf8');
|
2010-09-09 14:29:35 +08:00
|
|
|
|
2010-12-06 06:33:52 +08:00
|
|
|
c.addListener('connect', function() {
|
2010-09-09 14:29:35 +08:00
|
|
|
outstanding_reqs++;
|
2010-12-06 06:33:52 +08:00
|
|
|
c.write('GET / HTTP/1.0\r\n\r\n');
|
2010-09-09 14:29:35 +08:00
|
|
|
});
|
|
|
|
|
2010-12-06 06:33:52 +08:00
|
|
|
c.addListener('data', function(chunk) {
|
|
|
|
//console.log(chunk);
|
2010-09-09 14:29:35 +08:00
|
|
|
res_buffer += chunk;
|
|
|
|
});
|
|
|
|
|
2010-12-06 06:33:52 +08:00
|
|
|
c.addListener('end', function() {
|
2010-09-09 14:29:35 +08:00
|
|
|
c.end();
|
2010-12-06 06:33:52 +08:00
|
|
|
assert.ok(! /x-foo/.test(res_buffer), 'Trailer in HTTP/1.0 response.');
|
2010-09-09 14:29:35 +08:00
|
|
|
outstanding_reqs--;
|
|
|
|
if (outstanding_reqs == 0) {
|
2010-12-06 06:33:52 +08:00
|
|
|
server.close();
|
|
|
|
process.exit();
|
2010-09-09 14:29:35 +08:00
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
// now, we test an HTTP/1.1 request.
|
2010-12-06 06:33:52 +08:00
|
|
|
server.addListener('listening', function() {
|
2010-09-09 14:29:35 +08:00
|
|
|
var c = net.createConnection(common.PORT);
|
2010-12-06 06:33:52 +08:00
|
|
|
var res_buffer = '';
|
2010-09-09 14:29:35 +08:00
|
|
|
var tid;
|
|
|
|
|
2010-12-06 06:33:52 +08:00
|
|
|
c.setEncoding('utf8');
|
2010-09-09 14:29:35 +08:00
|
|
|
|
2010-12-06 06:33:52 +08:00
|
|
|
c.addListener('connect', function() {
|
2010-09-09 14:29:35 +08:00
|
|
|
outstanding_reqs++;
|
2010-12-06 06:33:52 +08:00
|
|
|
c.write('GET / HTTP/1.1\r\n\r\n');
|
|
|
|
tid = setTimeout(assert.fail, 2000, 'Couldn\'t find last chunk.');
|
2010-09-09 14:29:35 +08:00
|
|
|
});
|
|
|
|
|
2010-12-06 06:33:52 +08:00
|
|
|
c.addListener('data', function(chunk) {
|
|
|
|
//console.log(chunk);
|
2010-09-09 14:29:35 +08:00
|
|
|
res_buffer += chunk;
|
|
|
|
if (/0\r\n/.test(res_buffer)) { // got the end.
|
2010-12-06 06:33:52 +08:00
|
|
|
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();
|
|
|
|
}
|
2010-09-09 14:29:35 +08:00
|
|
|
}
|
|
|
|
});
|
2010-09-29 17:38:48 +08:00
|
|
|
});
|
2010-09-09 14:29:35 +08:00
|
|
|
|
2010-09-29 17:38:48 +08:00
|
|
|
// now, see if the client sees the trailers.
|
|
|
|
server.addListener('listening', function() {
|
|
|
|
var client = http.createClient(common.PORT);
|
2010-12-06 06:33:52 +08:00
|
|
|
var req = client.request('/hello', {});
|
2010-09-29 17:38:48 +08:00
|
|
|
req.end();
|
|
|
|
outstanding_reqs++;
|
2010-12-06 06:33:52 +08:00
|
|
|
req.addListener('response', function(res) {
|
|
|
|
res.addListener('end', function() {
|
|
|
|
//console.log(res.trailers);
|
|
|
|
assert.ok('x-foo' in res.trailers, 'Client doesn\'t see trailers.');
|
2010-09-29 17:38:48 +08:00
|
|
|
outstanding_reqs--;
|
|
|
|
if (outstanding_reqs == 0) {
|
|
|
|
server.close();
|
|
|
|
process.exit();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
2010-09-09 14:29:35 +08:00
|
|
|
});
|