From 2704f85a0f23fe75601aa50aaa159bcc44f838bb Mon Sep 17 00:00:00 2001 From: Claudio Bley Date: Mon, 27 Nov 2023 16:52:25 +0100 Subject: [PATCH] Add job summary --- .github/build-and-test | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/.github/build-and-test b/.github/build-and-test index 5276d1e6f..8b75fe7d9 100755 --- a/.github/build-and-test +++ b/.github/build-and-test @@ -90,6 +90,12 @@ run_command() { echo '::endgroup::' } +write_summary() { + if [ -v GITHUB_STEP_SUMMARY ]; then + echo "$@" >> "$GITHUB_STEP_SUMMARY" + fi +} + for dir in "${build_dirs[@]}"; do # bazel test //... fails in modules that don't define any test targets, use # bazel build in those instead. Workaround for @@ -97,6 +103,23 @@ for dir in "${build_dirs[@]}"; do run_command build $dir done +write_summary '### Test results' +write_summary '| Test | Result | Elapsed Time |' +write_summary '| ---- | :----: | ------------ |' + +declare start elapsed failed for dir in "${test_dirs[@]}"; do + start=$EPOCHSECONDS + failed=${#FAILURES[@]} run_command test $dir + elapsed=$(( EPOCHSECONDS - start )) + if [[ "$failed" < "${#FAILURES[@]}" ]]; then + write_summary "| $dir | Pass :red_circle: | $( TZ=UTC0 printf '%(%H:%M:%S)T' $elapsed ) |" + else + write_summary "| $dir | Fail :white_check_mark: | $( TZ=UTC0 printf '%(%H:%M:%S)T' $elapsed ) |" + fi done + +# Local Variables: +# mode: sh +# End: