2017-07-18 13:00:44 -03:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
const common = require('../common.js');
|
2018-05-30 03:50:31 +00:00
|
|
|
const { deepEqual, deepStrictEqual, notDeepEqual, notDeepStrictEqual } =
|
|
|
|
require('assert');
|
2017-07-18 13:00:44 -03:00
|
|
|
|
|
|
|
const bench = common.createBenchmark(main, {
|
2025-03-08 18:01:04 +01:00
|
|
|
n: [1e3],
|
2025-04-05 10:53:31 +02:00
|
|
|
len: [2, 1e2],
|
2018-08-03 15:30:22 +02:00
|
|
|
strict: [0, 1],
|
2025-04-05 10:53:31 +02:00
|
|
|
order: ['insert', 'random', 'reversed'],
|
2017-07-18 13:00:44 -03:00
|
|
|
method: [
|
|
|
|
'deepEqual_primitiveOnly',
|
|
|
|
'deepEqual_objectOnly',
|
|
|
|
'deepEqual_mixed',
|
|
|
|
'notDeepEqual_primitiveOnly',
|
|
|
|
'notDeepEqual_objectOnly',
|
2019-01-31 21:05:17 -08:00
|
|
|
'notDeepEqual_mixed',
|
|
|
|
],
|
2025-04-05 10:53:31 +02:00
|
|
|
}, {
|
|
|
|
combinationFilter(p) {
|
|
|
|
return p.order !== 'random' || p.strict === 1 && p.method !== 'notDeepEqual_objectOnly';
|
|
|
|
},
|
2017-07-18 13:00:44 -03:00
|
|
|
});
|
|
|
|
|
2025-04-05 10:53:31 +02:00
|
|
|
function shuffleArray(array) {
|
|
|
|
for (let i = array.length - 1; i > 0; i--) {
|
|
|
|
const j = Math.floor(Math.random() * (i + 1));
|
|
|
|
const temp = array[i];
|
|
|
|
array[i] = array[j];
|
|
|
|
array[j] = temp;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function benchmark(method, n, values, values2, order) {
|
2017-07-18 13:00:44 -03:00
|
|
|
const actual = new Set(values);
|
|
|
|
// Prevent reference equal elements
|
2025-04-05 10:53:31 +02:00
|
|
|
let deepCopy = JSON.parse(JSON.stringify(values2));
|
|
|
|
if (order === 'reversed') {
|
|
|
|
deepCopy = deepCopy.reverse();
|
|
|
|
} else if (order === 'random') {
|
|
|
|
shuffleArray(deepCopy);
|
|
|
|
}
|
2017-07-18 13:00:44 -03:00
|
|
|
const expected = new Set(deepCopy);
|
|
|
|
bench.start();
|
2019-11-12 19:56:03 +01:00
|
|
|
for (let i = 0; i < n; ++i) {
|
2017-07-18 13:00:44 -03:00
|
|
|
method(actual, expected);
|
|
|
|
}
|
|
|
|
bench.end(n);
|
|
|
|
}
|
|
|
|
|
2025-04-05 10:53:31 +02:00
|
|
|
function main({ n, len, method, strict, order }) {
|
|
|
|
const array = Array.from({ length: len }, () => '');
|
2017-07-18 13:00:44 -03:00
|
|
|
|
2017-12-30 03:54:30 +01:00
|
|
|
switch (method) {
|
2019-11-12 19:56:03 +01:00
|
|
|
case 'deepEqual_primitiveOnly': {
|
|
|
|
const values = array.map((_, i) => `str_${i}`);
|
2025-04-05 10:53:31 +02:00
|
|
|
benchmark(strict ? deepStrictEqual : deepEqual, n, values, values, order);
|
2017-07-18 13:00:44 -03:00
|
|
|
break;
|
2019-11-12 19:56:03 +01:00
|
|
|
}
|
|
|
|
case 'deepEqual_objectOnly': {
|
|
|
|
const values = array.map((_, i) => [`str_${i}`, null]);
|
2025-04-05 10:53:31 +02:00
|
|
|
benchmark(strict ? deepStrictEqual : deepEqual, n, values, values, order);
|
2017-07-18 13:00:44 -03:00
|
|
|
break;
|
2019-11-12 19:56:03 +01:00
|
|
|
}
|
|
|
|
case 'deepEqual_mixed': {
|
|
|
|
const values = array.map((_, i) => {
|
2017-07-18 13:00:44 -03:00
|
|
|
return i % 2 ? [`str_${i}`, null] : `str_${i}`;
|
|
|
|
});
|
2025-04-05 10:53:31 +02:00
|
|
|
benchmark(strict ? deepStrictEqual : deepEqual, n, values, values, order);
|
2017-07-18 13:00:44 -03:00
|
|
|
break;
|
2019-11-12 19:56:03 +01:00
|
|
|
}
|
|
|
|
case 'notDeepEqual_primitiveOnly': {
|
|
|
|
const values = array.map((_, i) => `str_${i}`);
|
|
|
|
const values2 = values.slice(0);
|
2017-07-18 13:00:44 -03:00
|
|
|
values2[Math.floor(len / 2)] = 'w00t';
|
2025-04-05 10:53:31 +02:00
|
|
|
benchmark(strict ? notDeepStrictEqual : notDeepEqual, n, values, values2, order);
|
2017-07-18 13:00:44 -03:00
|
|
|
break;
|
2019-11-12 19:56:03 +01:00
|
|
|
}
|
|
|
|
case 'notDeepEqual_objectOnly': {
|
|
|
|
const values = array.map((_, i) => [`str_${i}`, null]);
|
|
|
|
const values2 = values.slice(0);
|
2017-07-18 13:00:44 -03:00
|
|
|
values2[Math.floor(len / 2)] = ['w00t'];
|
2025-04-05 10:53:31 +02:00
|
|
|
benchmark(strict ? notDeepStrictEqual : notDeepEqual, n, values, values2, order);
|
2017-07-18 13:00:44 -03:00
|
|
|
break;
|
2019-11-12 19:56:03 +01:00
|
|
|
}
|
|
|
|
case 'notDeepEqual_mixed': {
|
|
|
|
const values = array.map((_, i) => {
|
2017-07-18 13:00:44 -03:00
|
|
|
return i % 2 ? [`str_${i}`, null] : `str_${i}`;
|
|
|
|
});
|
2019-11-12 19:56:03 +01:00
|
|
|
const values2 = values.slice();
|
2017-07-18 13:00:44 -03:00
|
|
|
values2[0] = 'w00t';
|
2025-04-05 10:53:31 +02:00
|
|
|
benchmark(strict ? notDeepStrictEqual : notDeepEqual, n, values, values2, order);
|
2017-07-18 13:00:44 -03:00
|
|
|
break;
|
2019-11-12 19:56:03 +01:00
|
|
|
}
|
2017-07-18 13:00:44 -03:00
|
|
|
default:
|
2018-01-23 13:17:21 +01:00
|
|
|
throw new Error(`Unsupported method "${method}"`);
|
2017-07-18 13:00:44 -03:00
|
|
|
}
|
|
|
|
}
|