Skip to content

Latest commit

 

History

History
116 lines (85 loc) · 2.48 KB

README.md

File metadata and controls

116 lines (85 loc) · 2.48 KB

# sinonquire

Automatically stubs CommonJS modules returned by require/import using Sinon.JS

Inspired by Jest's "mock by default" concept.

Installation

npm install --save-dev sinonquire

Usage

The following example uses mocha, chai and sinon-chai.

First, let's tell sinonquire which paths should never be loaded as stubs.

test/index.js:

import sinonquire from 'sinonquire';

sinonquire.excludePaths(
  '/node_modules/mocha/',
  '/my-app/test/'
);

Then, make sure this configuration module is started before all the tests. One way to do it is using the --require argument of mocha CLI.

package.json:

"scripts": {
  "test": "mocha --recursive --require ./test/index.js"
}

OK. Now suppose your app has two main modules, one is a class and the other is a function that instantiate the class a couple of times.

Based on this Jest example.

lib/User.js:

export default class User() {

  setName(name) {
    this.name = name;
  }

  getName() {
    return this.name;
  }

}

lib/createCouple.js:

import User from './User.js';

export default function createCouple(nameA, nameB) {
  const userA = new User();
  userA.setName(nameA);

  const userB = new User();
  userB.setName(nameB);

  return [userA, userB];
}

test/createCouple.js:

import {expect} from 'chai';
import sinonquire from 'sinonquire';

describe('createCouple', () => {

  let createCouple;

  beforeEach(() => {
    sinonquire.dontStub('../lib/createCouple.js');
    createCouple = require('../lib/createCouple.js');
  });

  afterEach(() => {
    sinonquire.resetStubs(); // needed for correct spying (eg. calls count)
  });

  it('should spy instance methods', () => {
    const couple = createCouple('userA', 'userB');
    expect(couple[0].setName).to.have.been.calledWith('userA');
    expect(couple[1].setName).to.have.been.calledWith('userB');
  });

  it('should stub instance methods', () => {
    const couple = createCouple('userA', 'userB');
    couple[0].getName.returns('something new');
    expect(couple[0].getName()).to.equal('something new');
  });

  it('should spy class instantiation', () => {
    createCouple('userA', 'userB');
    const User = require('../lib/User.js');
    expect(User).to.have.been.calledTwice;
    expect(User).to.have.been.calledWithNew;
  });

});