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
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions lib/sinon/assert.js
Original file line number Diff line number Diff line change
Expand Up @@ -207,6 +207,7 @@ mirrorPropAsAssertion("alwaysCalledWith", "expected %n to always be called with
mirrorPropAsAssertion("alwaysCalledWithMatch", "expected %n to always be called with match %D");
mirrorPropAsAssertion("calledWithExactly", "expected %n to be called with exact arguments %D");
mirrorPropAsAssertion("calledOnceWithExactly", "expected %n to be called once and with exact arguments %D");
mirrorPropAsAssertion("calledOnceWithMatch", "expected %n to be called once and with match %D");
mirrorPropAsAssertion("alwaysCalledWithExactly", "expected %n to always be called with exact arguments %D");
mirrorPropAsAssertion("neverCalledWith", "expected %n to never be called with arguments %*%C");
mirrorPropAsAssertion("neverCalledWithMatch", "expected %n to never be called with match %*%C");
Expand Down
1 change: 1 addition & 0 deletions lib/sinon/proxy.js
Original file line number Diff line number Diff line change
Expand Up @@ -176,6 +176,7 @@ delegateToCalls(proxyApi, "alwaysCalledWith", false, "calledWith");
delegateToCalls(proxyApi, "alwaysCalledWithMatch", false, "calledWithMatch");
delegateToCalls(proxyApi, "calledWithExactly", true);
delegateToCalls(proxyApi, "calledOnceWithExactly", true, "calledWithExactly", false, undefined, 1);
delegateToCalls(proxyApi, "calledOnceWithMatch", true, "calledWithMatch", false, undefined, 1);
delegateToCalls(proxyApi, "alwaysCalledWithExactly", false, "calledWithExactly");
delegateToCalls(proxyApi, "neverCalledWith", false, "notCalledWith", false, function() {
return true;
Expand Down
99 changes: 99 additions & 0 deletions test/assert-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -941,6 +941,105 @@ describe("assert", function() {
});
});

describe(".calledOnceWithMatch", function() {
// eslint-disable-next-line mocha/no-setup-in-describe
requiresValidFake("calledOnceWithMatch");

it("fails when method fails", function() {
var object = {};
sinonStub(this.stub, "calledOnceWithMatch").returns(false);
var stub = this.stub;

assert.exception(function() {
sinonAssert.calledOnceWithMatch(stub, object, 1);
});

assert(this.stub.calledOnceWithMatch.calledOnceWithMatch(object, 1));
assert(sinonAssert.fail.called);
});

it("passes when method doesn't fail", function() {
var object = {};
sinonStub(this.stub, "calledOnceWithMatch").returns(true);
var stub = this.stub;

refute.exception(function() {
sinonAssert.calledOnceWithMatch(stub, object, 1);
});

assert(this.stub.calledOnceWithMatch.calledOnceWithMatch(object, 1));
assert.isFalse(sinonAssert.fail.called);
});

it("calls pass callback", function() {
this.stub("yeah");
sinonAssert.calledOnceWithMatch(this.stub, "yeah");

assert(sinonAssert.pass.calledOnce);
assert(sinonAssert.pass.calledWith("calledOnceWithMatch"));
});

it("fails when method does not exist", function() {
assert.exception(function() {
sinonAssert.calledOnceWithMatch();
});

assert(sinonAssert.fail.called);
});

it("fails when method is not stub", function() {
assert.exception(function() {
sinonAssert.calledOnceWithMatch(function() {
return;
});
});

assert(sinonAssert.fail.called);
});

it("fails when method was not called", function() {
var stub = this.stub;

assert.exception(function() {
sinonAssert.calledOnceWithMatch(stub);
});

assert(sinonAssert.fail.called);
});

it("fails when called with more than one argument", function() {
var stub = this.stub;
stub();

assert.exception(function() {
sinonAssert.calledOnceWithMatch(stub, 1);
});
});

it("passes when method was called", function() {
var stub = this.stub;
stub();

refute.exception(function() {
sinonAssert.calledOnceWithMatch(stub);
});

assert.isFalse(sinonAssert.fail.called);
});

it("fails when method was called more than once", function() {
var stub = this.stub;
stub();
stub();

assert.exception(function() {
sinonAssert.calledOnceWithMatch(stub);
});

assert(sinonAssert.fail.called);
});
});

describe(".neverCalledWith", function() {
it("fails when method fails", function() {
var object = {};
Expand Down
38 changes: 38 additions & 0 deletions test/spy-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -1314,6 +1314,44 @@ describe("spy", function() {
});
});

describe(".calledOnceWithMatch", function() {
beforeEach(function() {
this.spy = createSpy();
});

it("returns true for exact match", function() {
this.spy(1, 2, 3);

assert.isTrue(this.spy.calledOnceWithMatch(1, 2, 3));
});

it("returns true for partial match", function() {
this.spy(1, 2, 3);

assert.isTrue(this.spy.calledOnceWithMatch(1, 2));
});

it("returns false for exact parameters but called more then once", function() {
this.spy(1, 2, 3);
this.spy(1, 2, 3);

assert.isFalse(this.spy.calledOnceWithMatch(1, 2, 3));
});

it("return false for one mismatched call", function() {
this.spy(1, 2);

assert.isFalse(this.spy.calledOnceWithMatch(1, 2, 3));
});

it("return false for one mismatched call with some other", function() {
this.spy(1, 2, 3);
this.spy(1, 2);

assert.isFalse(this.spy.calledOnceWithMatch(1, 2, 3));
});
});

describe(".alwaysCalledWithExactly", function() {
beforeEach(function() {
this.spy = createSpy();
Expand Down