Skip to content

Commit

Permalink
ci: silence ci test output while recording in full (#30654)
Browse files Browse the repository at this point in the history
* ci: silence ci test output while recording in full

* shellcheck

* Adjust --color handling place

* Dump to stderr...

* Reduce too spammy solana_metrics logs

* Clean up

* Tweak

* Stash actual command's exit_code, not echo's
  • Loading branch information
ryoqun authored Mar 16, 2023
1 parent 423fd60 commit aaaee55
Show file tree
Hide file tree
Showing 6 changed files with 46 additions and 12 deletions.
11 changes: 11 additions & 0 deletions .buildkite/hooks/post-command
Original file line number Diff line number Diff line change
@@ -1,11 +1,22 @@
#!/bin/bash -e

source ci/upload-ci-artifact.sh

#
# Add job_stats data point
#
if [[ -z $CI_BUILD_START ]]; then
echo Error: CI_BUILD_START empty
else
# make sure console outputs are uploaded as soon as possible, if any
(
shopt -s nullglob
for console_log in ./intercepted-console-*; do
gzip -f "$console_log"
upload-ci-artifact "$console_log.gz"
done
)

CI_BUILD_DURATION=$(( $(date +%s) - CI_BUILD_START + 1 ))

CI_LABEL=${BUILDKITE_LABEL:-build label missing}
Expand Down
22 changes: 22 additions & 0 deletions ci/intercept.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
#!/usr/bin/env bash

set -e

if [[ -n $CI && -z $NO_INTERCEPT ]]; then
console_log="./intercepted-console-$(date '+%Yy%mm%dd%Hh%Mm%Ss%Nns').log"
echo "$0: Intercepting stderr into $console_log, along side tee-d stdout."

# we don't care about being racy here as was before; so disable shellcheck
# shellcheck disable=SC2094
if "$@" 2>> "$console_log" 1>> >(tee -a "$console_log"); then
exit_code=0
else
exit_code=$?
echo "$0: command failed; please see $console_log in artifacts"
fi
exit "$exit_code"
else
# revert to noop so that this wrapper isn't so inconvenient to be used deep
# outside CI=1 land (i.e. on laptops)
"$@"
fi
3 changes: 0 additions & 3 deletions ci/test-coverage.sh
Original file line number Diff line number Diff line change
Expand Up @@ -21,9 +21,6 @@ report=coverage-"${CI_COMMIT:0:9}".tar.gz
mv target/cov/report.tar.gz "$report"
upload-ci-artifact "$report"

gzip -f target/cov/coverage-stderr.log
upload-ci-artifact target/cov/coverage-stderr.log.gz

annotate --style success --context lcov-report \
"lcov report: <a href=\"artifact://$report\">$report</a>"

Expand Down
11 changes: 6 additions & 5 deletions ci/test-stable.sh
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@ test-stable)
_ cargo test --jobs "$JOBS" --all --tests --exclude solana-local-cluster ${V:+--verbose} -- -Z unstable-options --format json --report-time | tee results.json
exit_if_error "${PIPESTATUS[0]}"
else
_ cargo test --jobs "$JOBS" --all --tests --exclude solana-local-cluster ${V:+--verbose} -- --nocapture
_ ci/intercept.sh cargo test --jobs "$JOBS" --all --tests --exclude solana-local-cluster ${V:+--verbose} -- --nocapture
fi
;;
test-stable-sbf)
Expand Down Expand Up @@ -180,7 +180,7 @@ test-local-cluster)
_ cargo test --release --package solana-local-cluster --test local_cluster ${V:+--verbose} -- --test-threads=1 -Z unstable-options --format json --report-time | tee results.json
exit_if_error "${PIPESTATUS[0]}"
else
_ cargo test --release --package solana-local-cluster --test local_cluster ${V:+--verbose} -- --nocapture --test-threads=1
_ ci/intercept.sh cargo test --release --package solana-local-cluster --test local_cluster ${V:+--verbose} -- --nocapture --test-threads=1
fi
exit 0
;;
Expand All @@ -190,7 +190,7 @@ test-local-cluster-flakey)
_ cargo test --release --package solana-local-cluster --test local_cluster_flakey ${V:+--verbose} -- --test-threads=1 -Z unstable-options --format json --report-time | tee results.json
exit_if_error "${PIPESTATUS[0]}"
else
_ cargo test --release --package solana-local-cluster --test local_cluster_flakey ${V:+--verbose} -- --nocapture --test-threads=1
_ ci/intercept.sh cargo test --release --package solana-local-cluster --test local_cluster_flakey ${V:+--verbose} -- --nocapture --test-threads=1
fi
exit 0
;;
Expand All @@ -200,7 +200,7 @@ test-local-cluster-slow-1)
_ cargo test --release --package solana-local-cluster --test local_cluster_slow_1 ${V:+--verbose} -- --test-threads=1 -Z unstable-options --format json --report-time | tee results.json
exit_if_error "${PIPESTATUS[0]}"
else
_ cargo test --release --package solana-local-cluster --test local_cluster_slow_1 ${V:+--verbose} -- --nocapture --test-threads=1
_ ci/intercept.sh cargo test --release --package solana-local-cluster --test local_cluster_slow_1 ${V:+--verbose} -- --nocapture --test-threads=1
fi
exit 0
;;
Expand All @@ -210,7 +210,7 @@ test-local-cluster-slow-2)
_ cargo test --release --package solana-local-cluster --test local_cluster_slow_2 ${V:+--verbose} -- --test-threads=1 -Z unstable-options --format json --report-time | tee results.json
exit_if_error "${PIPESTATUS[0]}"
else
_ cargo test --release --package solana-local-cluster --test local_cluster_slow_2 ${V:+--verbose} -- --nocapture --test-threads=1
_ ci/intercept.sh cargo test --release --package solana-local-cluster --test local_cluster_slow_2 ${V:+--verbose} -- --nocapture --test-threads=1
fi
exit 0
;;
Expand Down Expand Up @@ -243,6 +243,7 @@ esac

(
export CARGO_TOOLCHAIN=+"$rust_stable"
export RUST_LOG="solana_metrics=warn,info,$RUST_LOG"
echo --- ci/localnet-sanity.sh
ci/localnet-sanity.sh -x

Expand Down
7 changes: 5 additions & 2 deletions scripts/coverage.sh
Original file line number Diff line number Diff line change
Expand Up @@ -78,8 +78,11 @@ fi
NPROC=$(nproc)
JOBS=$((JOBS>NPROC ? NPROC : JOBS))

RUST_LOG=solana=trace _ "$cargo" nightly test --jobs "$JOBS" --target-dir target/cov --no-run "${packages[@]}"
if RUST_LOG=solana=trace _ "$cargo" nightly test --jobs "$JOBS" --target-dir target/cov "${packages[@]}" -- --nocapture 2> >(tee target/cov/coverage-stderr.log >&2); then
_ "$cargo" nightly test --jobs "$JOBS" --target-dir target/cov --no-run "${packages[@]}"

# most verbose log level (trace) is enabled for all solana code to make log!
# macro code green always
if RUST_LOG=solana=trace _ ci/intercept.sh "$cargo" nightly test --jobs "$JOBS" --target-dir target/cov "${packages[@]}" -- --nocapture; then
test_status=0
else
test_status=$?
Expand Down
4 changes: 2 additions & 2 deletions sdk/cargo-build-sbf/tests/crates.rs
Original file line number Diff line number Diff line change
Expand Up @@ -30,8 +30,8 @@ fn run_cargo_build(crate_name: &str, extra_args: &[&str], fail: bool) {
let mut cmd = assert_cmd::Command::cargo_bin("cargo-build-sbf").unwrap();
let assert = cmd.env("RUST_LOG", "debug").args(&args).assert();
let output = assert.get_output();
println!("Test stdout\n{}\n", String::from_utf8_lossy(&output.stdout));
println!("Test stderr\n{}\n", String::from_utf8_lossy(&output.stderr));
eprintln!("Test stdout\n{}\n", String::from_utf8_lossy(&output.stdout));
eprintln!("Test stderr\n{}\n", String::from_utf8_lossy(&output.stderr));
if fail {
assert.failure();
} else {
Expand Down

0 comments on commit aaaee55

Please sign in to comment.