docs: update developer guide for testing and IntelliJ (#29048)

provide the command for running all test suites
- don't make new contributors read the whole Bazel doc
add info about ClangFormatIJ plugin for IntelliJ
add info about Bazel plugin for IntelliJ
fix inconsistent casing of GitHub

PR Close #29048
This commit is contained in:
Michael Prentice 2019-02-28 20:09:46 -05:00 committed by Miško Hevery
parent 7baf45fe88
commit ce789b75a4
1 changed files with 23 additions and 7 deletions

View File

@ -85,12 +85,15 @@ To build Angular run:
Bazel is used as the primary tool for building and testing Angular. Building and testing is Bazel is used as the primary tool for building and testing Angular. Building and testing is
incremental with Bazel, and it's possible to only run tests for an individual package instead incremental with Bazel, and it's possible to only run tests for an individual package instead
of for all packages. of for all packages. Read more about this in the [BAZEL.md](./BAZEL.md) document.
Read more about this in the [BAZEL.md](./BAZEL.md) document. You should execute all test suites You should execute all test suites before submitting a PR to GitHub:
before submitting a PR to Github. - `yarn bazel test packages/...`
All the tests are executed on our Continuous Integration infrastructure and a PR could only be **Note**: The first test run will be much slower than future runs. This is because future runs will
benefit from Bazel's capability to do incremental builds.
All the tests are executed on our Continuous Integration infrastructure. PRs can only be
merged if the code is formatted properly and all tests are passing. merged if the code is formatted properly and all tests are passing.
## <a name="clang-format"></a> Formatting your source code ## <a name="clang-format"></a> Formatting your source code
@ -109,6 +112,13 @@ A better way is to set up your IDE to format the changed file on each file save.
It will automatically pick up the settings from Angular's [settings.json](../.vscode/settings.json). It will automatically pick up the settings from Angular's [settings.json](../.vscode/settings.json).
### WebStorm / IntelliJ
1. Install the [ClangFormatIJ](https://plugins.jetbrains.com/plugin/8396-clangformatij) plugin
1. Open `Preferences->Tools->clang-format`
1. Find the field named "PATH"
1. Add `<PATH_TO_YOUR_WORKSPACE>/angular/node_modules/clang-format/bin/<OS>/`
where the OS options are: `darwin_x64`, `linux_x64`, and `win32`.
## Linting/verifying your source code ## Linting/verifying your source code
You can check that your code is properly formatted and adheres to coding style by running: You can check that your code is properly formatted and adheres to coding style by running:
@ -128,17 +138,17 @@ You may find that your un-merged change needs some validation from external part
Rather than requiring them to pull your Pull Request and build Angular locally, you can Rather than requiring them to pull your Pull Request and build Angular locally, you can
publish the `*-builds` snapshots just like our CircleCI build does. publish the `*-builds` snapshots just like our CircleCI build does.
First time, you need to create the github repositories: First time, you need to create the GitHub repositories:
``` shell ``` shell
$ export TOKEN=[get one from https://github.com/settings/tokens] $ export TOKEN=[get one from https://github.com/settings/tokens]
$ CREATE_REPOS=1 ./scripts/ci/publish-build-artifacts.sh [github username] $ CREATE_REPOS=1 ./scripts/ci/publish-build-artifacts.sh [GitHub username]
``` ```
For subsequent snapshots, just run For subsequent snapshots, just run
``` shell ``` shell
$ ./scripts/ci/publish-build-artifacts.sh [github username] $ ./scripts/ci/publish-build-artifacts.sh [GitHub username]
``` ```
The script will publish the build snapshot to a branch with the same name as your current branch, The script will publish the build snapshot to a branch with the same name as your current branch,
@ -148,3 +158,9 @@ and create it if it doesn't exist.
### VS Code ### VS Code
1. Install [Bazel](https://marketplace.visualstudio.com/items?itemName=DevonDCarew.bazel-code) extension for VS Code. 1. Install [Bazel](https://marketplace.visualstudio.com/items?itemName=DevonDCarew.bazel-code) extension for VS Code.
### WebStorm / IntelliJ
1. Install the [Bazel](https://plugins.jetbrains.com/plugin/8609-bazel) plugin
1. You can find the settings under `Preferences->Other Settings->Bazel Settings`
It will automatically recognize `*.bazel` and `*.bzl` files.