mirror of
https://github.com/nodejs/node.git
synced 2024-11-21 21:19:50 +01:00
ed3604cd64
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>
42 lines
1.2 KiB
JavaScript
42 lines
1.2 KiB
JavaScript
'use strict';
|
|
const common = require('../common');
|
|
const assert = require('assert');
|
|
const http = require('http');
|
|
|
|
{
|
|
const server = http.createServer(common.mustNotCall((req, res) => {
|
|
res.writeHead(200);
|
|
res.end();
|
|
}));
|
|
|
|
// From RFC 7230 5.4 https://datatracker.ietf.org/doc/html/rfc7230#section-5.4
|
|
// A server MUST respond with a 400 (Bad Request) status code to any
|
|
// HTTP/1.1 request message that lacks a Host header field
|
|
server.listen(0, common.mustCall(() => {
|
|
http.get({ port: server.address().port, headers: [] }, (res) => {
|
|
assert.strictEqual(res.statusCode, 400);
|
|
assert.strictEqual(res.headers.connection, 'close');
|
|
res.resume().on('end', common.mustCall(() => {
|
|
server.close();
|
|
}));
|
|
});
|
|
}));
|
|
}
|
|
|
|
{
|
|
const server = http.createServer({ requireHostHeader: false }, common.mustCall((req, res) => {
|
|
res.writeHead(200, ['test', '1']);
|
|
res.end();
|
|
}));
|
|
|
|
server.listen(0, common.mustCall(() => {
|
|
http.get({ port: server.address().port, headers: [] }, (res) => {
|
|
assert.strictEqual(res.statusCode, 200);
|
|
assert.strictEqual(res.headers.test, '1');
|
|
res.resume().on('end', common.mustCall(() => {
|
|
server.close();
|
|
}));
|
|
});
|
|
}));
|
|
}
|