From 682194810a0b6e22314a2e8b9b6c20cc9e390bcb Mon Sep 17 00:00:00 2001 From: Ze-Zheng Wu Date: Fri, 26 Jan 2024 15:04:41 +0800 Subject: [PATCH] fix: `just-compare` crash on some objects - objects with keys shadowing `hasOwnProperty` - objects with no prototypes --- packages/collection-compare/index.cjs | 2 +- packages/collection-compare/index.mjs | 2 +- test/collection-compare/index.cjs | 21 +++++++++++++++++++++ 3 files changed, 23 insertions(+), 2 deletions(-) diff --git a/packages/collection-compare/index.cjs b/packages/collection-compare/index.cjs index a829e78dd..39d31276b 100644 --- a/packages/collection-compare/index.cjs +++ b/packages/collection-compare/index.cjs @@ -88,7 +88,7 @@ function compareObjects(value1, value2) { for (var i = 0; i < len; i++) { var key1 = keys1[i]; - if (!(value2.hasOwnProperty(key1) && compare(value1[key1], value2[key1]))) { + if (!({}.hasOwnProperty.call(value2, key1) && compare(value1[key1], value2[key1]))) { return false; } } diff --git a/packages/collection-compare/index.mjs b/packages/collection-compare/index.mjs index a23af9a71..4091e36a8 100644 --- a/packages/collection-compare/index.mjs +++ b/packages/collection-compare/index.mjs @@ -88,7 +88,7 @@ function compareObjects(value1, value2) { for (var i = 0; i < len; i++) { var key1 = keys1[i]; - if (!(value2.hasOwnProperty(key1) && compare(value1[key1], value2[key1]))) { + if (!({}.hasOwnProperty.call(value2, key1) && compare(value1[key1], value2[key1]))) { return false; } } diff --git a/test/collection-compare/index.cjs b/test/collection-compare/index.cjs index bacd2d403..582868a95 100644 --- a/test/collection-compare/index.cjs +++ b/test/collection-compare/index.cjs @@ -204,3 +204,24 @@ test('primitives compared with primitive wrappers return false', function(t) { t.notOk(compare(value2, value1)); t.end(); }); + +test('objects with keys shadowing hasOwnProperty do not crash', function(t) { + t.plan(2); + var value1 = {hasOwnProperty: 1}; + var value2 = {hasOwnProperty: 1}; + t.ok(compare(value1, value2)); + var value3 = {hasOwnProperty: 2}; + t.notOk(compare(value1, value3)); + t.end(); +}); + +test('objects with no prototypes do not crash', function(t) { + t.plan(2); + var value1 = {foo: 'bar'}; + var value2 = Object.create(null); + value2.foo = 'bar'; + t.ok(compare(value1, value2)); + var value3 = {foo: 'baz'}; + t.notOk(compare(value3, value2)); + t.end(); +});