test: add http2 test for method CONNECT
Adds test case for default handling of method CONNECT, as well as the ability to bind a connect listener and handle the request. PR-URL: https://github.com/nodejs/node/pull/15052 Refs: https://github.com/nodejs/node/issues/14985 Reviewed-By: James M Snell <jasnell@gmail.com>
This commit is contained in:
parent
5723c4c5f0
commit
88441f6baf
41
test/parallel/test-http2-compat-method-connect.js
Normal file
41
test/parallel/test-http2-compat-method-connect.js
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
// Flags: --expose-http2
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
const common = require('../common');
|
||||||
|
if (!common.hasCrypto)
|
||||||
|
common.skip('missing crypto');
|
||||||
|
const assert = require('assert');
|
||||||
|
const http2 = require('http2');
|
||||||
|
|
||||||
|
const server = http2.createServer(common.mustNotCall());
|
||||||
|
|
||||||
|
server.listen(0, common.mustCall(() => testMethodConnect(2)));
|
||||||
|
|
||||||
|
server.once('connect', common.mustCall((req, res) => {
|
||||||
|
assert.strictEqual(req.headers[':method'], 'CONNECT');
|
||||||
|
res.statusCode = 405;
|
||||||
|
res.end();
|
||||||
|
}));
|
||||||
|
|
||||||
|
function testMethodConnect(testsToRun) {
|
||||||
|
if (!testsToRun) {
|
||||||
|
return server.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
const port = server.address().port;
|
||||||
|
const client = http2.connect(`http://localhost:${port}`);
|
||||||
|
const req = client.request({
|
||||||
|
':method': 'CONNECT',
|
||||||
|
':authority': `localhost:${port}`
|
||||||
|
});
|
||||||
|
|
||||||
|
req.on('response', common.mustCall((headers) => {
|
||||||
|
assert.strictEqual(headers[':status'], 405);
|
||||||
|
}));
|
||||||
|
req.resume();
|
||||||
|
req.on('end', common.mustCall(() => {
|
||||||
|
client.destroy();
|
||||||
|
testMethodConnect(testsToRun - 1);
|
||||||
|
}));
|
||||||
|
req.end();
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user