Skip to content

Commit

Permalink
assert: fix deepEqual always return true on URL
Browse files Browse the repository at this point in the history
PR-URL: #50853
Fixes: #50836
Reviewed-By: Yagiz Nizipli <[email protected]>
Reviewed-By: Marco Ippolito <[email protected]>
Reviewed-By: Ruben Bridgewater <[email protected]>
  • Loading branch information
meixg authored and aduh95 committed Nov 27, 2024
1 parent 08a4f08 commit 66bf05a
Show file tree
Hide file tree
Showing 3 changed files with 59 additions and 0 deletions.
5 changes: 5 additions & 0 deletions lib/internal/util/comparisons.js
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ const {
const { compare } = internalBinding('buffer');
const assert = require('internal/assert');
const { isError } = require('internal/util');
const { isURL } = require('internal/url');
const types = require('internal/util/types');
const {
isAnyArrayBuffer,
Expand Down Expand Up @@ -286,6 +287,10 @@ function innerDeepEqual(val1, val2, strict, memos) {
) {
return false;
}
} else if (isURL(val1)) {
if (!isURL(val2) || val1.href !== val2.href) {
return false;
}
}
return keyCheck(val1, val2, strict, memos, kNoIterator);
}
Expand Down
10 changes: 10 additions & 0 deletions lib/internal/util/inspect.js
Original file line number Diff line number Diff line change
Expand Up @@ -166,6 +166,11 @@ function pathToFileUrlHref(filepath) {
return internalUrl.pathToFileURL(filepath).href;
}

function isURL(value) {
internalUrl ??= require('internal/url');
return typeof value.href === 'string' && value instanceof internalUrl.URL;
}

const builtInObjects = new SafeSet(
ArrayPrototypeFilter(
ObjectGetOwnPropertyNames(globalThis),
Expand Down Expand Up @@ -1026,6 +1031,11 @@ function formatRaw(ctx, value, recurseTimes, typedArray) {
if (keys.length === 0 && protoProps === undefined) {
return base;
}
} else if (isURL(value) && !(recurseTimes > ctx.depth && ctx.depth !== null)) {
base = value.href;
if (keys.length === 0 && protoProps === undefined) {
return base;
}
} else {
if (keys.length === 0 && protoProps === undefined) {
if (isExternal(value)) {
Expand Down
44 changes: 44 additions & 0 deletions test/parallel/test-assert-deep.js
Original file line number Diff line number Diff line change
Expand Up @@ -1345,3 +1345,47 @@ test('Crypto', { skip: !hasCrypto }, async () => {
assertDeepAndStrictEqual(a, b);
}
});

// check URL
{
const a = new URL('http://foo');
const b = new URL('http://bar');

assertNotDeepOrStrict(a, b);
}

{
const a = new URL('http://foo');
const b = new URL('http://foo');

assertDeepAndStrictEqual(a, b);
}

{
const a = new URL('http://foo');
const b = new URL('http://foo');
a.bar = 1;
b.bar = 2;
assertNotDeepOrStrict(a, b);
}

{
const a = new URL('http://foo');
const b = new URL('http://foo');
a.bar = 1;
b.bar = 1;
assertDeepAndStrictEqual(a, b);
}

{
const a = new URL('http://foo');
const b = new URL('http://bar');
assert.throws(
() => assert.deepStrictEqual(a, b),
{
code: 'ERR_ASSERTION',
name: 'AssertionError',
message: /http:\/\/bar/
}
);
}

0 comments on commit 66bf05a

Please sign in to comment.