/cashmere

A Javascript testing library

Primary LanguageJavaScriptMIT LicenseMIT

cashmere

A javascript testing library.

Warning: Install at your own peril! This project is brand new and nowhere near ready!

Important: All test files must end in .test.js, the runner executes a find command with that extension

Note: As specified in engines, Node >=6.4.0 is required as ES6 Proxies are currently being used

Note: If you run the tests for cashmere, some of them fail intentionally to show FAIL output

To install:

yarn add cashmere
or
npm install cashmere

Here is an example of a test person.test.js:

describe('person', () => {
  context('#firstName()', () => {
    it('Should get first name', () => {
      expect({ hello: 'world' }).to.deep.equal({ hello: 'world' });
    });

    it('Should get middle name', () => {
      expect(1).to.equal(1);
    });
  });
});

Note that you don't have to import anything, including expect.

Here is an example of an asynchronous test websites.test.js:

describe('websites', () => {
  it.async('Facebook', (done, request) => {
    request.get('https://www.facebook.com', (err, res) => {
      expect(err).to.equal(null);
      expect(res.statusCode).to.equal(200);
      done();
    });
  });

  it.async('Halis Technology', (done, request) => {
    request.get('https://www.halistechnology.com', (err, res) => {
      expect(err).to.equal(null);
      expect(res.statusCode).to.equal(200);
      done();
    });
  });
});

For async tests it's it.async instead of it. Note that you don't have to import anything, including request.

Current Features

  • Unit tests
  • Mocha style describe/context/it
  • Async tests (brand new so use at your own peril)
  • Automatically compiles tests written in ES6
  • No special unicode characters in test output that don't display correctly in CI servers
  • No hiding logging statements
  • Clean stack traces
  • Diff output

Future Goals

  • Performance (may need parallel runs at some point)
  • Setup a global Redux-like store and have access to it from every test
  • Experiment with different testing styles
  • Probably need to store the output of asynchronous tests until done is called and then flush it all to the console at once

Note: In the tests you DO NOT need to import the following:

  • describe
  • context
  • it
  • expect
  • request
  • By
  • until

These are provided for you by default.

If you are using ESLint then put the following in your .eslintrc:

  "globals": {
    "expect": true
  },
  "env": {
    "mocha": true
  }

Note: This all works on Mac right now, Windows support could be added at some point