X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=deep-merge-object.mjs;h=50cc13cb4cbe60341f815d6310fab4dacaac0b01;hb=9fe780df3b1ec373b4fd145fad258a899320d9ac;hp=036f4f0f9c1e1dfc99ff132500e16241ce68c945;hpb=896570f75bba05688050ab104915cd638cc327fd;p=benchmarks-js.git diff --git a/deep-merge-object.mjs b/deep-merge-object.mjs index 036f4f0..50cc13c 100644 --- a/deep-merge-object.mjs +++ b/deep-merge-object.mjs @@ -1,43 +1,31 @@ /* 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('deep-clone', (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(err => { - console.error(err) + () => { + bench('lodash merge', (obj = object) => { + const objMerged = _.merge(obj, objectToMerge) + }) + bench('rambda mergeDeepRight', (obj = object) => { + const objMerged = mergeDeepRight(obj, objectToMerge) + }) + bench('deepmerge', (obj = object) => { + const objMerged = deepMerge(obj, objectToMerge) + }) + } +) + +await run({ + units: true })