%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'; // https://github.com/nodejs/node/issues/3020 // Promises, nextTick, and queueMicrotask allow code to escape the timeout // set for runInContext, runInNewContext, and runInThisContext const common = require('../common'); const assert = require('assert'); const vm = require('vm'); const NS_PER_MS = 1000000n; const hrtime = process.hrtime.bigint; const nextTick = process.nextTick; const waitDuration = common.platformTimeout(100n); function loop() { const start = hrtime(); while (1) { const current = hrtime(); const span = (current - start) / NS_PER_MS; if (span >= waitDuration) { throw new Error( `escaped timeout at ${span} milliseconds!`); } } } // The bug won't happen 100% reliably so run the test a small number of times to // make sure we catch it if the bug exists. for (let i = 0; i < 4; i++) { assert.throws(() => { vm.runInNewContext( 'nextTick(loop); loop();', { hrtime, nextTick, loop }, { timeout: common.platformTimeout(10) } ); }, { code: 'ERR_SCRIPT_EXECUTION_TIMEOUT' }); }