Browse Source

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>
canary-base
Anatoli Papirovski 7 years ago
committed by Ruben Bridgewater
parent
commit
6eeb06f234
No known key found for this signature in database GPG Key ID: F07496B3EB3C1762
  1. 46
      test/parallel/test-http2-compat-expect-handling.js

46
test/parallel/test-http2-compat-expect-handling.js

@ -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…
Cancel
Save