Skip to content
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: show diff when doing partial comparisons with a custom message #56211

Conversation

puskin94
Copy link
Contributor

@puskin94 puskin94 commented Dec 10, 2024

following the same reasoning as this PR:

right now the method assert.partialDeepStrictEqual does not show the diff when the assertion fails.
With this PR we go from this:

const assert = require('assert');

assert.partialDeepStrictEqual([1, 2, 3, 5], [4, 5]);
image

to this
image

with a custom error message:

image

Relevant changes:

  1. enabled the diff when assert.partialDeepStrictEqual fails
  2. enabled the diff when assert.partialDeepStrictEqual fails with a custom error message
  3. added different diff style in case assert.partialDeepStrictEqual fails:
  • properties available in actual are gray
  • properties in expected but not in actual are prefixed with the classic red -
  • properties present in both actual and expected are white

@nodejs-github-bot nodejs-github-bot added assert Issues and PRs related to the assert subsystem. needs-ci PRs that need a full CI run. labels Dec 10, 2024
@BridgeAR
Copy link
Member

How to show the diff for the partial implementation has been one of my main concerns for a while and my current idea is to grey out or hide all lines that are not in the expected object. That way it would be more straight forward for the user.

Copy link

codecov bot commented Dec 10, 2024

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 88.54%. Comparing base (3851edf) to head (0018ef3).
Report is 168 commits behind head on main.

Additional details and impacted files
@@            Coverage Diff             @@
##             main   #56211      +/-   ##
==========================================
+ Coverage   88.49%   88.54%   +0.04%     
==========================================
  Files         656      657       +1     
  Lines      189261   190668    +1407     
  Branches    36348    36595     +247     
==========================================
+ Hits       167493   168833    +1340     
- Misses      14977    15019      +42     
- Partials     6791     6816      +25     
Files with missing lines Coverage Δ
lib/assert.js 99.37% <100.00%> (+0.27%) ⬆️
lib/internal/assert/assertion_error.js 95.44% <100.00%> (+0.07%) ⬆️
lib/internal/assert/myers_diff.js 90.05% <100.00%> (+0.23%) ⬆️

... and 75 files with indirect coverage changes

@puskin94 puskin94 marked this pull request as draft December 10, 2024 19:21
@puskin94 puskin94 force-pushed the partial-deep-strict-equal-custom-message-diff branch 2 times, most recently from e2f640c to e4b2307 Compare December 11, 2024 13:17
@puskin94 puskin94 marked this pull request as ready for review December 11, 2024 13:18
@puskin94 puskin94 force-pushed the partial-deep-strict-equal-custom-message-diff branch from e4b2307 to 3db0829 Compare December 11, 2024 13:24
@puskin94
Copy link
Contributor Author

Is there anything left to be done here?

Copy link
Member

@BridgeAR BridgeAR left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM!

Let's see how people react to the greyed out part to gather feedback while it's experimental. I feel it is nicer than the green plus.

test/pseudo-tty/test-assert-no-color.js Outdated Show resolved Hide resolved
@BridgeAR BridgeAR added the request-ci Add this label to start a Jenkins CI on a PR. label Dec 21, 2024
@github-actions github-actions bot removed the request-ci Add this label to start a Jenkins CI on a PR. label Dec 21, 2024
@nodejs-github-bot
Copy link
Collaborator

@puskin94 puskin94 force-pushed the partial-deep-strict-equal-custom-message-diff branch from 3db0829 to 9f449e9 Compare December 21, 2024 21:05
@puskin94 puskin94 force-pushed the partial-deep-strict-equal-custom-message-diff branch from 9f449e9 to 0018ef3 Compare December 28, 2024 08:22
@puskin94
Copy link
Contributor Author

puskin94 commented Jan 2, 2025

Is anything else needed here?

Copy link
Member

@BridgeAR BridgeAR left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Still LGTM

@BridgeAR BridgeAR added the request-ci Add this label to start a Jenkins CI on a PR. label Jan 5, 2025
@github-actions github-actions bot removed the request-ci Add this label to start a Jenkins CI on a PR. label Jan 5, 2025
@nodejs-github-bot
Copy link
Collaborator

@nodejs-github-bot
Copy link
Collaborator

@BridgeAR BridgeAR added the commit-queue Add this label to land a pull request using GitHub Actions. label Jan 6, 2025
@nodejs-github-bot nodejs-github-bot added commit-queue-failed An error occurred while landing this pull request using GitHub Actions. and removed commit-queue Add this label to land a pull request using GitHub Actions. labels Jan 6, 2025
@nodejs-github-bot
Copy link
Collaborator

Commit Queue failed
- Loading data for nodejs/node/pull/56211
✔  Done loading data for nodejs/node/pull/56211
----------------------------------- PR info ------------------------------------
Title      assert: show diff when doing partial comparisons with a custom message (#56211)
   ⚠  Could not retrieve the email or name of the PR author's from user's GitHub profile!
Branch     puskin94:partial-deep-strict-equal-custom-message-diff -> nodejs:main
Labels     assert, needs-ci
Commits    1
 - assert: show diff when doing partial comparisons
Committers 1
 - Giovanni <github@puskin.it>
PR-URL: /~https://github.com/nodejs/node/pull/56211
Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de>
------------------------------ Generated metadata ------------------------------
PR-URL: /~https://github.com/nodejs/node/pull/56211
Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de>
--------------------------------------------------------------------------------
   ℹ  This PR was created on Tue, 10 Dec 2024 15:24:35 GMT
   ✔  Approvals: 1
   ✔  - Ruben Bridgewater (@BridgeAR) (TSC): /~https://github.com/nodejs/node/pull/56211#pullrequestreview-2530930488
   ✘  Last GitHub CI failed
   ℹ  Last Full PR CI on 2025-01-06T16:25:01Z: https://ci.nodejs.org/job/node-test-pull-request/64369/
- Querying data for job/node-test-pull-request/64369/
   ✔  Last Jenkins CI successful
--------------------------------------------------------------------------------
   ✔  Aborted `git node land` session in /home/runner/work/node/node/.ncu
/~https://github.com/nodejs/node/actions/runs/12638165059

@pmarchini pmarchini added commit-queue Add this label to land a pull request using GitHub Actions. and removed commit-queue-failed An error occurred while landing this pull request using GitHub Actions. labels Jan 8, 2025
@nodejs-github-bot nodejs-github-bot removed the commit-queue Add this label to land a pull request using GitHub Actions. label Jan 8, 2025
@nodejs-github-bot nodejs-github-bot merged commit 799d920 into nodejs:main Jan 8, 2025
69 checks passed
@nodejs-github-bot
Copy link
Collaborator

Landed in 799d920

targos pushed a commit that referenced this pull request Jan 13, 2025
PR-URL: #56211
Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de>
Ceres6 pushed a commit to Ceres6/node that referenced this pull request Jan 13, 2025
PR-URL: nodejs#56211
Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
assert Issues and PRs related to the assert subsystem. needs-ci PRs that need a full CI run.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants