mirror of
https://github.com/oven-sh/bun
synced 2026-02-09 18:38:55 +00:00
one more
This commit is contained in:
58
test/js/node/test/parallel/test-http2-session-unref.js
Normal file
58
test/js/node/test/parallel/test-http2-session-unref.js
Normal file
@@ -0,0 +1,58 @@
|
||||
'use strict';
|
||||
// Tests that calling unref() on Http2Session:
|
||||
// (1) Prevents it from keeping the process alive
|
||||
// (2) Doesn't crash
|
||||
|
||||
const common = require('../common');
|
||||
if (!common.hasCrypto)
|
||||
common.skip('missing crypto');
|
||||
const http2 = require('http2');
|
||||
const Countdown = require('../common/countdown');
|
||||
const { duplexPair } = require('stream');
|
||||
|
||||
const server = http2.createServer();
|
||||
const [ clientSide, serverSide ] = duplexPair();
|
||||
|
||||
const counter = new Countdown(3, () => server.unref());
|
||||
|
||||
// 'session' event should be emitted 3 times:
|
||||
// - the vanilla clientgit
|
||||
// - the destroyed client
|
||||
// - manual 'connection' event emission with generic Duplex stream
|
||||
server.on('session', common.mustCallAtLeast((session) => {
|
||||
counter.dec();
|
||||
session.unref();
|
||||
}, 3));
|
||||
|
||||
server.listen(0, common.mustCall(() => {
|
||||
const port = server.address().port;
|
||||
|
||||
// unref new client
|
||||
{
|
||||
const client = http2.connect(`http://localhost:${port}`);
|
||||
client.unref();
|
||||
}
|
||||
|
||||
// Unref destroyed client
|
||||
{
|
||||
const client = http2.connect(`http://localhost:${port}`);
|
||||
|
||||
client.on('connect', common.mustCall(() => {
|
||||
client.destroy();
|
||||
client.unref();
|
||||
}));
|
||||
}
|
||||
|
||||
// Unref destroyed client
|
||||
{
|
||||
const client = http2.connect(`http://localhost:${port}`, {
|
||||
createConnection: common.mustCall(() => clientSide)
|
||||
});
|
||||
|
||||
client.on('connect', common.mustCall(() => {
|
||||
client.destroy();
|
||||
client.unref();
|
||||
}));
|
||||
}
|
||||
}));
|
||||
server.emit('connection', serverSide);
|
||||
Reference in New Issue
Block a user