Improve this doc

Building and Testing AngularJS

This document describes how to set up your development environment to build and test AngularJS, and explains the basic mechanics of using git, node, npm, grunt, and bower.

See the contributing guidelines for how to contribute your own code to AngularJS.

Installing Dependencies

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

  • Git: The Github Guide to Installing Git is a good source of information.

  • Node.js: We use Node to generate the documentation, run a development web server, run tests, and generate distributable files. Depending on your system, you can install Node either from source or as a pre-packaged bundle.

  • Java: We minify JavaScript using our Closure Tools jar. Make sure you have Java (version 6 or higher) installed and included in your PATH variable.

  • Grunt: We use Grunt as our build system. Install the grunt command-line tool globally with:

  1. npm install -g grunt-cli
  • Bower: We use Bower to manage client-side packages for the docs. Install the bower command-line tool globally with:
  1. npm install -g bower

Forking Angular on Github

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

Building AngularJS

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

  1. # Clone your Github repository:
  2. git clone git@github.com:<github username>/angular.js.git
  3. # Go to the AngularJS directory:
  4. cd angular.js
  5. # Add the main AngularJS repository as an upstream remote to your repository:
  6. git remote add upstream https://github.com/angular/angular.js.git
  7. # Install node.js dependencies:
  8. npm install
  9. # Install bower components:
  10. bower install
  11. # Build AngularJS:
  12. grunt package

Note: If you're using Windows, you must use an elevated command prompt (right click, run as Administrator). This is because grunt package creates some symbolic links.

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

  • angular-.zip — The complete zip file, containing all of the release build artifacts.

  • angular.js — The non-minified angular script.

  • angular.min.js — The minified angular script.

  • angular-scenario.js — The angular End2End test runner.

  • docs/ — A directory that contains all of the files needed to run docs.angularjs.org.

  • docs/index.html — The main page for the documentation.

  • docs/docs-scenario.html — The End2End test runner for the documentation application.

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.

  • To start the web server, run:
  1. grunt webserver
  • To access the local server, enter the following URL into your web browser:
  1. http://localhost:8000/

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

Running the Unit Test Suite

We write unit and integration tests with Jasmine and execute them with Karma. To run all of the tests once on Chrome run:

  1. grunt test:unit

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

  1. 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:

  • To start the Karma server, capture Chrome browser and run unit tests, run:
  1. grunt autotest
  • 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):
  1. http://localhost:9876/
  • To re-run tests just change any source or test file.

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

  1. grunt --help

Running the End-to-end Test Suite

Simply run:

  1. grunt test:e2e

This will start the webserver and run the tests.