mirror of
https://github.com/nodejs/node.git
synced 2024-12-01 16:10:02 +01:00
c1278e5329
This refactors a couple tests to have upper case first characters in comments and to use `input` instead of `i`. It also adds a few TODOs and rewrites a few lines to use default arguments and to prevent function recreation when unnecessary. PR-URL: https://github.com/nodejs/node/pull/19445 Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Matteo Collina <matteo.collina@gmail.com> Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com> Reviewed-By: Anna Henningsen <anna@addaleax.net>
136 lines
3.6 KiB
JavaScript
136 lines
3.6 KiB
JavaScript
'use strict';
|
|
|
|
const common = require('../common');
|
|
if (!common.hasCrypto)
|
|
common.skip('missing crypto');
|
|
|
|
const async_hooks = require('async_hooks');
|
|
const assert = require('assert');
|
|
const http2 = require('http2');
|
|
|
|
const pings = new Set();
|
|
const events = [0, 0, 0, 0];
|
|
|
|
const hook = async_hooks.createHook({
|
|
init(id, type, trigger, resource) {
|
|
if (type === 'HTTP2PING') {
|
|
pings.add(id);
|
|
events[0]++;
|
|
}
|
|
},
|
|
before(id) {
|
|
if (pings.has(id)) {
|
|
events[1]++;
|
|
}
|
|
},
|
|
after(id) {
|
|
if (pings.has(id)) {
|
|
events[2]++;
|
|
}
|
|
},
|
|
destroy(id) {
|
|
if (pings.has(id)) {
|
|
events[3]++;
|
|
}
|
|
}
|
|
});
|
|
hook.enable();
|
|
|
|
process.on('exit', () => {
|
|
assert.deepStrictEqual(events, [4, 4, 4, 4]);
|
|
});
|
|
|
|
const server = http2.createServer();
|
|
server.on('stream', common.mustCall((stream) => {
|
|
assert(stream.session.ping(common.mustCall((err, duration, ret) => {
|
|
assert.strictEqual(err, null);
|
|
assert.strictEqual(typeof duration, 'number');
|
|
assert.strictEqual(ret.length, 8);
|
|
stream.end('ok');
|
|
})));
|
|
stream.respond();
|
|
}));
|
|
|
|
server.listen(0, common.mustCall(() => {
|
|
const client = http2.connect(`http://localhost:${server.address().port}`,
|
|
{ maxOutstandingPings: 2 });
|
|
client.on('connect', common.mustCall(() => {
|
|
{
|
|
const payload = Buffer.from('abcdefgh');
|
|
assert(client.ping(payload, common.mustCall((err, duration, ret) => {
|
|
assert.strictEqual(err, null);
|
|
assert.strictEqual(typeof duration, 'number');
|
|
assert.deepStrictEqual(payload, ret);
|
|
})));
|
|
}
|
|
{
|
|
const payload = Buffer.from('abcdefgi');
|
|
assert(client.ping(payload, common.mustCall((err, duration, ret) => {
|
|
assert.strictEqual(err, null);
|
|
assert.strictEqual(typeof duration, 'number');
|
|
assert.deepStrictEqual(payload, ret);
|
|
})));
|
|
}
|
|
|
|
// Only max 2 pings at a time based on the maxOutstandingPings option
|
|
assert(!client.ping(common.expectsError({
|
|
code: 'ERR_HTTP2_PING_CANCEL',
|
|
type: Error,
|
|
message: 'HTTP2 ping cancelled'
|
|
})));
|
|
|
|
// Should throw if payload is not of type ArrayBufferView
|
|
{
|
|
[1, true, {}, []].forEach((payload) =>
|
|
common.expectsError(
|
|
() => client.ping(payload),
|
|
{
|
|
type: TypeError,
|
|
code: 'ERR_INVALID_ARG_TYPE',
|
|
message: 'The "payload" argument must be one of type Buffer, ' +
|
|
`TypedArray, or DataView. Received type ${typeof payload}`
|
|
}
|
|
)
|
|
);
|
|
}
|
|
|
|
// Should throw if payload length is not 8
|
|
{
|
|
const shortPayload = Buffer.from('abcdefg');
|
|
const longPayload = Buffer.from('abcdefghi');
|
|
[shortPayload, longPayload].forEach((payloadWithInvalidLength) =>
|
|
common.expectsError(
|
|
() => client.ping(payloadWithInvalidLength),
|
|
{
|
|
type: RangeError,
|
|
code: 'ERR_HTTP2_PING_LENGTH',
|
|
message: 'HTTP2 ping payload must be 8 bytes'
|
|
}
|
|
)
|
|
);
|
|
}
|
|
|
|
// Should throw error is callback is not of type function
|
|
{
|
|
const payload = Buffer.from('abcdefgh');
|
|
[1, true, {}, []].forEach((invalidCallback) =>
|
|
common.expectsError(
|
|
() => client.ping(payload, invalidCallback),
|
|
{
|
|
type: TypeError,
|
|
code: 'ERR_INVALID_CALLBACK',
|
|
message: 'Callback must be a function'
|
|
}
|
|
)
|
|
);
|
|
}
|
|
|
|
const req = client.request();
|
|
req.resume();
|
|
req.on('end', common.mustCall(() => {
|
|
client.close();
|
|
server.close();
|
|
}));
|
|
}));
|
|
}));
|