X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;ds=inline;f=busy-wait.js;h=9d0d31b4d6ee0285a9fe7fcd19a54e96e17de913;hb=a651d43cbc4c000f39e113f08d1cd71be0f54cf3;hp=d49a5fde51981ba870ab4de30397d5e61066592c;hpb=a8bf8b7d73343b33657cb8d6f36091a3bcdc38d6;p=benchmarks-js.git diff --git a/busy-wait.js b/busy-wait.js index d49a5fd..9d0d31b 100644 --- a/busy-wait.js +++ b/busy-wait.js @@ -1,11 +1,18 @@ -const Benchmark = require('benchmark') -const { LIST_FORMATTER, sleep } = require('./benchmark-utils') - -const suite = new Benchmark.Suite() +const Benchmark = require('benny') +const { sleep } = require('./benchmark-utils') const timeout = 2000 const interval = 1000 +/** + * @param timeoutMs + */ +function dummyTimeoutBusyWait (timeoutMs) { + const timeoutTimestampMs = Date.now() + timeoutMs + // eslint-disable-next-line no-empty + do {} while (Date.now() < timeoutTimestampMs) +} + /** * @param timeoutMs */ @@ -47,24 +54,23 @@ function setIntervalTimeoutBusyWait (timeoutMs, intervalMs = interval) { }, intervalMs) } -suite - .add('sleepTimeoutBusyWait', async function () { - sleepTimeoutBusyWait(timeout) - }) - .add('divideAndConquerTimeoutBusyWait', async function () { +Benchmark.suite( + 'Busy wait', + Benchmark.add('dummyTimeoutBusyWait', () => { + dummyTimeoutBusyWait(timeout) + }), + Benchmark.add('sleepTimeoutBusyWait', async () => { + await sleepTimeoutBusyWait(timeout) + }), + Benchmark.add('divideAndConquerTimeoutBusyWait', async () => { await divideAndConquerTimeoutBusyWait(timeout) - }) - .add('setIntervalTimeoutBusyWait', function () { + }), + Benchmark.add('setIntervalTimeoutBusyWait', () => { setIntervalTimeoutBusyWait(timeout) - }) - .on('cycle', function (event) { - console.log(event.target.toString()) - }) - .on('complete', function () { - console.log( - 'Fastest is ' + LIST_FORMATTER.format(this.filter('fastest').map('name')) - ) - // eslint-disable-next-line no-process-exit - process.exit() - }) - .run() + }), + Benchmark.cycle(), + Benchmark.complete(), + Benchmark.save({ file: 'busy-wait', format: 'json', details: true }), + Benchmark.save({ file: 'busy-wait', format: 'chart.html', details: true }), + Benchmark.save({ file: 'busy-wait', format: 'table.html', details: true }) +)