Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Sinon-chai calledWith(new Error()) and with exact message

I need to test this function :

   //user.js
    function getUser(req, res, next){
    helper.get_user(param1, param2, (err, file) => {
        if (err) return next(err);
    }

This is my test function :

it ("failed - helper.get_user throws error", sinon.test(function () {
    var req, res;
    var get_user = this.stub(helper, "get_user")
    get_user.yields(new Error("message"));
    var next = sinon.spy(next);
    user.get_user(req, res, next);
    expect(next).to.have.been.calledWith(new Error("other message"));
}))

For my assertion I'm using sinon-chai syntax.

This test is passing even though I would expect it to fail, because my code doesn't throw a message with the error.

How can I test that an error is thrown with correct message?

like image 890
masterG Avatar asked Feb 08 '17 17:02

masterG


3 Answers

A more complete example to complement @Alex response:

expect(next).to.have.been.calledWith(
  sinon.match.instanceOf(Error)
    .and(sinon.match.has(
      'message',
      'Some message',
    )
  )
);
like image 123
paulodiovani Avatar answered Nov 03 '22 06:11

paulodiovani


What I usually do is:

const next = stub();
someMiddleware(req, res, next);
expect(next).to.have.been.called();
const errArg = next.firstCall.args[0];
expect(errArg).to.be.instanceof(Error);
expect(errArg.message).to.equal("Your message");

Note that I am using dirty-chai to be eslint friendly.

HTH,

like image 34
Danosaure Avatar answered Nov 03 '22 07:11

Danosaure


Since you are using Sinon, you could also take advantage of the matchers. For example:

const expectedErr = { message: 'Your message' }

sinon.assert.calledWith(next, sinon.match(expectedErr))

This will check against a plain object. A more precise check would be

const expectedErr = sinon.match.instanceOf(Error)
  .and(sinon.match.has('message', 'Your message'))

sinon.assert.calledWith(next, sinon.match(expectedErr))

Check out this GitHub issue for more details.

like image 20
Alex Avatar answered Nov 03 '22 06:11

Alex