-
Notifications
You must be signed in to change notification settings - Fork 30.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
assert: handle enum. symbol keys in deepStrictEqual #15169
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM if CI and CITGM don't reveal any surprises. Left some nits on the docs but they're tiny suggestions that can be ignored if anyone disputes any of them.
doc/api/assert.md
Outdated
throw an `AssertionError` because the properties on the [`RegExp`][] object are | ||
not enumerable: | ||
[`[[Prototype]]`][prototype-spec] of objects or enumerable own [`Symbol`][] | ||
properties — for such checks, consider using [`assert.deepStrictEqual()`][] |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Micro-nit: Get rid of the —
and make these two simple sentences instead:
Only [enumerable "own" properties][] are considered. The [
assert.deepEqual()
][] implementation does not test the [[[Prototype]]
][prototype-spec] of objects or enumerable own [Symbol
][] properties. For such checks, consider using [assert.deepStrictEqual()
][] instead.
doc/api/assert.md
Outdated
not enumerable: | ||
[`[[Prototype]]`][prototype-spec] of objects or enumerable own [`Symbol`][] | ||
properties — for such checks, consider using [`assert.deepStrictEqual()`][] | ||
instead. This can lead to some potentially surprising results. For example, the |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nit: New paragraph starting with This can lead…
. Maybe also replace This
. And get rid of For example
as the next few words are the following example
. All told, maybe this?:
assert.deepEqual()
can have potentially surprising results. The following example does not throw anAssertioneError
because the properties on the [RegExp
][] object are not enumerable:
doc/api/assert.md
Outdated
@@ -105,6 +104,9 @@ parameter is undefined, a default error message is assigned. | |||
added: v1.2.0 | |||
changes: | |||
- version: REPLACEME | |||
pr-url: https://github.com/nodejs/node/pull/XXXXX | |||
description: Enumerable symbols are now compared as well. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nano-nit: Remove as well
?
a734b87
to
23f6168
Compare
Comments addressed and rebased due to conflicts. |
@jasnell It seems like something broke CITGM, would you mind taking a look? |
broke in what way? I'm on an extremely slow in flight wifi for the next 9 hours so it may be better to have someone else take a look. @nodejs/citgm |
@jasnell check the test names of the failures in e.g. https://ci.nodejs.org/view/Node.js-citgm/job/citgm-smoker/964/ |
RE: CITGM - npm was broken between #15053 and #15131 |
@refack urgs, you are right. Your CITGM fails as well though because you did not rebase to master^^ Here is a build rebased on master https://ci.nodejs.org/view/Node.js-citgm/job/citgm-smoker/967/ |
@BridgeAR ... can you rebase this? |
@jasnell I will look into this soon. I missed a fast path and I want to think about how to check that in a nice way. That is the reason I did not yet land it^^. |
23f6168
to
5ae71ae
Compare
5ae71ae
to
ddf110f
Compare
I rebased this and I refactored the code to make sure the fast paths are also checking for the symbols. This required some more changes than before. So PTAL |
Landed in db2e093 |
PR-URL: #15169 Reviewed-By: Anna Henningsen <[email protected]> Reviewed-By: Refael Ackermann <[email protected]> Reviewed-By: Luigi Pinca <[email protected]> Reviewed-By: Rich Trott <[email protected]> Reviewed-By: James M Snell <[email protected]> Reviewed-By: Tobias Nießen <[email protected]>
PR-URL: nodejs/node#15169 Reviewed-By: Anna Henningsen <[email protected]> Reviewed-By: Refael Ackermann <[email protected]> Reviewed-By: Luigi Pinca <[email protected]> Reviewed-By: Rich Trott <[email protected]> Reviewed-By: James M Snell <[email protected]> Reviewed-By: Tobias Nießen <[email protected]>
PR-URL: nodejs/node#15169 Reviewed-By: Anna Henningsen <[email protected]> Reviewed-By: Refael Ackermann <[email protected]> Reviewed-By: Luigi Pinca <[email protected]> Reviewed-By: Rich Trott <[email protected]> Reviewed-By: James M Snell <[email protected]> Reviewed-By: Tobias Nießen <[email protected]>
Adding support for enumerable symbol keys is consequent as we do compare symbols as primitives in deepEqual but we do not check them as keys.
I think this is important as I think we should try to prevent using enumerable symbols as private keys in our code and instead only use non-enumerable ones.
Checklist
make -j4 test
(UNIX), orvcbuild test
(Windows) passesAffected core subsystem(s)
assert