X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=deep-merge-object.mjs;h=5e1ab7bd278dfa122fadef29a59f7466e5566f65;hb=ab9a08f3b8fdd43f8714e90652028621849f9f58;hp=1fbf315a111c1f3ed838458d786ac3be818408b1;hpb=1b4e2f913afc4f5dfed823720d89dde05d23d184;p=benchmarks-js.git diff --git a/deep-merge-object.mjs b/deep-merge-object.mjs index 1fbf315..5e1ab7b 100644 --- a/deep-merge-object.mjs +++ b/deep-merge-object.mjs @@ -1,42 +1,31 @@ /* eslint-disable no-unused-vars */ -import Benchmark from 'benny' import deepMerge from 'deepmerge' -import merge from 'just-merge' import _ from 'lodash' +import { bench, group, run } from 'mitata' +import { mergeDeepRight } from 'rambda' 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) => { + 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 +})