mirror of
https://github.com/nodejs/node.git
synced 2025-05-01 08:42:45 +00:00

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>
52 lines
1.4 KiB
JavaScript
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();
|
|
}
|
|
}));
|
|
}
|