We love pull requests. Here's a quick guide:
-
Fork the repo.
-
Run the tests. We only take pull requests with passing tests, and it's great to know that you have a clean slate
-
Add a test for your change. Only refactoring and documentation changes require no new tests. If you are adding functionality or fixing a bug, we need a test!
-
Make the test pass.
-
Push to your fork and submit a pull request.
At this point you're waiting on us. We like to at least comment on, if not accept, pull requests within three business days (and, typically, one business day). We may suggest some changes or improvements or alternatives.
- Use JavaScript idioms
- Include tests that fail without your code, and pass with it
- Update the documentation, the surrounding one, examples elsewhere, guides, whatever is affected by your contribution
And in case we didn't emphasize it enough: we love tests!
Install Editor Config for your text editor, this will ensure that the correct formatting is applied for each file type.
There are grunt tasks for helping with linting and testing the codebase.
The tests are implemented using BusterJS and the excellent Sinon.JS. All dependencies can be installed with npm install
(assuming you already have nodejs installed).
$ grunt lint
If you have PhantomJS installed on your system, you can run the Buster tests by running
$ grunt test
or by running
$ npm test