mirror of
https://github.com/uutils/coreutils.git
synced 2025-12-23 08:47:37 +00:00
Some checks failed
CheckScripts / ShellScript/Check (push) Has been cancelled
CheckScripts / ShellScript/Format (push) Has been cancelled
CICD / Style/cargo-deny (push) Waiting to run
CICD / Style/deps (push) Waiting to run
CICD / Documentation/warnings (push) Waiting to run
CICD / MinRustV (push) Waiting to run
CICD / Separate Builds (push) Waiting to run
CICD / Dependencies (push) Waiting to run
CICD / Build/Makefile (push) Blocked by required conditions
CICD / Build/stable (push) Blocked by required conditions
CICD / Build/nightly (push) Blocked by required conditions
CICD / Binary sizes (push) Blocked by required conditions
CICD / Build (push) Blocked by required conditions
CICD / Tests/BusyBox test suite (push) Blocked by required conditions
CICD / Tests/Toybox test suite (push) Blocked by required conditions
CICD / Test all features separately (push) Blocked by required conditions
CICD / Code Coverage (push) Waiting to run
CICD / Build/SELinux-Stubs (Non-Linux) (push) Blocked by required conditions
CICD / Build/SELinux (push) Blocked by required conditions
CICD / Safe Traversal Security Check (push) Blocked by required conditions
GnuTests / Run GNU tests (native) (push) Waiting to run
GnuTests / Run GNU tests (SELinux) (push) Waiting to run
GnuTests / Aggregate GNU test results (push) Blocked by required conditions
Android / Test builds (push) Waiting to run
Benchmarks / Run benchmarks (CodSpeed) (push) Waiting to run
Code Quality / Style/format (push) Waiting to run
Code Quality / Style/lint (push) Waiting to run
Code Quality / Style/spelling (push) Waiting to run
Code Quality / Pre-commit hooks (push) Waiting to run
Code Quality / Style/toml (push) Waiting to run
Code Quality / Style/Python (push) Waiting to run
Devcontainer / Verify devcontainer (push) Waiting to run
FreeBSD / Style and Lint (push) Waiting to run
FreeBSD / Tests (push) Waiting to run
OpenBSD / Style and Lint (push) Waiting to run
OpenBSD / Tests (push) Waiting to run
WSL2 / Test (push) Waiting to run
125 lines
5.4 KiB
Bash
Executable file
125 lines
5.4 KiB
Bash
Executable file
#!/usr/bin/env bash
|
|
# `run-gnu-test.bash [TEST]`
|
|
# run GNU test (or all tests if TEST is missing/null)
|
|
|
|
# spell-checker:ignore (env/vars) GNULIB SRCDIR SUBDIRS OSTYPE ; (utils) shellcheck gnproc greadlink
|
|
|
|
# ref: [How the GNU coreutils are tested](https://www.pixelbeat.org/docs/coreutils-testing.html) @@ <https://archive.is/p2ITW>
|
|
# * note: to run a single test => `make check TESTS=PATH/TO/TEST/SCRIPT SUBDIRS=. VERBOSE=yes`
|
|
|
|
# Use GNU version for make, nproc, readlink on *BSD
|
|
case "$OSTYPE" in
|
|
*bsd*)
|
|
MAKE="gmake"
|
|
NPROC="gnproc"
|
|
READLINK="greadlink"
|
|
;;
|
|
*)
|
|
MAKE="make"
|
|
NPROC="nproc"
|
|
READLINK="readlink"
|
|
;;
|
|
esac
|
|
|
|
ME_dir="$(dirname -- "$("${READLINK}" -fm -- "$0")")"
|
|
REPO_main_dir="$(dirname -- "${ME_dir}")"
|
|
|
|
echo "ME_dir='${ME_dir}'"
|
|
echo "REPO_main_dir='${REPO_main_dir}'"
|
|
|
|
set -e
|
|
|
|
### * config (from environment with fallback defaults); note: GNU and GNULIB are expected to be sibling repo directories
|
|
|
|
path_UUTILS=${path_UUTILS:-${REPO_main_dir}}
|
|
path_GNU="$("${READLINK}" -fm -- "${path_GNU:-${path_UUTILS}/../gnu}")"
|
|
|
|
echo "path_UUTILS='${path_UUTILS}'"
|
|
echo "path_GNU='${path_GNU}'"
|
|
|
|
###
|
|
|
|
cd "${path_GNU}" && echo "[ pwd:'${PWD}' ]"
|
|
|
|
export RUST_BACKTRACE=1
|
|
|
|
# Determine if we have SELinux tests
|
|
has_selinux_tests=false
|
|
if test $# -ge 1; then
|
|
for t in "$@"; do
|
|
if [[ "$t" == *"selinux"* ]]; then
|
|
has_selinux_tests=true
|
|
break
|
|
fi
|
|
done
|
|
fi
|
|
|
|
if [[ "$1" == "run-tty" ]]; then
|
|
# Handle TTY tests - dynamically find tests requiring TTY and run each individually
|
|
shift
|
|
TTY_TESTS=$(grep -r "require_controlling_input_terminal" tests --include="*.sh" --include="*.pl" -l 2>/dev/null)
|
|
echo "Running TTY tests individually:"
|
|
# If a test fails, it can break the implementation of the other tty tests. By running them separately this stops the different tests from being able to break each other
|
|
for test in $TTY_TESTS; do
|
|
echo " Running: $test"
|
|
script -qec "timeout -sKILL 5m '${MAKE}' check TESTS='$test' SUBDIRS=. RUN_EXPENSIVE_TESTS=yes VERBOSE=no gl_public_submodule_commit='' srcdir='${path_GNU}'" /dev/null || :
|
|
done
|
|
exit 0
|
|
elif [[ "$1" == "run-root" && "$has_selinux_tests" == true ]]; then
|
|
# Handle SELinux root tests separately
|
|
shift
|
|
if test -n "$CI"; then
|
|
echo "Running SELinux tests as root"
|
|
# Don't use check-root here as the upstream root tests is hardcoded
|
|
sudo "${MAKE}" -j "$("${NPROC}")" check TESTS="$*" SUBDIRS=. RUN_EXPENSIVE_TESTS=yes RUN_VERY_EXPENSIVE_TESTS=yes VERBOSE=no gl_public_submodule_commit="" srcdir="${path_GNU}" TEST_SUITE_LOG="tests/test-suite-root.log" || :
|
|
fi
|
|
exit 0
|
|
elif test "$1" != "run-root" && test "$1" != "run-tty"; then
|
|
if test $# -ge 1; then
|
|
# if set, run only the tests passed
|
|
SPECIFIC_TESTS=""
|
|
for t in "$@"; do
|
|
|
|
# Construct the full path
|
|
full_path="$path_GNU/$t"
|
|
|
|
# Check if the file exists with .sh, .pl extension or without any extension in the $path_GNU directory
|
|
if [ -f "$full_path" ] || [ -f "$full_path.sh" ] || [ -f "$full_path.pl" ]; then
|
|
SPECIFIC_TESTS="$SPECIFIC_TESTS $t"
|
|
else
|
|
echo "Error: Test file $full_path, $full_path.sh, or $full_path.pl does not exist!"
|
|
exit 1
|
|
fi
|
|
done
|
|
# trim it
|
|
SPECIFIC_TESTS=$(echo "$SPECIFIC_TESTS" | xargs)
|
|
echo "Running specific tests: $SPECIFIC_TESTS"
|
|
fi
|
|
fi
|
|
|
|
# * timeout used to kill occasionally errant/"stuck" processes (note: 'release' testing takes ~1 hour; 'debug' testing takes ~2.5 hours)
|
|
# * `gl_public_submodule_commit=` disables testing for use of a "public" gnulib commit (which will fail when using shallow gnulib checkouts)
|
|
# * `srcdir=..` specifies the GNU source directory for tests (fixing failing/confused 'tests/factor/tNN.sh' tests and causing no harm to other tests)
|
|
#shellcheck disable=SC2086
|
|
|
|
if test "$1" != "run-root" && test "$1" != "run-tty"; then
|
|
# run the regular tests
|
|
if test $# -ge 1; then
|
|
timeout -sKILL 4h "${MAKE}" -j "$("${NPROC}")" check TESTS="$SPECIFIC_TESTS" SUBDIRS=. RUN_EXPENSIVE_TESTS=yes RUN_VERY_EXPENSIVE_TESTS=yes VERBOSE=no gl_public_submodule_commit="" srcdir="${path_GNU}" || : # Kill after 4 hours in case something gets stuck in make
|
|
else
|
|
timeout -sKILL 4h "${MAKE}" -j "$("${NPROC}")" check SUBDIRS=. RUN_EXPENSIVE_TESTS=yes RUN_VERY_EXPENSIVE_TESTS=yes VERBOSE=no gl_public_submodule_commit="" srcdir="${path_GNU}" || : # Kill after 4 hours in case something gets stuck in make
|
|
fi
|
|
else
|
|
# in case we would like to run tests requiring root
|
|
if test -z "$1" -o "$1" == "run-root"; then
|
|
if test -n "$CI"; then
|
|
if test $# -ge 2; then
|
|
echo "Running check-root to run only root tests"
|
|
sudo "${MAKE}" -j "$("${NPROC}")" check-root TESTS="$2" SUBDIRS=. RUN_EXPENSIVE_TESTS=yes RUN_VERY_EXPENSIVE_TESTS=yes VERBOSE=no gl_public_submodule_commit="" srcdir="${path_GNU}" TEST_SUITE_LOG="tests/test-suite-root.log" || :
|
|
else
|
|
echo "Running check-root to run only root tests"
|
|
sudo "${MAKE}" -j "$("${NPROC}")" check-root SUBDIRS=. RUN_EXPENSIVE_TESTS=yes RUN_VERY_EXPENSIVE_TESTS=yes VERBOSE=no gl_public_submodule_commit="" srcdir="${path_GNU}" TEST_SUITE_LOG="tests/test-suite-root.log" || :
|
|
fi
|
|
fi
|
|
fi
|
|
fi
|