node/test/parallel/test-http-connect-req-res.js
Michaël Zasso 2ef9a76ece
http: use objects with null prototype in Agent
Fixes: https://github.com/nodejs/node/issues/36364

PR-URL: https://github.com/nodejs/node/pull/36409
Reviewed-By: Gerhard Stöbich <deb2001-github@yahoo.de>
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
Reviewed-By: Rich Trott <rtrott@gmail.com>
2020-12-13 22:16:18 +01:00

72 lines
2.0 KiB
JavaScript

'use strict';
const common = require('../common');
const assert = require('assert');
const http = require('http');
const server = http.createServer(common.mustNotCall());
server.on('connect', common.mustCall(function(req, socket, firstBodyChunk) {
assert.strictEqual(req.method, 'CONNECT');
assert.strictEqual(req.url, 'example.com:443');
console.error('Server got CONNECT request');
// It is legal for the server to send some data intended for the client
// along with the CONNECT response
socket.write(
'HTTP/1.1 200 Connection established\r\n' +
'Date: Tue, 15 Nov 1994 08:12:31 GMT\r\n' +
'\r\n' +
'Head'
);
let data = firstBodyChunk.toString();
socket.on('data', function(buf) {
data += buf.toString();
});
socket.on('end', function() {
socket.end(data);
});
}));
server.listen(0, common.mustCall(function() {
const req = http.request({
port: this.address().port,
method: 'CONNECT',
path: 'example.com:443'
}, common.mustNotCall());
assert.strictEqual(req.destroyed, false);
req.on('close', common.mustCall(() => {
assert.strictEqual(req.destroyed, true);
}));
req.on('connect', common.mustCall(function(res, socket, firstBodyChunk) {
console.error('Client got CONNECT request');
// Make sure this request got removed from the pool.
const name = `localhost:${server.address().port}`;
assert(!(name in http.globalAgent.sockets));
assert(!(name in http.globalAgent.requests));
// Make sure this socket has detached.
assert(!socket.ondata);
assert(!socket.onend);
assert.strictEqual(socket.listeners('connect').length, 0);
assert.strictEqual(socket.listeners('data').length, 0);
let data = firstBodyChunk.toString();
// Test that the firstBodyChunk was not parsed as HTTP
assert.strictEqual(data, 'Head');
socket.on('data', function(buf) {
data += buf.toString();
});
socket.on('end', function() {
assert.strictEqual(data, 'HeadRequestEnd');
server.close();
});
socket.end('End');
}));
req.end('Request');
}));