mirror of https://github.com/lukechilds/node.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
123 lines
4.2 KiB
123 lines
4.2 KiB
'use strict';
|
|
|
|
/* eslint-disable no-restricted-properties */
|
|
|
|
const common = require('../common.js');
|
|
const assert = require('assert');
|
|
|
|
const bench = common.createBenchmark(main, {
|
|
n: [5e2],
|
|
len: [5e2],
|
|
method: [
|
|
'deepEqual_primitiveOnly',
|
|
'deepStrictEqual_primitiveOnly',
|
|
'deepEqual_objectOnly',
|
|
'deepStrictEqual_objectOnly',
|
|
'deepEqual_mixed',
|
|
'deepStrictEqual_mixed',
|
|
'deepEqual_looseMatches',
|
|
'notDeepEqual_primitiveOnly',
|
|
'notDeepStrictEqual_primitiveOnly',
|
|
'notDeepEqual_objectOnly',
|
|
'notDeepStrictEqual_objectOnly',
|
|
'notDeepEqual_mixed',
|
|
'notDeepStrictEqual_mixed',
|
|
'notDeepEqual_looseMatches',
|
|
]
|
|
});
|
|
|
|
function benchmark(method, n, values, values2) {
|
|
const actual = new Map(values);
|
|
// Prevent reference equal elements
|
|
const deepCopy = JSON.parse(JSON.stringify(values2 ? values2 : values));
|
|
const expected = new Map(deepCopy);
|
|
bench.start();
|
|
for (var i = 0; i < n; ++i) {
|
|
method(actual, expected);
|
|
}
|
|
bench.end(n);
|
|
}
|
|
|
|
function main(conf) {
|
|
const n = +conf.n;
|
|
const len = +conf.len;
|
|
|
|
const array = Array(len).fill(1);
|
|
var values, values2;
|
|
|
|
switch (conf.method) {
|
|
case 'deepEqual_primitiveOnly':
|
|
values = array.map((_, i) => [`str_${i}`, 123]);
|
|
benchmark(assert.deepEqual, n, values);
|
|
break;
|
|
case 'deepStrictEqual_primitiveOnly':
|
|
values = array.map((_, i) => [`str_${i}`, 123]);
|
|
benchmark(assert.deepStrictEqual, n, values);
|
|
break;
|
|
case 'deepEqual_objectOnly':
|
|
values = array.map((_, i) => [[`str_${i}`, 1], 123]);
|
|
benchmark(assert.deepEqual, n, values);
|
|
break;
|
|
case 'deepStrictEqual_objectOnly':
|
|
values = array.map((_, i) => [[`str_${i}`, 1], 123]);
|
|
benchmark(assert.deepStrictEqual, n, values);
|
|
break;
|
|
case 'deepEqual_mixed':
|
|
values = array.map((_, i) => [i % 2 ? [`str_${i}`, 1] : `str_${i}`, 123]);
|
|
benchmark(assert.deepEqual, n, values);
|
|
break;
|
|
case 'deepStrictEqual_mixed':
|
|
values = array.map((_, i) => [i % 2 ? [`str_${i}`, 1] : `str_${i}`, 123]);
|
|
benchmark(assert.deepStrictEqual, n, values);
|
|
break;
|
|
case 'deepEqual_looseMatches':
|
|
values = array.map((_, i) => [i, i]);
|
|
values2 = values.slice().map((v) => [String(v[0]), String(v[1])]);
|
|
benchmark(assert.deepEqual, n, values, values2);
|
|
break;
|
|
case 'notDeepEqual_primitiveOnly':
|
|
values = array.map((_, i) => [`str_${i}`, 123]);
|
|
values2 = values.slice(0);
|
|
values2[Math.floor(len / 2)] = ['w00t', 123];
|
|
benchmark(assert.notDeepEqual, n, values, values2);
|
|
break;
|
|
case 'notDeepStrictEqual_primitiveOnly':
|
|
values = array.map((_, i) => [`str_${i}`, 123]);
|
|
values2 = values.slice(0);
|
|
values2[Math.floor(len / 2)] = ['w00t', 123];
|
|
benchmark(assert.notDeepStrictEqual, n, values, values2);
|
|
break;
|
|
case 'notDeepEqual_objectOnly':
|
|
values = array.map((_, i) => [[`str_${i}`, 1], 123]);
|
|
values2 = values.slice(0);
|
|
values2[Math.floor(len / 2)] = [['w00t'], 123];
|
|
benchmark(assert.notDeepEqual, n, values, values2);
|
|
break;
|
|
case 'notDeepStrictEqual_objectOnly':
|
|
values = array.map((_, i) => [[`str_${i}`, 1], 123]);
|
|
values2 = values.slice(0);
|
|
values2[Math.floor(len / 2)] = [['w00t'], 123];
|
|
benchmark(assert.notDeepStrictEqual, n, values, values2);
|
|
break;
|
|
case 'notDeepEqual_mixed':
|
|
values = array.map((_, i) => [i % 2 ? [`str_${i}`, 1] : `str_${i}`, 123]);
|
|
values2 = values.slice(0);
|
|
values2[0] = ['w00t', 123];
|
|
benchmark(assert.notDeepEqual, n, values, values2);
|
|
break;
|
|
case 'notDeepStrictEqual_mixed':
|
|
values = array.map((_, i) => [i % 2 ? [`str_${i}`, 1] : `str_${i}`, 123]);
|
|
values2 = values.slice(0);
|
|
values2[0] = ['w00t', 123];
|
|
benchmark(assert.notDeepStrictEqual, n, values, values2);
|
|
break;
|
|
case 'notDeepEqual_looseMatches':
|
|
values = array.map((_, i) => [i, i]);
|
|
values2 = values.slice().map((v) => [String(v[0]), String(v[1])]);
|
|
values2[len - 1] = [String(len + 1), String(len + 1)];
|
|
benchmark(assert.notDeepEqual, n, values, values2);
|
|
break;
|
|
default:
|
|
throw new Error('Unsupported method');
|
|
}
|
|
}
|
|
|