2.2 KiB
Contributing Guide
Contributing to angular-moment
is fairly easy. This document shows you how to
get the project, run all provided tests and generate a production ready build.
It also covers provided grunt tasks, that help you developing on angular-moment
.
Dependencies
To make sure, that the following instructions work, please install the following dependencies on you machine:
- Node.js
- npm
- Git
If you install node through the binary installation file, npm will be already there. When npm is installed, use it to install the needed npm packages:
npm install -g grunt-cli bower
Installation
To get the source of angular-moment
clone the git repository via:
git clone https://github.com/urish/angular-moment
This will clone the complete source to your local machine. Navigate to the project folder and install all needed dependencies via npm:
npm install
Then install all the needed client-side dependencies via bower:
bower install
angular-moment
is now installed and ready to be built.
Building
angular-moment
comes with a few grunt tasks which help you to automate
the development process. The following grunt tasks are provided:
grunt test
grunt test
executes (as you might thought) the unit tests, which are located
in tests.js
. The task uses the karma test runner to executes the tests with
the jasmine testing framework. This task also checks the coding using jshint.
grunt build
grunt build
updates the minified version of the code (angular-moment.min.js). It also
checks the code using jshint.
Contributing/Submitting changes
- Checkout a new branch based on
master
and name it to what you intend to do:- Example:
$ git checkout -b BRANCH_NAME
- Use one branch per fix/feature
- Example:
- Make your changes
- Make sure to provide a spec for unit tests (in
tests.js
) - Run your tests with
grunt test
- When all tests pass, everything's fine
- Make sure to provide a spec for unit tests (in
- Commit your changes
- Please provide a git message which explains what you've done
- Commit to the forked repository
- Make a pull request
If you follow these instructions, your PR will land pretty safety in the main repo!