2019-01-31 16:28:02 -05:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
#
|
2023-10-03 16:38:56 +02:00
|
|
|
# Copyright (c) 2018-present The Bitcoin Core developers
|
2019-01-31 16:28:02 -05:00
|
|
|
# Distributed under the MIT software license, see the accompanying
|
|
|
|
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
|
|
|
|
export LC_ALL=C.UTF-8
|
|
|
|
|
2023-05-04 18:40:01 +02:00
|
|
|
set -ex
|
|
|
|
|
2024-08-16 15:32:43 +02:00
|
|
|
export ASAN_OPTIONS="detect_leaks=1:detect_stack_use_after_return=1:check_initialization_order=1:strict_init_order=1"
|
2023-06-26 15:41:27 +02:00
|
|
|
export LSAN_OPTIONS="suppressions=${BASE_ROOT_DIR}/test/sanitizer_suppressions/lsan"
|
2024-11-06 10:59:18 +00:00
|
|
|
export TSAN_OPTIONS="suppressions=${BASE_ROOT_DIR}/test/sanitizer_suppressions/tsan:halt_on_error=1:second_deadlock_stack=1"
|
2023-06-26 15:41:27 +02:00
|
|
|
export UBSAN_OPTIONS="suppressions=${BASE_ROOT_DIR}/test/sanitizer_suppressions/ubsan:print_stacktrace=1:halt_on_error=1:report_error_type=1"
|
|
|
|
|
2024-09-20 11:32:40 +02:00
|
|
|
echo "Number of available processing units: $(nproc)"
|
2023-05-10 13:49:27 +02:00
|
|
|
if [ "$CI_OS_NAME" == "macos" ]; then
|
|
|
|
top -l 1 -s 0 | awk ' /PhysMem/ {print}'
|
|
|
|
else
|
2023-05-10 14:05:36 +02:00
|
|
|
free -m -h
|
2023-10-03 16:38:56 +02:00
|
|
|
echo "System info: $(uname --kernel-name --kernel-release)"
|
2023-07-06 11:14:52 +02:00
|
|
|
lscpu
|
2023-05-10 13:49:27 +02:00
|
|
|
fi
|
2023-05-10 14:05:36 +02:00
|
|
|
echo "Free disk space:"
|
|
|
|
df -h
|
2023-05-10 13:49:27 +02:00
|
|
|
|
2023-07-17 12:30:12 +02:00
|
|
|
# What host to compile for. See also ./depends/README.md
|
|
|
|
# Tests that need cross-compilation export the appropriate HOST.
|
|
|
|
# Tests that run natively guess the host
|
|
|
|
export HOST=${HOST:-$("$BASE_ROOT_DIR/depends/config.guess")}
|
|
|
|
|
2024-09-11 13:08:14 +02:00
|
|
|
echo "=== BEGIN env ==="
|
|
|
|
env
|
|
|
|
echo "=== END env ==="
|
|
|
|
|
2023-08-28 21:32:41 +02:00
|
|
|
(
|
|
|
|
# compact->outputs[i].file_size is uninitialized memory, so reading it is UB.
|
|
|
|
# The statistic bytes_written is only used for logging, which is disabled in
|
|
|
|
# CI, so as a temporary minimal fix to work around UB and CI failures, leave
|
|
|
|
# bytes_written unmodified.
|
|
|
|
# See https://github.com/bitcoin/bitcoin/pull/28359#issuecomment-1698694748
|
2024-02-21 10:02:21 -05:00
|
|
|
# Tee patch to stdout to make it clear CI is testing modified code.
|
|
|
|
tee >(patch -p1) <<'EOF'
|
2023-08-28 21:32:41 +02:00
|
|
|
--- a/src/leveldb/db/db_impl.cc
|
|
|
|
+++ b/src/leveldb/db/db_impl.cc
|
|
|
|
@@ -1028,9 +1028,6 @@ Status DBImpl::DoCompactionWork(CompactionState* compact) {
|
|
|
|
stats.bytes_read += compact->compaction->input(which, i)->file_size;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
- for (size_t i = 0; i < compact->outputs.size(); i++) {
|
|
|
|
- stats.bytes_written += compact->outputs[i].file_size;
|
|
|
|
- }
|
|
|
|
|
|
|
|
mutex_.Lock();
|
2024-02-21 10:02:21 -05:00
|
|
|
stats_[compact->compaction->level() + 1].Add(stats);
|
|
|
|
EOF
|
2023-08-28 21:32:41 +02:00
|
|
|
)
|
|
|
|
|
2023-05-10 13:49:27 +02:00
|
|
|
if [ "$RUN_FUZZ_TESTS" = "true" ]; then
|
2024-09-03 20:37:46 +02:00
|
|
|
export DIR_FUZZ_IN=${DIR_QA_ASSETS}/fuzz_corpora/
|
2023-05-10 13:49:27 +02:00
|
|
|
if [ ! -d "$DIR_FUZZ_IN" ]; then
|
2023-10-09 17:19:34 +02:00
|
|
|
${CI_RETRY_EXE} git clone --depth=1 https://github.com/bitcoin-core/qa-assets "${DIR_QA_ASSETS}"
|
2023-05-10 13:49:27 +02:00
|
|
|
fi
|
2023-05-22 10:03:31 +02:00
|
|
|
(
|
|
|
|
cd "${DIR_QA_ASSETS}"
|
|
|
|
echo "Using qa-assets repo from commit ..."
|
|
|
|
git log -1
|
|
|
|
)
|
2023-05-10 13:49:27 +02:00
|
|
|
elif [ "$RUN_UNIT_TESTS" = "true" ] || [ "$RUN_UNIT_TESTS_SEQUENTIAL" = "true" ]; then
|
|
|
|
export DIR_UNIT_TEST_DATA=${DIR_QA_ASSETS}/unit_test_data/
|
|
|
|
if [ ! -d "$DIR_UNIT_TEST_DATA" ]; then
|
2023-05-10 14:05:36 +02:00
|
|
|
mkdir -p "$DIR_UNIT_TEST_DATA"
|
2023-08-18 14:17:00 +02:00
|
|
|
${CI_RETRY_EXE} curl --location --fail https://github.com/bitcoin-core/qa-assets/raw/main/unit_test_data/script_assets_test.json -o "${DIR_UNIT_TEST_DATA}/script_assets_test.json"
|
2023-05-10 13:49:27 +02:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ "$USE_BUSY_BOX" = "true" ]; then
|
|
|
|
echo "Setup to use BusyBox utils"
|
|
|
|
# tar excluded for now because it requires passing in the exact archive type in ./depends (fixed in later BusyBox version)
|
|
|
|
# ar excluded for now because it does not recognize the -q option in ./depends (unknown if fixed)
|
2023-05-10 14:05:36 +02:00
|
|
|
for util in $(busybox --list | grep -v "^ar$" | grep -v "^tar$" ); do ln -s "$(command -v busybox)" "${BINS_SCRATCH_DIR}/$util"; done
|
2023-05-10 13:49:27 +02:00
|
|
|
# Print BusyBox version
|
2023-05-10 14:05:36 +02:00
|
|
|
patch --help
|
2023-05-10 13:49:27 +02:00
|
|
|
fi
|
|
|
|
|
|
|
|
# Make sure default datadir does not exist and is never read by creating a dummy file
|
|
|
|
if [ "$CI_OS_NAME" == "macos" ]; then
|
|
|
|
echo > "${HOME}/Library/Application Support/Bitcoin"
|
|
|
|
else
|
2023-05-10 14:05:36 +02:00
|
|
|
echo > "${HOME}/.bitcoin"
|
2023-05-10 13:49:27 +02:00
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -z "$NO_DEPENDS" ]; then
|
|
|
|
if [[ $CI_IMAGE_NAME_TAG == *centos* ]]; then
|
2023-05-15 14:36:44 +02:00
|
|
|
SHELL_OPTS="CONFIG_SHELL=/bin/dash"
|
2023-05-10 13:49:27 +02:00
|
|
|
else
|
|
|
|
SHELL_OPTS="CONFIG_SHELL="
|
|
|
|
fi
|
2023-05-10 14:05:36 +02:00
|
|
|
bash -c "$SHELL_OPTS make $MAKEJOBS -C depends HOST=$HOST $DEP_OPTS LOG=1"
|
2023-05-10 13:49:27 +02:00
|
|
|
fi
|
|
|
|
if [ "$DOWNLOAD_PREVIOUS_RELEASES" = "true" ]; then
|
2023-05-10 14:05:36 +02:00
|
|
|
test/get_previous_releases.py -b -t "$PREVIOUS_RELEASES_DIR"
|
2023-05-10 13:49:27 +02:00
|
|
|
fi
|
|
|
|
|
2024-07-24 11:54:41 +01:00
|
|
|
BITCOIN_CONFIG_ALL="-DBUILD_BENCH=ON -DBUILD_FUZZ_BINARY=ON"
|
2023-05-10 13:49:27 +02:00
|
|
|
if [ -z "$NO_DEPENDS" ]; then
|
2024-07-24 11:54:41 +01:00
|
|
|
BITCOIN_CONFIG_ALL="${BITCOIN_CONFIG_ALL} -DCMAKE_TOOLCHAIN_FILE=$DEPENDS_DIR/$HOST/toolchain.cmake"
|
2023-05-10 13:49:27 +02:00
|
|
|
fi
|
|
|
|
if [ -z "$NO_WERROR" ]; then
|
2024-07-24 11:54:41 +01:00
|
|
|
BITCOIN_CONFIG_ALL="${BITCOIN_CONFIG_ALL} -DWERROR=ON"
|
2023-05-10 13:49:27 +02:00
|
|
|
fi
|
|
|
|
|
2023-07-30 21:36:56 +01:00
|
|
|
ccache --zero-stats
|
2023-05-10 13:49:27 +02:00
|
|
|
PRINT_CCACHE_STATISTICS="ccache --version | head -n 1 && ccache --show-stats"
|
|
|
|
|
2024-07-24 11:54:41 +01:00
|
|
|
# Folder where the build is done.
|
|
|
|
BASE_BUILD_DIR=${BASE_BUILD_DIR:-$BASE_SCRATCH_DIR/build-$HOST}
|
2023-05-10 14:05:36 +02:00
|
|
|
mkdir -p "${BASE_BUILD_DIR}"
|
|
|
|
cd "${BASE_BUILD_DIR}"
|
2023-05-10 13:49:27 +02:00
|
|
|
|
2024-07-24 11:54:41 +01:00
|
|
|
BITCOIN_CONFIG_ALL="$BITCOIN_CONFIG_ALL -DENABLE_EXTERNAL_SIGNER=ON -DCMAKE_INSTALL_PREFIX=$BASE_OUTDIR"
|
2023-05-10 13:49:27 +02:00
|
|
|
|
|
|
|
if [[ "${RUN_TIDY}" == "true" ]]; then
|
2024-07-24 11:54:41 +01:00
|
|
|
BITCOIN_CONFIG_ALL="$BITCOIN_CONFIG_ALL -DCMAKE_EXPORT_COMPILE_COMMANDS=ON"
|
2023-05-10 13:49:27 +02:00
|
|
|
fi
|
|
|
|
|
2024-09-07 14:38:14 +01:00
|
|
|
bash -c "cmake -S $BASE_ROOT_DIR $BITCOIN_CONFIG_ALL $BITCOIN_CONFIG || ( (cat $(cmake -P "${BASE_ROOT_DIR}/ci/test/GetCMakeLogFiles.cmake")) && false)"
|
2024-07-24 11:54:41 +01:00
|
|
|
|
2024-09-07 14:28:28 +01:00
|
|
|
bash -c "cmake --build . $MAKEJOBS --target all $GOAL" || ( echo "Build failure. Verbose build follows." && cmake --build . --target all "$GOAL" --verbose ; false )
|
2023-05-10 13:49:27 +02:00
|
|
|
|
2023-05-10 14:05:36 +02:00
|
|
|
bash -c "${PRINT_CCACHE_STATISTICS}"
|
|
|
|
du -sh "${DEPENDS_DIR}"/*/
|
|
|
|
du -sh "${PREVIOUS_RELEASES_DIR}"
|
2023-05-10 13:49:27 +02:00
|
|
|
|
2020-11-09 10:17:00 +01:00
|
|
|
if [[ $HOST = *-mingw32 ]]; then
|
2023-05-04 18:40:01 +02:00
|
|
|
"${BASE_ROOT_DIR}/ci/test/wrap-wine.sh"
|
2020-11-09 10:17:00 +01:00
|
|
|
fi
|
|
|
|
|
2019-11-15 11:38:27 -05:00
|
|
|
if [ -n "$USE_VALGRIND" ]; then
|
2023-05-04 18:40:01 +02:00
|
|
|
"${BASE_ROOT_DIR}/ci/test/wrap-valgrind.sh"
|
2019-11-15 11:38:27 -05:00
|
|
|
fi
|
|
|
|
|
2024-07-25 09:07:20 -04:00
|
|
|
if [ "$RUN_CHECK_DEPS" = "true" ]; then
|
|
|
|
"${BASE_ROOT_DIR}/contrib/devtools/check-deps.sh" .
|
|
|
|
fi
|
|
|
|
|
2019-01-31 16:28:02 -05:00
|
|
|
if [ "$RUN_UNIT_TESTS" = "true" ]; then
|
2024-11-08 13:06:51 -05:00
|
|
|
DIR_UNIT_TEST_DATA="${DIR_UNIT_TEST_DATA}" LD_LIBRARY_PATH="${DEPENDS_DIR}/${HOST}/lib" CTEST_OUTPUT_ON_FAILURE=ON ctest --stop-on-failure "${MAKEJOBS}" --timeout $(( TEST_RUNNER_TIMEOUT_FACTOR * 60 ))
|
2019-01-31 16:28:02 -05:00
|
|
|
fi
|
|
|
|
|
2020-04-08 22:20:52 +08:00
|
|
|
if [ "$RUN_UNIT_TESTS_SEQUENTIAL" = "true" ]; then
|
2023-11-28 13:51:18 +01:00
|
|
|
DIR_UNIT_TEST_DATA="${DIR_UNIT_TEST_DATA}" LD_LIBRARY_PATH="${DEPENDS_DIR}/${HOST}/lib" "${BASE_OUTDIR}"/bin/test_bitcoin --catch_system_errors=no -l test_suite
|
2020-04-08 22:20:52 +08:00
|
|
|
fi
|
|
|
|
|
2019-01-31 16:28:02 -05:00
|
|
|
if [ "$RUN_FUNCTIONAL_TESTS" = "true" ]; then
|
2024-06-07 13:11:45 +01:00
|
|
|
# parses TEST_RUNNER_EXTRA as an array which allows for multiple arguments such as TEST_RUNNER_EXTRA='--exclude "rpc_bind.py --ipv6"'
|
|
|
|
eval "TEST_RUNNER_EXTRA=($TEST_RUNNER_EXTRA)"
|
|
|
|
LD_LIBRARY_PATH="${DEPENDS_DIR}/${HOST}/lib" test/functional/test_runner.py --ci "${MAKEJOBS}" --tmpdirprefix "${BASE_SCRATCH_DIR}"/test_runner/ --ansi --combinedlogslen=99999999 --timeout-factor="${TEST_RUNNER_TIMEOUT_FACTOR}" "${TEST_RUNNER_EXTRA[@]}" --quiet --failfast
|
2019-01-31 16:28:02 -05:00
|
|
|
fi
|
2019-01-16 11:49:01 -05:00
|
|
|
|
2022-04-04 11:00:09 +02:00
|
|
|
if [ "${RUN_TIDY}" = "true" ]; then
|
2023-07-20 16:19:48 +01:00
|
|
|
cmake -B /tidy-build -DLLVM_DIR=/usr/lib/llvm-"${TIDY_LLVM_V}"/cmake -DCMAKE_BUILD_TYPE=Release -S "${BASE_ROOT_DIR}"/contrib/devtools/bitcoin-tidy
|
2022-07-19 15:51:47 +01:00
|
|
|
cmake --build /tidy-build "$MAKEJOBS"
|
|
|
|
cmake --build /tidy-build --target bitcoin-tidy-tests "$MAKEJOBS"
|
|
|
|
|
2022-07-26 16:24:28 +01:00
|
|
|
set -eo pipefail
|
2024-07-24 11:54:41 +01:00
|
|
|
cd "${BASE_BUILD_DIR}/src/"
|
2023-12-15 17:01:06 +01:00
|
|
|
if ! ( run-clang-tidy-"${TIDY_LLVM_V}" -quiet -load="/tidy-build/libbitcoin-tidy.so" "${MAKEJOBS}" | tee tmp.tidy-out.txt ); then
|
|
|
|
grep -C5 "error: " tmp.tidy-out.txt
|
|
|
|
echo "^^^ ⚠️ Failure generated from clang-tidy"
|
|
|
|
false
|
|
|
|
fi
|
2023-05-04 13:40:06 +02:00
|
|
|
# Filter out:
|
|
|
|
# * qt qrc and moc generated files
|
2024-07-24 11:54:41 +01:00
|
|
|
jq 'map(select(.file | test("src/qt/qrc_.*\\.cpp$|/moc_.*\\.cpp$") | not))' "${BASE_BUILD_DIR}/compile_commands.json" > tmp.json
|
|
|
|
mv tmp.json "${BASE_BUILD_DIR}/compile_commands.json"
|
|
|
|
cd "${BASE_ROOT_DIR}"
|
2023-07-31 09:57:26 +01:00
|
|
|
python3 "/include-what-you-use/iwyu_tool.py" \
|
2024-07-24 11:54:41 +01:00
|
|
|
-p "${BASE_BUILD_DIR}" "${MAKEJOBS}" \
|
|
|
|
-- -Xiwyu --cxx17ns -Xiwyu --mapping_file="${BASE_ROOT_DIR}/contrib/devtools/iwyu/bitcoin.core.imp" \
|
2023-05-20 13:16:26 +01:00
|
|
|
-Xiwyu --max_line_length=160 \
|
2023-05-04 18:40:01 +02:00
|
|
|
2>&1 | tee /tmp/iwyu_ci.out
|
|
|
|
cd "${BASE_ROOT_DIR}/src"
|
2023-07-31 09:57:26 +01:00
|
|
|
python3 "/include-what-you-use/fix_includes.py" --nosafe_headers < /tmp/iwyu_ci.out
|
2023-05-04 18:40:01 +02:00
|
|
|
git --no-pager diff
|
2022-04-04 11:00:09 +02:00
|
|
|
fi
|
|
|
|
|
2019-01-16 11:49:01 -05:00
|
|
|
if [ "$RUN_FUZZ_TESTS" = "true" ]; then
|
2023-11-28 13:51:18 +01:00
|
|
|
# shellcheck disable=SC2086
|
|
|
|
LD_LIBRARY_PATH="${DEPENDS_DIR}/${HOST}/lib" test/fuzz/test_runner.py ${FUZZ_TESTS_CONFIG} "${MAKEJOBS}" -l DEBUG "${DIR_FUZZ_IN}" --empty_min_time=60
|
2019-01-16 11:49:01 -05:00
|
|
|
fi
|