test: add a test for Expect & checkExpectation
New test case for Expect header & checkExpectation event based on the existing http test case. PR-URL: https://github.com/nodejs/node/pull/15040 Refs: https://github.com/nodejs/node/issues/14985 Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Yuta Hiroto <hello@about-hiroppy.com> Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
This commit is contained in:
parent
88441f6baf
commit
6eeb06f234
46
test/parallel/test-http2-compat-expect-handling.js
Normal file
46
test/parallel/test-http2-compat-expect-handling.js
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
// 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 expectValue = 'meoww';
|
||||||
|
|
||||||
|
const server = http2.createServer(common.mustNotCall());
|
||||||
|
|
||||||
|
server.once('checkExpectation', common.mustCall((req, res) => {
|
||||||
|
assert.strictEqual(req.headers['expect'], expectValue);
|
||||||
|
res.statusCode = 417;
|
||||||
|
res.end();
|
||||||
|
}));
|
||||||
|
|
||||||
|
server.listen(0, common.mustCall(() => nextTest(2)));
|
||||||
|
|
||||||
|
function nextTest(testsToRun) {
|
||||||
|
if (!testsToRun) {
|
||||||
|
return server.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
const port = server.address().port;
|
||||||
|
const client = http2.connect(`http://localhost:${port}`);
|
||||||
|
const req = client.request({
|
||||||
|
':path': '/',
|
||||||
|
':method': 'GET',
|
||||||
|
':scheme': 'http',
|
||||||
|
':authority': `localhost:${port}`,
|
||||||
|
expect: expectValue
|
||||||
|
});
|
||||||
|
|
||||||
|
req.on('response', common.mustCall((headers) => {
|
||||||
|
assert.strictEqual(headers[':status'], 417);
|
||||||
|
req.resume();
|
||||||
|
}));
|
||||||
|
|
||||||
|
req.on('end', common.mustCall(() => {
|
||||||
|
client.destroy();
|
||||||
|
nextTest(testsToRun - 1);
|
||||||
|
}));
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user