commit | 09924273efc7050a2e342cd89b823a619ca073f8 | [log] [tgz] |
---|---|---|
author | mschaller <mschaller@google.com> | Tue Apr 07 20:50:28 2020 -0700 |
committer | Copybara-Service <copybara-worker@google.com> | Tue Apr 07 20:51:46 2020 -0700 |
tree | 2fd12ed348d0fca072da7eaa4a5c0668ab77fd56 | |
parent | 422b71672ade782b67f9cf0c481ceefef7b9a841 [diff] |
Support publishing FailureDetail messages for crashes Adds a startup flag, "--failure_detail_out", whose default value is "${OUTPUT_BASE}/failure_detail.rawproto". Adds a class similar to the existing class which supports writing an exit code file to the output base. This new class supports writing a serialized FailureDetail protobuf message to the "--failure_details_out" path. When Bazel handles a crash via BugReport.handleCrash, the new class is used to write a FailureDetail message describing the crash. Adds a Crash category message type to failure_details.proto. Along with a Code-style subcategory enum field, this message type specifies a repeated Throwable field to describe the java.lang.Throwable responsible for the crash, if any, and its chain of causes. This chain's length is limited to a small number: 5, for now. The number of stack trace elements described is limited to 1000 per Throwable, for now. There are still ways for Bazel to fail without reporting FailureDetail via gRPC or through the BugReport.handleCrash methods, notably during startup. Future changes will add support for emitting FailureDetail in more places. RELNOTES: None. PiperOrigin-RevId: 305398847
{Fast, Correct} - Choose two
Build and test software of any size, quickly and reliably.
Speed up your builds and tests: Bazel rebuilds only what is necessary. With advanced local and distributed caching, optimized dependency analysis and parallel execution, you get fast and incremental builds.
One tool, multiple languages: Build and test Java, C++, Android, iOS, Go, and a wide variety of other language platforms. Bazel runs on Windows, macOS, and Linux.
Scalable: Bazel helps you scale your organization, codebase, and continuous integration solution. It handles codebases of any size, in multiple repositories or a huge monorepo.
Extensible to your needs: Easily add support for new languages and platforms with Bazel's familiar extension language. Share and re-use language rules written by the growing Bazel community.
Follow our tutorials:
See CONTRIBUTING.md