node/test/parallel/test-http2-buffersize.js
Luigi Pinca 0f9434af4d test: deflake test-http2-buffersize
This is basically a revert of
c452632d34.

The problem with that commit is that the promises returned by
`once(server, 'stream')` are all resolved with the same stream when the
first `'stream'` event is emitted.

Refs: https://github.com/nodejs/node/pull/39525#issuecomment-889080913

PR-URL: https://github.com/nodejs/node/pull/39591
Reviewed-By: Rich Trott <rtrott@gmail.com>
Reviewed-By: Anna Henningsen <anna@addaleax.net>
2021-08-02 18:42:44 +02:00

52 lines
1.4 KiB
JavaScript

'use strict';
const { mustCall, mustSucceed, hasCrypto, skip } = require('../common');
if (!hasCrypto)
skip('missing crypto');
const assert = require('assert');
const { createServer, connect } = require('http2');
const Countdown = require('../common/countdown');
// This test ensures that `bufferSize` of Http2Session and Http2Stream work
// as expected.
{
const kSockets = 2;
const kTimes = 10;
const kBufferSize = 30;
const server = createServer();
let client;
const countdown = new Countdown(kSockets, () => {
client.close();
server.close();
});
server.on('stream', mustCall((stream) => {
stream.on('data', mustCall());
stream.on('end', mustCall());
stream.on('close', mustCall(() => {
countdown.dec();
}));
}, kSockets));
server.listen(0, mustCall(() => {
const authority = `http://localhost:${server.address().port}`;
client = connect(authority);
client.once('connect', mustCall());
for (let j = 0; j < kSockets; j += 1) {
const stream = client.request({ ':method': 'POST' });
stream.on('data', () => {});
for (let i = 0; i < kTimes; i += 1) {
stream.write(Buffer.allocUnsafe(kBufferSize), mustSucceed());
const expectedSocketBufferSize = kBufferSize * (i + 1);
assert.strictEqual(stream.bufferSize, expectedSocketBufferSize);
}
stream.end();
stream.close();
}
}));
}