%PDF- <> %âãÏÓ endobj 2 0 obj <> endobj 3 0 obj <>/ExtGState<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI] >>/Annots[ 28 0 R 29 0 R] /MediaBox[ 0 0 595.5 842.25] /Contents 4 0 R/Group<>/Tabs/S>> endobj ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<> endobj 2 0 obj<>endobj 2 0 obj<>es 3 0 R>> endobj 2 0 obj<> ox[ 0.000000 0.000000 609.600000 935.600000]/Fi endobj 3 0 obj<> endobj 7 1 obj<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI]>>/Subtype/Form>> stream
'use strict'; const common = require('../common'); if (!common.hasCrypto) common.skip('missing crypto'); const assert = require('assert'); const http2 = require('http2'); let requests = 0; const mustNotCall = () => { assert.fail(`Timeout after ${requests} request(s)`); }; const server = http2.createServer(); // Disable server timeout until first request. We will set the timeout based on // how long the first request takes. server.timeout = 0; server.on('request', (req, res) => res.end()); server.on('timeout', mustNotCall); server.listen(0, common.mustCall(() => { const port = server.address().port; const url = `http://localhost:${port}`; const client = http2.connect(url); let startTime = process.hrtime(); makeReq(); function makeReq() { const request = client.request({ ':path': '/foobar', ':method': 'GET', ':scheme': 'http', ':authority': `localhost:${port}`, }); request.resume(); request.end(); requests += 1; request.on('end', () => { const diff = process.hrtime(startTime); const milliseconds = (diff[0] * 1e3 + diff[1] / 1e6); if (server.timeout === 0) { // Set the timeout now. First connection will take significantly longer // than subsequent connections, so using the duration of the first // connection as the timeout should be robust. Double it anyway for good // measure. server.timeout = milliseconds * 2; startTime = process.hrtime(); makeReq(); } else if (milliseconds < server.timeout * 2) { makeReq(); } else { server.removeListener('timeout', mustNotCall); server.close(); client.close(); } }); } }));