Skip to content

Commit

Permalink
Export BAZEL_TEST=1 for bazel test executables
Browse files Browse the repository at this point in the history
[Catch2][catch2] has [learnt][pr2399] how to output JUnit to the `XML_OUTPUT_FILE`. However, the upstream developers
[felt][comment] that `XML_OUTPUT_FILE` is too generic to blanket enable JUnit output to the file as there are various
XML reporters for Catch2.

This patch enables exporting `BAZEL_TEST` environment variable so that Catch2 can enable JUnit output support
unconditionally in their build when both `BAZEL_TEST` _and_ `XML_OUTPUT_FILE` are available.

[catch2]: https://github.com/catchorg/Catch2
[pr2399]: catchorg/Catch2#2399
[comment]: catchorg/Catch2#2399 (comment)

Closes bazelbuild#15393.

PiperOrigin-RevId: 447706388
  • Loading branch information
mattyclarkson authored and copybara-github committed May 10, 2022
1 parent 83ca7d1 commit 830d464
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 0 deletions.
5 changes: 5 additions & 0 deletions site/en/reference/test-encyclopedia.md
Original file line number Diff line number Diff line change
Expand Up @@ -452,6 +452,11 @@ The initial environment block shall be composed as follows:
class="external">JUnit test result schema</a>.</td>
<td>optional</td>
</tr>
<tr>
<td><code>BAZEL_TEST</code></td>
<td>Signifies test executable is being driven by <code>bazel test</code></td>
<td>required</td>
</tr>
</table>

The environment may contain additional entries. Tests should not depend on the
Expand Down
5 changes: 5 additions & 0 deletions tools/test/test-setup.sh
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,11 @@ function is_absolute {
# root.
EXEC_ROOT="$PWD"

# Declare that the executable is running in a `bazel test` environment
# This allows test frameworks to enable output to the unprefixed environment variable
# For example, if `BAZEL_TEST` and `XML_OUTPUT_FILE` are defined, write JUnit output
export BAZEL_TEST=1

# Bazel sets some environment vars to relative paths to improve caching and
# support remote execution, where the absolute path may not be known to Bazel.
# Convert them to absolute paths here before running the actual test.
Expand Down

0 comments on commit 830d464

Please sign in to comment.