-
Notifications
You must be signed in to change notification settings - Fork 98
/
perf.js
33 lines (31 loc) · 1.2 KB
/
perf.js
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
var jmespath = require('./jmespath')
var Benchmark = require('benchmark');
var suite = new Benchmark.Suite;
// add tests
suite.add('Parser#single_expr', function() {
jmespath.compile("foo");
})
.add('Parser#single_subexpr', function() {
jmespath.compile("foo.bar");
})
.add('Parser#deeply_nested_50', function() {
jmespath.compile("j49.j48.j47.j46.j45.j44.j43.j42.j41.j40.j39.j38.j37.j36.j35.j34.j33.j32.j31.j30.j29.j28.j27.j26.j25.j24.j23.j22.j21.j20.j19.j18.j17.j16.j15.j14.j13.j12.j11.j10.j9.j8.j7.j6.j5.j4.j3.j2.j1.j0");
})
.add('Parser#deeply_nested_50_index', function() {
jmespath.compile("[49][48][47][46][45][44][43][42][41][40][39][38][37][36][35][34][33][32][31][30][29][28][27][26][25][24][23][22][21][20][19][18][17][16][15][14][13][12][11][10][9][8][7][6][5][4][3][2][1][0]");
})
.add('Parser#basic_list_projection', function() {
jmespath.compile("foo[*].bar");
})
.on('cycle', function(event) {
var bench = event.target;
var mean = bench.stats.mean * 1000;
var variance = bench.stats.variance * 1000000;
var result = 'Mean time: ' + mean.toFixed(6) + 'msec ';
result += event.target.toString();
console.log(result);
})
.on('complete', function() {
})
// run async
.run({ 'async': false });