X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=deep-merge-object.mjs;h=a33dc2160d1b3547f89d0d54adf63d585861bfb8;hb=HEAD;hp=fe1440f91b9e82123801ed33b2e491d65b5568fc;hpb=4aa2893a787119ef9b3957e82539fee4fad4f98f;p=benchmarks-js.git diff --git a/deep-merge-object.mjs b/deep-merge-object.mjs index fe1440f..b36b800 100644 --- a/deep-merge-object.mjs +++ b/deep-merge-object.mjs @@ -1,41 +1,30 @@ -/* eslint-disable no-unused-vars */ -import Benchmark from 'benny' -import _ from 'lodash' -import merge from 'just-merge' import deepMerge from 'deepmerge' +import _ from 'lodash' +import { mergeDeepRight } from 'rambda' +import { bench, group, run } from 'tatami-ng' + import { generateRandomObject } from './benchmark-utils.mjs' const object = generateRandomObject() const objectToMerge = generateRandomObject() -Benchmark.suite( +group( `Deep merge two objects: object with ${ Object.keys(object).length } keys, object with ${Object.keys(objectToMerge).length} keys`, - Benchmark.add('lodash merge', (obj = object) => { - const objMerged = _.merge(obj, objectToMerge) - }), - Benchmark.add('just-merge', (obj = object) => { - const objMerged = merge(obj, objectToMerge) - }), - Benchmark.add('deepmerge', (obj = object) => { - const objMerged = deepMerge(obj, objectToMerge) - }), - Benchmark.cycle(), - Benchmark.complete(), - Benchmark.save({ - file: 'deep-merge-object', - format: 'json', - details: true - }), - Benchmark.save({ - file: 'deep-merge-object', - format: 'chart.html', - details: true - }), - Benchmark.save({ - file: 'deep-merge-object', - format: 'table.html', - details: true - }) -).catch(console.error) + () => { + bench('lodash merge', (obj = object) => { + _.merge(obj, objectToMerge) + }) + bench('rambda mergeDeepRight', (obj = object) => { + mergeDeepRight(obj, objectToMerge) + }) + bench('deepmerge', (obj = object) => { + deepMerge(obj, objectToMerge) + }) + } +) + +await run({ + units: true, +})