-
Notifications
You must be signed in to change notification settings - Fork 128
/
Copy pathbenchmark.js
27 lines (21 loc) · 982 Bytes
/
benchmark.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
var opening_hours = require('./opening_hours.js');
var tests = 3;
var iterations = 40000;
console.log('Construction:');
for (var t = 0; t < tests; t++) {
var before = new Date();
for (var i = 0; i < iterations; i++)
var oh = new opening_hours('Mo,Tu,Th,Fr 12:00-18:00;Sa 12:00-17:00; Th[3] off; Th[-1] off');
var delta = (new Date()).getTime() - before.getTime();
console.log(iterations + ' iterations, ' + delta + ' ms (' + (iterations/delta*1000).toFixed(2) + ' n/sec)');
}
var iterations = 20000;
console.log('Checking:');
for (var t = 0; t < tests; t++) {
var oh = new opening_hours('Mo,Tu,Th,Fr 12:00-18:00;Sa 12:00-17:00; Th[3] off; Th[-1] off');
var before = new Date();
for (var i = 0; i < iterations; i++)
oh.getOpenIntervals(new Date('2012.01.01 00:00'), new Date('2012.01.07 00:00'));
var delta = (new Date()).getTime() - before.getTime();
console.log(iterations + ' iterations, ' + delta + ' ms (' + (iterations/delta*1000).toFixed(2) + ' n/sec)');
}