Skip to content

Commit

Permalink
http: add regression test for smuggling content length
Browse files Browse the repository at this point in the history
PR-URL: nodejs-private/node-private#285
Reviewed-By: Beth Griggs <bgriggs@redhat.com>
  • Loading branch information
mcollina authored and BethGriggs committed Oct 11, 2021
1 parent f467539 commit 9b92ae2
Showing 1 changed file with 31 additions and 0 deletions.
31 changes: 31 additions & 0 deletions test/parallel/test-http-request-smuggling-content-length.js
@@ -0,0 +1,31 @@
'use strict';

const common = require('../common');
const http = require('http');
const net = require('net');
const assert = require('assert');

// Verify that a request with a space before the content length will result
// in a 400 Bad Request.

const server = http.createServer(common.mustNotCall());

server.listen(0, common.mustCall(start));

function start() {
const sock = net.connect(server.address().port);

sock.write('GET / HTTP/1.1\r\nHost: localhost:5000\r\n' +
'Content-Length : 5\r\n\r\nhello');

let body = '';
sock.setEncoding('utf8');
sock.on('data', (chunk) => {
body += chunk;
});
sock.on('end', common.mustCall(function() {
assert.strictEqual(body, 'HTTP/1.1 400 Bad Request\r\n' +
'Connection: close\r\n\r\n');
server.close();
}));
}

0 comments on commit 9b92ae2

Please sign in to comment.