| # Static Analysis |
| |
| We use several tools for static analysis in chromium. |
| |
| [TOC] |
| |
| ## Autoninja Integration |
| |
| You can set `android_static_analysis = "build_server"` in your gn args to run |
| static analysis tasks in the background. This will change the build as follows: |
| * `autoninja` will not wait for static analysis jobs to complete. |
| * This means the build will succeed but static analysis might fail later. |
| * If there are background tasks still running, autoninja will say so at the end of the build. |
| * Leads to [30-50% improvement in build times][cbuild- speed improvement] when building debug. |
| * If a background static analysis task fails, the failure output is printed onto the terminal that ran `autoninja`. |
| * The output is preceded by an emoji like ⏩. |
| * If the output gets mixed in with what you are doing so it is no longer clear, you can check the task output in the logfile. |
| * E.g.: `out/Default/buildserver.log.0`. |
| * Changes the terminal title to keep live track of remaining analysis tasks. |
| |
| [cbuild- speed improvement]: https://dashboards.corp.google.com/clank_build_speed?f=commit:bt:1411615,1422246&f=benchmark:in:base_sig_compile,chrome_nosig_compile&f=server:in:true,false&f=emulator:in:None,api31 |
| |
| ## [Android Lint](lint.md) |
| * Runs as part of normal compilation. |
| * Controlled by GN arg: `disable_android_lint` (or `android_static_analysis`). |
| * [Useful checks include](https://googlesamples.github.io/android-custom-lint-rules/checks/index.md.html): |
| * `NewApi` (ensureing `Build.VERSION.SDK_INT` checks are in place). |
| * A list of disabled checks is found [within `lint.py`]. |
| * and [`lint-baseline.xml`] files contain individual suppressions. |
| * Custom lint checks [are possible], but we don't have any. |
| * Checks run on the entire codebase, not only on changed lines. |
| * Does not run when `chromium_code = false` (e.g. for `//third_party`). |
| |
| [are possible]: https://googlesamples.github.io/android-custom-lint-rules/api-guide.md.html |
| [within `lint.py`]: https://source.chromium.org/chromium/chromium/src/+/main:build/android/gyp/lint.py;l=25 |
| [`lint-baseline.xml`]: https://source.chromium.org/search?q=f:lint-baseline.xml%20-f:third_party |
| |
| ## [ErrorProne] |
| * Runs as part of normal compilation. |
| * Controlled by GN arg: `use_errorprone_java_compiler` (or |
| `android_static_analysis`). |
| * [Useful checks include]: |
| * Checking correctness of [nullable annotations] (via NullAway plugin). |
| * Enforcement of `@GuardedBy`, `@CheckReturnValue`, and `@DoNotMock`. |
| * Enforcement of `/* paramName= */` comments. |
| * A list of enabled / disabled checks is found [within `compile_java.py`] |
| * Many checks are currently disabled because there is work involved in fixing |
| violations they introduce. Please help! |
| * Chrome has [a few custom checks]. |
| * Checks run on the entire codebase, not only on changed lines. |
| * Does not run when `chromium_code = false` (e.g. for `//third_party`). |
| |
| [ErrorProne]: https://errorprone.info/ |
| [Useful checks include]: https://errorprone.info/bugpatterns |
| [nullable annotations]: /styleguide/java/nullaway.md |
| [within `compile_java.py`]: https://source.chromium.org/chromium/chromium/src/+/main:build/android/gyp/compile_java.py;l=46;drc=5dc479e73c3c9c03b59f324b2e349b8bd008401f |
| [a few custom checks]: /tools/android/errorprone_plugin/src/org/chromium/tools/errorprone/plugin/ |
| |
| ## [Checkstyle](https://checkstyle.sourceforge.io/) |
| * Mainly used for checking Java formatting & style. |
| * E.g.: Unused imports and naming conventions. |
| * Allows custom checks to be added via XML. Here [is ours]. |
| * Preferred over adding checks via `PRESUBMIT.py` because the tool understands |
| `@SuppressWarnings` annotations. |
| * Runs only on changed lines as a part of `PRESUBMIT.py`. |
| |
| [is ours]: /tools/android/checkstyle/chromium-style-5.0.xml |
| |
| ## [PRESUBMIT.py](/PRESUBMIT.py): |
| * Checks for banned patterns via `_BANNED_JAVA_FUNCTIONS`. |
| * (These should likely be moved to checkstyle). |
| * Checks for a random set of things in `ChecksAndroidSpecificOnUpload()`. |
| * Including running Checkstyle. |
| * Runs only on changed lines. |
| |
| ## [Bytecode Processor](/build/android/bytecode/) |
| * Runs as part of normal compilation. |
| * Controlled by GN arg: `android_static_analysis`. |
| * Performs a single check: |
| * Enforces that targets do not rely on indirect dependencies to populate |
| their classpath. |
| * In other words: that `deps` are not missing any entries. |