// Flags: --expose-gc --expose-internals 'use strict'; const common = require('../common'); const assert = require('assert'); const { monitorEventLoopDelay } = require('perf_hooks'); const { sleep } = require('internal/util'); { const histogram = monitorEventLoopDelay(); assert(histogram); assert(histogram.enable()); assert(!histogram.enable()); histogram.reset(); assert(histogram.disable()); assert(!histogram.disable()); } { [null, 'a', 1, false, Infinity].forEach((i) => { assert.throws( () => monitorEventLoopDelay(i), { name: 'TypeError', code: 'ERR_INVALID_ARG_TYPE' } ); }); [null, 'a', false, {}, []].forEach((i) => { assert.throws( () => monitorEventLoopDelay({ resolution: i }), { name: 'TypeError', code: 'ERR_INVALID_ARG_TYPE' } ); }); [-1, 0, Infinity].forEach((i) => { assert.throws( () => monitorEventLoopDelay({ resolution: i }), { name: 'RangeError', code: 'ERR_INVALID_OPT_VALUE' } ); }); } { const histogram = monitorEventLoopDelay({ resolution: 1 }); histogram.enable(); let m = 5; function spinAWhile() { sleep(1000); if (--m > 0) { setTimeout(spinAWhile, common.platformTimeout(500)); } else { histogram.disable(); // The values are non-deterministic, so we just check that a value is // present, as opposed to a specific value. assert(histogram.min > 0); assert(histogram.max > 0); assert(histogram.stddev > 0); assert(histogram.mean > 0); assert(histogram.percentiles.size > 0); for (let n = 1; n < 100; n = n + 0.1) { assert(histogram.percentile(n) >= 0); } histogram.reset(); assert.strictEqual(histogram.min, 9223372036854776000); assert.strictEqual(histogram.max, 0); assert(Number.isNaN(histogram.stddev)); assert(Number.isNaN(histogram.mean)); assert.strictEqual(histogram.percentiles.size, 1); ['a', false, {}, []].forEach((i) => { assert.throws( () => histogram.percentile(i), { name: 'TypeError', code: 'ERR_INVALID_ARG_TYPE' } ); }); [-1, 0, 101].forEach((i) => { assert.throws( () => histogram.percentile(i), { name: 'RangeError', code: 'ERR_INVALID_ARG_VALUE' } ); }); } } spinAWhile(); } // Make sure that the histogram instances can be garbage-collected without // and not just implictly destroyed when the Environment is torn down. process.on('exit', global.gc);