Skip to content

Commit b9c7c90

Browse files
addaleaxBridgeAR
authored andcommitted
benchmark: improve process.env benchmarks
Benchmark different types of operations and make results comparable by normalizing process.env for enumeartion. PR-URL: #29188 Reviewed-By: James M Snell <[email protected]> Reviewed-By: Colin Ihrig <[email protected]>
1 parent 3a6bc90 commit b9c7c90

File tree

2 files changed

+49
-8
lines changed

2 files changed

+49
-8
lines changed

benchmark/process/bench-env.js

+47-7
Original file line numberDiff line numberDiff line change
@@ -3,15 +3,55 @@
33
const common = require('../common');
44

55
const bench = common.createBenchmark(main, {
6-
n: [1e5],
6+
n: [1e6],
7+
operation: ['get', 'set', 'enumerate', 'query', 'delete']
78
});
89

910

10-
function main({ n }) {
11-
bench.start();
12-
for (var i = 0; i < n; i++) {
13-
// Access every item in object to process values.
14-
Object.keys(process.env);
11+
function main({ n, operation }) {
12+
switch (operation) {
13+
case 'get':
14+
bench.start();
15+
for (let i = 0; i < n; i++) {
16+
process.env.PATH;
17+
}
18+
bench.end(n);
19+
break;
20+
case 'set':
21+
bench.start();
22+
for (let i = 0; i < n; i++) {
23+
process.env.DUMMY = 'hello, world';
24+
}
25+
bench.end(n);
26+
break;
27+
case 'enumerate':
28+
// First, normalize process.env so that benchmark results are comparable.
29+
for (const key of Object.keys(process.env))
30+
delete process.env[key];
31+
for (let i = 0; i < 64; i++)
32+
process.env[Math.random()] = Math.random();
33+
34+
n /= 10; // Enumeration is comparatively heavy.
35+
bench.start();
36+
for (let i = 0; i < n; i++) {
37+
// Access every item in object to process values.
38+
Object.keys(process.env);
39+
}
40+
bench.end(n);
41+
break;
42+
case 'query':
43+
bench.start();
44+
for (let i = 0; i < n; i++) {
45+
'PATH' in process.env;
46+
}
47+
bench.end(n);
48+
break;
49+
case 'delete':
50+
bench.start();
51+
for (let i = 0; i < n; i++) {
52+
delete process.env.DUMMY;
53+
}
54+
bench.end(n);
55+
break;
1556
}
16-
bench.end(n);
1757
}

test/benchmark/test-benchmark-process.js

+2-1
Original file line numberDiff line numberDiff line change
@@ -7,5 +7,6 @@ const runBenchmark = require('../common/benchmark');
77
runBenchmark('process',
88
[
99
'n=1',
10-
'type=raw'
10+
'type=raw',
11+
'operation=enumerate',
1112
], { NODEJS_BENCHMARK_ZERO_ALLOWED: 1 });

0 commit comments

Comments
 (0)