machinepack-postgresql
Version:
Structured Node.js bindings for connecting and running queries against a PostgreSQL database.
33 lines (27 loc) • 1.12 kB
JavaScript
var _ = require('@sailshq/lodash');
var Benchmark = require('benchmark');
module.exports = function runBenchmarks(name, testFns) {
var suite = new Benchmark.Suite({
name: name
});
_.each(testFns, function buildTest(testFn) {
suite = suite.add(testFn.name, {
fn: testFn
});
});
suite.on('cycle', function(event) {
console.log(' •', String(event.target));
})
.on('complete', function() {
// Time is measured in microseconds so 1000 = 1ms
var fastestMean = _.first(this.filter('fastest')).stats.mean * 1000;
var slowestMean = _.first(this.filter('slowest')).stats.mean * 1000;
var mean = {
fastest: Benchmark.formatNumber(fastestMean < 1 ? fastestMean.toFixed(2) : Math.round(fastestMean)),
slowest: Benchmark.formatNumber(slowestMean < 1 ? slowestMean.toFixed(2) : Math.round(slowestMean))
};
console.log('Fastest is ' + this.filter('fastest').map('name') + ' with an average of: ' + mean.fastest + 'ms');
console.log('Slowest is ' + this.filter('slowest').map('name') + ' with an average of: ' + mean.slowest + 'ms');
})
.run();
};