Improve this doc

License

AngularJS is an open source project licensed under the MIT license. Your contributions are always welcome. When working with AngularJS code base, please follow the guidelines provided on this page.

Contributing to Source Code

We'd love for you to contribute to our source code and to make AngularJS even better than it is today! Here are the guidelines we'd like you to follow:

Applying Code Standards

To ensure consistency throughout the source code, keep these rules in mind as you are working:

Checking Out and Building Angular

The AngularJS source code is hosted at Github, which we also use to accept code contributions. The AngularJS repository can be found at https://github.com/angular/angular.js.

Several steps are needed to check out and build AngularJS:

Installation Dependencies

Before you can build AngularJS, you must install or configure the following dependencies on your machine:

Creating a Github Account and Forking Angular

To create a Github account, follow the instructions here. Afterwards, go ahead and fork the main angular repository.

Building AngularJS

To build AngularJS, you check out the source code and use Grunt to generate the non-minified and minified AngularJS files:

  1. To clone your Github repository, run:

     git clone git@github.com:<github username>/angular.js.git
  2. To go to the AngularJS directory, run:

     cd angular.js
  3. To add the main AngularJS repository as an upstream remote to your repository, run:

     git remote add upstream https://github.com/angular/angular.js.git
  4. To add node.js dependencies

     npm install
  5. To add docs components

     bower install
  6. To build AngularJS, run:

     grunt package

NOTE: If you're using Windows you must run your command line with administrative privileges (right click, run as Administrator).

The build output can be located under the build directory. It consists of the following files and directories:

Running a Local Development Web Server

To debug code and run end-to-end tests, it is often useful to have a local HTTP server. For this purpose, we have made available a local web server based on Node.js.

  1. To start the web server, run:

     grunt webserver
  2. To access the local server, go to this website:

     http://localhost:8000/

    By default, it serves the contents of the AngularJS project directory.

Running the Unit Test Suite

Our unit and integration tests are written with Jasmine and executed with Karma. To run all of the tests once on Chrome run:

grunt test:unit

To run the tests on other browsers (Chrome, ChromeCanary, Firefox, Opera and Safari are pre-configured) use:

grunt test:unit --browsers Opera,Firefox

Note there should be no spaces between browsers. Opera, Firefox is INVALID.

During development it's however more productive to continuously run unit tests every time the source or test files change. To execute tests in this mode run:

  1. To start the Karma server, capture Chrome browser and run unit tests, run:

     grunt autotest:jqlite
  2. To capture more browsers, open this url in the desired browser (url might be different if you have multiple instance of Karma running, read Karma's console output for the correct url):

     http://localhost:9876/
  3. To re-run tests just change any source or test file.

To learn more about all of the preconfigured Grunt tasks run:

grunt --help

Running the end-to-end Test Suite

To run the E2E test suite:

  1. Start the local web server if it's not running already.

     grunt webserver
  2. In a browser, go to:

     http://localhost:8000/build/docs/docs-scenario.html

    or in terminal run:

     grunt test:end2end

For convenience you can also simply run:

    grunt test:e2e

This will start the webserver for you and run the tests.

Submitting Your Changes

To create and submit a change:

  1. Please sign our Contributor License Agreement (CLA) before sending pull requests. For any code changes to be accepted, the CLA must be signed. It's a quick process, we promise!

    For individuals we have a simple click-through form. For corporations we'll need you to print, sign and one of scan+email, fax or mail the form.

  1. Create and checkout a new branch off the master branch for your changes:

     git checkout -b my-fix-branch master
  2. Create your patch, make sure to have plenty of tests (that pass).

  3. Commit your changes and create a descriptive commit message (the commit message is used to generate release notes, please check out our commit message conventions and our commit message presubmit hook validate-commit-msg.js):

     git commit -a
  4. Push your branch to Github:

     git push origin my-fix-branch
  5. In Github, send a pull request to angular:master.

  1. When the patch is reviewed and merged, delete your branch and pull yours — and other — changes from the main (upstream) repository:

    1. To delete the branch in Github, run:

        git push origin :my-fix-branch
    2. To check out the master branch, run:

        git checkout master
    3. To delete a local branch, run:

        git branch -D my-fix-branch
    4. To update your master with the latest upstream version, run:

        git pull --ff upstream master

That's it! Thank you for your contribution!