forked from unjs/consola
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbenchmarks.js
89 lines (79 loc) · 2.02 KB
/
benchmarks.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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
import { Suite } from 'benchmark'
import { Consola, BasicReporter } from './src'
/**
* Benchmarks for Consola
*
* run as:
* node -r esm benchmark.js >/dev/null
*/
const consolaDefault = new Consola({
async: null,
reporters: [
new BasicReporter()
]
})
const consolaSync = new Consola({
async: false,
reporters: [
new BasicReporter()
]
})
const consolaAsync = new Consola({
async: true,
reporters: [
new BasicReporter()
]
})
let suite
const benchmarks = {
log: ['test'],
'log with string arg': ['test', 'test'],
'log with array arg': ['test', [1, 2, 3]],
'log with object arg': ['test', { a: 1, b: 2, c: 3 }],
'log with error': ['test', new Error('test')]
}
function run () {
let p = Promise.resolve()
Object.keys(benchmarks).forEach((name) => {
p = p.then(() => {
return new Promise((resolve) => {
/* eslint-disable-next-line no-console */
console.error('Running benchmark: ' + name)
suite = new Suite()
suite
.add('default', () => {
consolaDefault.log(...benchmarks[name])
})
.add('sync', () => {
consolaSync.log(...benchmarks[name])
})
.add('async', () => {
consolaAsync.log(...benchmarks[name])
})
.add('async resolve', {
defer: true,
fn: (deferred) => {
consolaAsync.log(...benchmarks[name]).then(() => {
deferred.resolve()
})
}
})
.on('cycle', (event) => {
/* eslint-disable-next-line no-console */
console.error(String(event.target))
})
.on('complete', function () {
/* eslint-disable-next-line no-console */
console.error('Fastest is ' + this.filter('fastest').map('name') + '\n')
resolve()
})
.run({ async: true })
})
})
})
return p
}
run().then(() => {
/* eslint-disable-next-line no-console */
console.error('All benchmarks finished')
})