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

test: wrap expectsError in mustCall #14088

Merged
merged 1 commit into from
Jul 9, 2017

Conversation

BridgeAR
Copy link
Member

@BridgeAR BridgeAR commented Jul 5, 2017

To make sure that all expectsError calls are indeed called, wrap them in mustCall.
By doing so I found one obsolete expectsError call in the tests.

I think it's nice to have the exact number of calls but having a minimum would also be good if the churn is unwanted.

Checklist
  • make -j4 test (UNIX), or vcbuild test (Windows) passes
  • tests and/or benchmarks are included
  • documentation is changed or added
  • commit message follows commit guidelines
Affected core subsystem(s)

test

@nodejs-github-bot nodejs-github-bot added the test Issues and PRs related to the tests. label Jul 5, 2017
@BridgeAR BridgeAR force-pushed the must-call-expects-error branch from 67c6580 to 9d4451d Compare July 5, 2017 14:57
@Trott
Copy link
Member

Trott commented Jul 5, 2017

@nodejs/testing

Copy link
Contributor

@refack refack left a comment

Choose a reason for hiding this comment

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

@refack
Copy link
Contributor

refack commented Jul 6, 2017

@BridgeAR
Copy link
Member Author

BridgeAR commented Jul 8, 2017

Documentation added

@refack
Copy link
Contributor

refack commented Jul 8, 2017

@refack refack self-assigned this Jul 8, 2017
@refack
Copy link
Contributor

refack commented Jul 8, 2017

@BridgeAR I've rebased at refack@0c31246 PTAL
https://ci.nodejs.org/job/node-test-commit-linuxone/7156/ 🔴 sanity test failed

@BridgeAR BridgeAR force-pushed the must-call-expects-error branch from 5d16d64 to d950beb Compare July 8, 2017 20:36
@refack
Copy link
Contributor

refack commented Jul 8, 2017

Wrap expectsError in mustCall to make sure it's really called
as expected.

PR-URL: nodejs#14088
Reviewed-By: Refael Ackermann <refack@gmail.com>
Reviewed-By: Benjamin Gruenbaum <benjamingr@gmail.com>
@refack refack force-pushed the must-call-expects-error branch from d950beb to 1b2733f Compare July 9, 2017 18:19
@refack
Copy link
Contributor

refack commented Jul 9, 2017

Extra sanity on master: https://ci.nodejs.org/job/node-test-commit-linuxone/7169/ ✔️

@refack refack merged commit 1b2733f into nodejs:master Jul 9, 2017
@jasnell
Copy link
Member

jasnell commented Jul 10, 2017

I missed this PR because I was on vacation last week. I'm not a fan of this at all and now have to go through and refactor a number of http2 tests I've written to account for this. For example, there are a couple of tests where an error might be reported and should only be checked if it actually is. For those, I've done stream.on('error', common.expectsError(...)). The semantics of that check now change entirely because common.expectsError() is now mustCall() when it previously wasn't. For those checks, expectsError() is now unusable and I end up having to check the error objects manually.

What would have been better is adding an option such that:

common.expectsError({
  code: '...',
  type: Error,
  message: '...',
  mustCall: 2});

Wherein if the mustCall option is set to a number > -1, then, and only then, would the returned function be wrapped in a common.mustCall(fn, options.mustCall)

@BridgeAR
Copy link
Member Author

@jasnell hm, instead of making the mustCall optional, I think it would be better to explicitly opt-out of that.

So maybe a good follow up PR would be to add a mustCall: false option?

@jasnell
Copy link
Member

jasnell commented Jul 10, 2017

-1 to opt out. The semantics of common.expectsError() do not automatically imply common.mustCall().

@BridgeAR
Copy link
Member Author

So far there was not a single test that was not a mustCall. I was not aware of the tests for http2 and the name expectsError somewhat imply to me that it's a mustCall.

@refack
Copy link
Contributor

refack commented Jul 10, 2017

@BridgeAR maybe only implicitly activate in the new explicit fn case.

@refack
Copy link
Contributor

refack commented Jul 10, 2017

expectsError somewhat imply to me that it's a mustCall.

Actually I agree with @BridgeAR expects is BDD for should happen.
@jasnell if it's just the extra work for http2 point to the right place, and I'll post a PR.

@jasnell
Copy link
Member

jasnell commented Jul 10, 2017

I'm already fixing the tests. It's not all bad :-) ... it did help me find a bug in a test that I accidentally had not completed 100%, but there are a couple of cases where this change is a bit unfortunate. For instance, in one case, whether or not the 'error' event is actually thrown in dependent entirely on operating system specific timings. I had been doing stream.on('error', common.expectsError({...})) to validate the error if it is emitted, but there's no guarantee that the 'error' event would be emitted. Now that test has to change because common.expectsError() is no longer usable for that scenario.

@BridgeAR
Copy link
Member Author

@jasnell as you already fixed the tests and also had a benefit because of this: do you still want to revert it?

@gibfahn
Copy link
Member

gibfahn commented Jul 11, 2017

I had been doing stream.on('error', common.expectsError({...})) to validate the error if it is emitted, but there's no guarantee that the 'error' event would be emitted.

I guess we could have an alternate function that doesn't do the mustCall for this case (e.g. common.checkError), and then have expectsError = mustCall + checkError.

@refack
Copy link
Contributor

refack commented Jul 11, 2017

I had been doing stream.on('error', common.expectsError({...})) to validate the error if it is emitted, but there's no guarantee that the 'error' event would be emitted.
I guess we could have an alternate function that doesn't do the mustCall for this case (e.g. common.checkError), and then have expectsError = mustCall + checkError.

I don't want to 👎 but it seems like the case mentioned above is an exception to the rule, and shouldn't necessitate a new method. As usual the discussion if getting fragmented #14159 (comment). Gist:

  1. All existing cases of expectsError (177 in total) we're compatible with a mustCall
  2. Exception cases could be guarded with a simple if
  3. expectsError is a kludge in general, and should be replaced with assert.deepStrictEqual (pending solution to enumeration of inherited properties)
  4. @gibfahn will enjoy his vecation! 🌴 🌞 🍾

@gibfahn
Copy link
Member

gibfahn commented Jul 11, 2017

Agreed that if it's only used in 1 or 2 places it's probably not worth pulling it out into common.

I was thinking about whether you could just use deepStrictEqual, but AIUI in expectsError you don't exhaustively check all the properties, you choose to check one or more of code, type, message. So deepStrictEqual might not work for all cases.

👎 is fine, polite disagreement is what it's there for!

@addaleax
Copy link
Member

This doesn’t land cleanly on 8.x; if you can, please follow the guide and raise a backport PR.

@MylesBorins
Copy link
Contributor

Should this be backported to v6.x-staging? If yes please follow the guide and raise a backport PR, if not let me know or add the dont-land-on label.

@BridgeAR
Copy link
Member Author

This function does not exist in v.6 so backporting is obsolete.

@refack refack removed their assignment Oct 12, 2018
@BridgeAR BridgeAR deleted the must-call-expects-error branch April 1, 2019 23:36
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
test Issues and PRs related to the tests.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

9 participants