mirror of
https://github.com/FormidableLabs/react-fast-compare.git
synced 2026-01-18 16:13:59 +00:00
- Update library to include ES.next support for `Map`, `Set`, `ArrayBuffer`. Part of #36 - Update to `fast-deep-equal@3.1.1` with modified support for ES.next data types. - Upgrade lots of `devDependenices` - Use `fast-deep-equal` tests directly in our correctness tests. - Update CI to modern Node.js versions. - **Note**: There's a bug / limitation of `Set` comparisons whereby objects are compared by reference not value. Tracked at #50 . In our `yarn benchmark`, `lodash.isEqual` gets test differences because it correctly handles those.
73 lines
1.4 KiB
JavaScript
73 lines
1.4 KiB
JavaScript
'use strict';
|
|
var generic = require('fast-deep-equal-git/spec/tests.js');
|
|
var es6 = require('fast-deep-equal-git/spec/es6tests.js');
|
|
|
|
const reactElementA = {
|
|
'$$typeof': 'react.element',
|
|
type: 'div',
|
|
key: null,
|
|
ref: null,
|
|
props: { x: 1 },
|
|
_owner: {},
|
|
_store: {}
|
|
};
|
|
// in reality the _owner object is much more complex (and contains over dozen circular references)
|
|
reactElementA._owner.children = [reactElementA];
|
|
|
|
const reactElementA2 = {
|
|
'$$typeof': 'react.element',
|
|
type: 'div',
|
|
key: null,
|
|
ref: null,
|
|
props: { x: 1 },
|
|
_owner: {},
|
|
_store: {}
|
|
};
|
|
reactElementA2._owner.children = [reactElementA2];
|
|
|
|
const reactElementB = {
|
|
'$$typeof': 'react.element',
|
|
type: 'div',
|
|
key: null,
|
|
ref: null,
|
|
props: { x: 2 },
|
|
_owner: {},
|
|
_store: {}
|
|
};
|
|
reactElementB._owner.children = [reactElementB];
|
|
|
|
|
|
const react = [
|
|
{
|
|
description: 'React elements',
|
|
reactSpecific: true,
|
|
tests: [
|
|
{
|
|
description: 'an element compared with itself',
|
|
value1: reactElementA,
|
|
value2: reactElementA,
|
|
equal: true
|
|
},
|
|
{
|
|
description: 'two elements equal by value',
|
|
value1: reactElementA,
|
|
value2: reactElementA2,
|
|
equal: true
|
|
},
|
|
{
|
|
description: 'two elements unequal by value',
|
|
value1: reactElementA,
|
|
value2: reactElementB,
|
|
equal: false
|
|
}
|
|
]
|
|
}
|
|
];
|
|
|
|
module.exports = {
|
|
generic,
|
|
es6,
|
|
react,
|
|
all: [...generic, ...es6, ...react],
|
|
};
|