summaryrefslogtreecommitdiff
path: root/benchmark/timers/timers-timeout-unpooled.js
blob: 19f0f6a4af4d0d6f5afe5773983c8135e84a9d8d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
'use strict';
const common = require('../common.js');

// The following benchmark sets up n * 1e6 unpooled timeouts,
// then measures their execution on the next uv tick

const bench = common.createBenchmark(main, {
  n: [1e6],
});

function main({ n }) {
  let count = 0;

  // Function tracking on the hidden class in V8 can cause misleading
  // results in this benchmark if only a single function is used —
  // alternate between two functions for a fairer benchmark

  function cb() {
    count++;
    if (count === n)
      bench.end(n);
  }
  function cb2() {
    count++;
    if (count === n)
      bench.end(n);
  }

  for (var i = 0; i < n; i++) {
    // unref().ref() will cause each of these timers to
    // allocate their own handle
    setTimeout(i % 2 ? cb : cb2, 1).unref().ref();
  }

  bench.start();
}