node/test/parallel/test-http-pipeline-requests-connection-leak.js
wwwzbwcom ed3604cd64 http: server check Host header, to meet RFC 7230 5.4 requirement
PR-URL: https://github.com/nodejs/node/pull/45597
Fixes: https://github.com/nodejs/node/issues/39033
Co-authored-by: Luigi Pinca <luigipinca@gmail.com>
Co-authored-by: mscdex <mscdex@users.noreply.github.com>
Reviewed-By: Robert Nagy <ronagy@icloud.com>
Reviewed-By: Paolo Insogna <paolo@cowtech.it>
Reviewed-By: Yagiz Nizipli <yagiz@nizipli.com>
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
2022-11-28 18:35:31 +01:00

35 lines
792 B
JavaScript

'use strict';
require('../common');
const Countdown = require('../common/countdown');
// This test ensures Node.js doesn't behave erratically when receiving pipelined
// requests
// https://github.com/nodejs/node/issues/3332
const http = require('http');
const net = require('net');
const big = Buffer.alloc(16 * 1024, 'A');
const COUNT = 1e4;
const countdown = new Countdown(COUNT, () => {
server.close();
client.end();
});
let client;
const server = http
.createServer(function(req, res) {
res.end(big, function() {
countdown.dec();
});
})
.listen(0, function() {
const req = 'GET / HTTP/1.1\r\nHost: example.com\r\n\r\n'.repeat(COUNT);
client = net.connect(this.address().port, function() {
client.write(req);
});
client.resume();
});