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

Add a calledOnceWithMatch assertion #2294

Merged
merged 2 commits into from
Sep 29, 2020

Conversation

richthegeek
Copy link
Contributor

@richthegeek richthegeek commented Sep 11, 2020

Purpose

This adds an assertion which combines calledOnce and calledWithMatch into calledOnceWithMatch.

Background (Problem in detail)

This is a common pattern in tests that I write:

  sinon.assert.calledOnce(stub);
  sinon.assert.calledWithMatch(stub, arg1, arg2);

It would be great to only need write:

  sinon.assert.calledOnceWithMatch(stub, arg1, arg2);

It seems like uneven coverage to combine calledOnce + calledWithExactly whilst not covering this.

However, I can see that there is a potential for temptation to add too much sugar - no-one wants a combinatorial explosion! Many libraries solve this with something like sinon.assert.calledOnce(stub).withMatch(arg1, arg2) but that's not a discussion for this PR!

Testing

I was looking through the test files and wasn't entirely sure what coverage would be appropriate here - I'm happy to essentially duplicate the calledOnceWithMatch testing if that is sufficient coverage and validation, but it feels incomplete.

Please let me know what you think.

How to verify - mandatory

  1. Check out this branch
  2. npm install
  3. npm test

Checklist for author

  • npm run lint passes
  • References to standard library functions are cached.

@mroderick mroderick requested a review from mantoni September 12, 2020 12:08
@mroderick
Copy link
Member

Thank you for the pull request!

I agree, it seems silly not to have calledOnceWithMatch when calledOnceWithExactly exists.

I'm in favour of duplication in tests, as that makes each set easy to understand (and throw out) ... as opposed to really DRY tests, that require a lot of refactoring every time there's an expansion of the API. Please go ahead with the tests 🚀

@mantoni we should synchronise the list of assertions in @sinonjs/referee-sinon once this is merged, so the new assertion can be used as referee.assert.calledOnceWithMatch.

Copy link
Member

@mantoni mantoni left a comment

Choose a reason for hiding this comment

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

I have a need for this sometimes as well. Thank you! 🙏👍

@richthegeek
Copy link
Contributor Author

I've added testing based on calledOnceWithExactly, which at least confirms it works. I changed one slightly to specifically test the "match" part. I'm happy for this to be merged 👍

@mantoni
Copy link
Member

mantoni commented Sep 16, 2020

@richthegeek Regarding your suggestion to compose assertions instead of adding too much suggar, I'd like to highlight that this is a possible alternative that works today:

const spy = sinon.spy();

spy('some test');

sinon.assert.calledWith(spy, sinon.match('test'));

@richthegeek
Copy link
Contributor Author

@matoni great 👍

I meant mostly that having calledTwiceWithExactly calledThriceWithExactly calledThriceWithMatch etc would become a bit silly and unwieldy... and so even adding calledOnceWithMatch could be crossing that line for some people.

@mantoni mantoni merged commit 154d01c into sinonjs:master Sep 29, 2020
@mantoni
Copy link
Member

mantoni commented Sep 29, 2020

Released in v9.1.0. Thank you ❤️

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants