mirror of
https://github.com/nodejs/node.git
synced 2024-12-01 16:10:02 +01:00
3e25e4d00f
Support generic `Duplex` streams through more duck typing on the server and client sides. Since HTTP is, as a protocol, independent of its underlying transport layer, Node.js should not enforce any restrictions on what streams its HTTP parser may use. Ref: https://github.com/nodejs/node/issues/16256 PR-URL: https://github.com/nodejs/node/pull/16267 Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Matteo Collina <matteo.collina@gmail.com> Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: Anatoli Papirovski <apapirovski@mac.com>
61 lines
1.6 KiB
JavaScript
61 lines
1.6 KiB
JavaScript
'use strict';
|
|
const common = require('../common');
|
|
const assert = require('assert');
|
|
const http = require('http');
|
|
const MakeDuplexPair = require('../common/duplexpair');
|
|
|
|
// Test 1: Simple HTTP test, no keep-alive.
|
|
{
|
|
const testData = 'Hello, World!\n';
|
|
const server = http.createServer(common.mustCall((req, res) => {
|
|
res.statusCode = 200;
|
|
res.setHeader('Content-Type', 'text/plain');
|
|
res.end(testData);
|
|
}));
|
|
|
|
const { clientSide, serverSide } = MakeDuplexPair();
|
|
server.emit('connection', serverSide);
|
|
|
|
const req = http.request({
|
|
createConnection: common.mustCall(() => clientSide)
|
|
}, common.mustCall((res) => {
|
|
res.setEncoding('utf8');
|
|
res.on('data', common.mustCall((data) => {
|
|
assert.strictEqual(data, testData);
|
|
}));
|
|
}));
|
|
req.end();
|
|
}
|
|
|
|
// Test 2: Keep-alive for 2 requests.
|
|
{
|
|
const testData = 'Hello, World!\n';
|
|
const server = http.createServer(common.mustCall((req, res) => {
|
|
res.statusCode = 200;
|
|
res.setHeader('Content-Type', 'text/plain');
|
|
res.end(testData);
|
|
}, 2));
|
|
|
|
const { clientSide, serverSide } = MakeDuplexPair();
|
|
server.emit('connection', serverSide);
|
|
|
|
function doRequest(cb) {
|
|
const req = http.request({
|
|
createConnection: common.mustCall(() => clientSide),
|
|
headers: { Connection: 'keep-alive' }
|
|
}, common.mustCall((res) => {
|
|
res.setEncoding('utf8');
|
|
res.on('data', common.mustCall((data) => {
|
|
assert.strictEqual(data, testData);
|
|
}));
|
|
res.on('end', common.mustCall(cb));
|
|
}));
|
|
req.shouldKeepAlive = true;
|
|
req.end();
|
|
}
|
|
|
|
doRequest(() => {
|
|
doRequest();
|
|
});
|
|
}
|