| # Contributing | 
|   | 
| Thanks for your interest in contributing! The advice below will help you get your issue fixed / pull request merged. | 
|   | 
|   | 
| ## Purpose | 
|   | 
| Nunjucks has the following purpose: | 
|   | 
| * Aim for templating feature parity with Jinja2. | 
| * Aim for templating feature parity with Twig, but only when not conflicting with Jinja2 parity. | 
| * Works in all node releases that are | 
|   [actively maintained by the Node Foundation](https://github.com/nodejs/Release#release-schedule) | 
| * Works in all modern browsers (with [ES5 support](http://kangax.github.io/compat-table/es5/)). | 
| * Works in IE8 with [es5-shim](https://github.com/es-shims/es5-shim). | 
| * Keep footprint browser files as small as possible (save on bandwidth, download time). | 
| * Keep performance as fast as possible (see benchmarks). | 
| * Keep maintenance as easy as possible (avoid complexity, automate what we can). | 
|   | 
| Notes: | 
|   | 
| * We don't aim for parity of all language specific syntax. | 
| * We don't aim for parity of language specific filters like [Twig's PHP date format](http://twig.sensiolabs.org/doc/functions/date.html). | 
|   | 
| Issues and pull requests contributing to this purpose have the best chance to make it into Nunjucks. | 
|   | 
|   | 
| ## Questions? | 
|   | 
| Please DO NOT ask "how do I?" or usage questions via GitHub issues. Instead, | 
| use the [mailing list](https://groups.google.com/forum/#!forum/nunjucks). | 
|   | 
|   | 
| ## Submitting Issues | 
|   | 
| Issues are easier to reproduce/resolve when they have: | 
|   | 
| - A pull request with a failing test demonstrating the issue | 
| - A code example that produces the issue consistently | 
| - A traceback (when applicable) | 
|   | 
|   | 
| ## Pull Requests | 
|   | 
| When creating a pull request: | 
|   | 
| - Write tests (see below). | 
| - Note user-facing changes in the [`CHANGELOG.md`](CHANGELOG.md) file. | 
| - Update the documentation (in [`docs/`](docs/)) as needed. | 
|   | 
|   | 
| ## Testing | 
|   | 
| Please add tests for any changes you submit. The tests should fail before your | 
| code changes, and pass with your changes. Existing tests should not break. Test | 
| coverage (output at the end of every test run) should never decrease after your | 
| changes. | 
|   | 
| To install all the requirements for running the tests: | 
|   | 
| ```bash | 
| npm install | 
| ``` | 
|   | 
| To run the tests: | 
|   | 
| ```bash | 
| npm test | 
| ``` |