2021-06-14 14:55:38 +00:00
env :
2022-03-08 19:45:41 +00:00
### compiler options
HOST :
# Specific warnings can be disabled with -Wno-error=foo.
# -pedantic-errors is not equivalent to -Werror=pedantic and thus not implied by -Werror according to the GCC manual.
WERROR_CFLAGS : -Werror -pedantic-errors
MAKEFLAGS : -j4
BUILD : check
### secp256k1 config
ECMULTWINDOW : auto
2021-06-14 14:55:38 +00:00
ECMULTGENPRECISION : auto
ASM : no
2022-03-08 19:45:41 +00:00
WIDEMUL : auto
2021-06-14 14:55:38 +00:00
WITH_VALGRIND : yes
EXTRAFLAGS :
2022-03-08 19:45:41 +00:00
### secp256k1 modules
EXPERIMENTAL : no
2021-06-14 14:55:38 +00:00
ECDH : no
RECOVERY : no
SCHNORRSIG : no
2022-03-08 19:45:41 +00:00
### test options
SECP256K1_TEST_ITERS :
2021-06-14 14:55:38 +00:00
BENCH : yes
2022-03-08 19:45:41 +00:00
SECP256K1_BENCH_ITERS : 2
CTIMETEST : yes
2021-06-14 14:55:38 +00:00
cat_logs_snippet : &CAT_LOGS
always :
cat_tests_log_script :
- cat tests.log || true
cat_exhaustive_tests_log_script :
- cat exhaustive_tests.log || true
cat_valgrind_ctime_test_log_script :
- cat valgrind_ctime_test.log || true
cat_bench_log_script :
- cat bench.log || true
on_failure :
cat_config_log_script :
- cat config.log || true
cat_test_env_script :
- cat test_env.log || true
cat_ci_env_script :
- env
merge_base_script_snippet : &MERGE_BASE
merge_base_script :
- if [ "$CIRRUS_PR" = "" ]; then exit 0; fi
- git fetch $CIRRUS_REPO_CLONE_URL $CIRRUS_BASE_BRANCH
- git config --global user.email "ci@ci.ci"
- git config --global user.name "ci"
- git merge FETCH_HEAD # Merge base to detect silent merge conflicts
2022-03-08 19:45:41 +00:00
linux_container_snippet : &LINUX_CONTAINER
2021-06-14 14:55:38 +00:00
container :
dockerfile : ci/linux-debian.Dockerfile
# Reduce number of CPUs to be able to do more builds in parallel.
cpu : 1
2022-03-08 19:45:41 +00:00
# Gives us more CPUs for free if they're available.
greedy : true
2021-06-14 14:55:38 +00:00
# More than enough for our scripts.
memory : 1G
2022-03-08 19:45:41 +00:00
task :
name : "x86_64: Linux (Debian stable)"
<< : *LINUX_CONTAINER
2021-06-14 14:55:38 +00:00
matrix : &ENV_MATRIX
- env : {WIDEMUL: int64, RECOVERY : yes }
- env : {WIDEMUL: int64, ECDH: yes, EXPERIMENTAL: yes, SCHNORRSIG : yes }
- env : {WIDEMUL : int128}
- env : {WIDEMUL: int128, RECOVERY: yes, EXPERIMENTAL: yes, SCHNORRSIG : yes }
- env : {WIDEMUL: int128, ECDH: yes, EXPERIMENTAL: yes, SCHNORRSIG : yes }
- env : {WIDEMUL: int128, ASM : x86_64}
- env : { RECOVERY: yes, EXPERIMENTAL: yes, SCHNORRSIG : yes }
- env : {BUILD: distcheck, WITH_VALGRIND: no, CTIMETEST: no, BENCH : no }
- env : {CPPFLAGS : -DDETERMINISTIC}
- env : {CFLAGS: -O0, CTIMETEST : no }
2022-03-08 19:45:41 +00:00
- env : { ECMULTGENPRECISION: 2, ECMULTWINDOW : 2 }
- env : { ECMULTGENPRECISION: 8, ECMULTWINDOW : 4 }
2021-06-14 14:55:38 +00:00
matrix :
- env :
CC : gcc
- env :
CC : clang
<< : *MERGE_BASE
test_script :
- ./ci/cirrus.sh
<< : *CAT_LOGS
task :
name : "i686: Linux (Debian stable)"
2022-03-08 19:45:41 +00:00
<< : *LINUX_CONTAINER
2021-06-14 14:55:38 +00:00
env :
HOST : i686-linux-gnu
ECDH : yes
RECOVERY : yes
EXPERIMENTAL : yes
SCHNORRSIG : yes
matrix :
- env :
CC : i686-linux-gnu-gcc
- env :
CC : clang --target=i686-pc-linux-gnu -isystem /usr/i686-linux-gnu/include
<< : *MERGE_BASE
test_script :
- ./ci/cirrus.sh
<< : *CAT_LOGS
task :
name : "x86_64: macOS Catalina"
macos_instance :
image : catalina-base
env :
HOMEBREW_NO_AUTO_UPDATE : 1
HOMEBREW_NO_INSTALL_CLEANUP : 1
# Cirrus gives us a fixed number of 12 virtual CPUs. Not that we even have that many jobs at the moment...
MAKEFLAGS : -j13
matrix :
<< : *ENV_MATRIX
matrix :
- env :
CC : gcc-9
- env :
CC : clang
# Update Command Line Tools
# Uncomment this if the Command Line Tools on the CirrusCI macOS image are too old to brew valgrind.
# See https://apple.stackexchange.com/a/195963 for the implementation.
## update_clt_script:
## - system_profiler SPSoftwareDataType
## - touch /tmp/.com.apple.dt.CommandLineTools.installondemand.in-progress
## - |-
## PROD=$(softwareupdate -l | grep "*.*Command Line" | tail -n 1 | awk -F"*" '{print $2}' | sed -e 's/^ *//' | sed 's/Label: //g' | tr -d '\n')
## # For debugging
## - softwareupdate -l && echo "PROD: $PROD"
## - softwareupdate -i "$PROD" --verbose
## - rm /tmp/.com.apple.dt.CommandLineTools.installondemand.in-progress
##
brew_valgrind_pre_script :
2022-03-08 19:45:41 +00:00
- brew update
2021-06-14 14:55:38 +00:00
- brew config
2022-03-08 19:45:41 +00:00
- brew tap LouisBrunner/valgrind
2021-06-14 14:55:38 +00:00
# Fetch valgrind source but don't build it yet.
- brew fetch --HEAD LouisBrunner/valgrind/valgrind
brew_valgrind_cache :
# This is $(brew --cellar valgrind) but command substition does not work here.
folder : /usr/local/Cellar/valgrind
# Rebuild cache if ...
fingerprint_script :
# ... macOS version changes:
- sw_vers
# ... brew changes:
- brew config
# ... valgrind changes:
- git -C "$(brew --cache)/valgrind--git" rev-parse HEAD
populate_script :
# If there's no hit in the cache, build and install valgrind.
- brew install --HEAD LouisBrunner/valgrind/valgrind
brew_valgrind_post_script :
# If we have restored valgrind from the cache, tell brew to create symlink to the PATH.
# If we haven't restored from cached (and just run brew install), this is a no-op.
- brew link valgrind
brew_script :
- brew install automake libtool gcc@9
<< : *MERGE_BASE
test_script :
- ./ci/cirrus.sh
<< : *CAT_LOGS
task :
name : "s390x (big-endian): Linux (Debian stable, QEMU)"
2022-03-08 19:45:41 +00:00
<< : *LINUX_CONTAINER
2021-06-14 14:55:38 +00:00
env :
WRAPPER_CMD : qemu-s390x
2022-03-08 19:45:41 +00:00
SECP256K1_TEST_ITERS : 16
2021-06-14 14:55:38 +00:00
HOST : s390x-linux-gnu
WITH_VALGRIND : no
ECDH : yes
RECOVERY : yes
EXPERIMENTAL : yes
SCHNORRSIG : yes
CTIMETEST : no
<< : *MERGE_BASE
test_script :
# https://sourceware.org/bugzilla/show_bug.cgi?id=27008
- rm /etc/ld.so.cache
- ./ci/cirrus.sh
<< : *CAT_LOGS
task :
name : "ARM32: Linux (Debian stable, QEMU)"
2022-03-08 19:45:41 +00:00
<< : *LINUX_CONTAINER
2021-06-14 14:55:38 +00:00
env :
WRAPPER_CMD : qemu-arm
2022-03-08 19:45:41 +00:00
SECP256K1_TEST_ITERS : 16
2021-06-14 14:55:38 +00:00
HOST : arm-linux-gnueabihf
WITH_VALGRIND : no
ECDH : yes
RECOVERY : yes
EXPERIMENTAL : yes
SCHNORRSIG : yes
CTIMETEST : no
matrix :
- env : {}
- env : {ASM : arm}
<< : *MERGE_BASE
test_script :
- ./ci/cirrus.sh
<< : *CAT_LOGS
task :
name : "ARM64: Linux (Debian stable, QEMU)"
2022-03-08 19:45:41 +00:00
<< : *LINUX_CONTAINER
2021-06-14 14:55:38 +00:00
env :
WRAPPER_CMD : qemu-aarch64
2022-03-08 19:45:41 +00:00
SECP256K1_TEST_ITERS : 16
2021-06-14 14:55:38 +00:00
HOST : aarch64-linux-gnu
WITH_VALGRIND : no
ECDH : yes
RECOVERY : yes
EXPERIMENTAL : yes
SCHNORRSIG : yes
CTIMETEST : no
<< : *MERGE_BASE
test_script :
- ./ci/cirrus.sh
<< : *CAT_LOGS
task :
name : "ppc64le: Linux (Debian stable, QEMU)"
2022-03-08 19:45:41 +00:00
<< : *LINUX_CONTAINER
2021-06-14 14:55:38 +00:00
env :
WRAPPER_CMD : qemu-ppc64le
2022-03-08 19:45:41 +00:00
SECP256K1_TEST_ITERS : 16
2021-06-14 14:55:38 +00:00
HOST : powerpc64le-linux-gnu
WITH_VALGRIND : no
ECDH : yes
RECOVERY : yes
EXPERIMENTAL : yes
SCHNORRSIG : yes
CTIMETEST : no
<< : *MERGE_BASE
test_script :
- ./ci/cirrus.sh
<< : *CAT_LOGS
task :
name : "x86_64 (mingw32-w64): Windows (Debian stable, Wine)"
2022-03-08 19:45:41 +00:00
<< : *LINUX_CONTAINER
2021-06-14 14:55:38 +00:00
env :
WRAPPER_CMD : wine64-stable
2022-03-08 19:45:41 +00:00
SECP256K1_TEST_ITERS : 16
2021-06-14 14:55:38 +00:00
HOST : x86_64-w64-mingw32
WITH_VALGRIND : no
ECDH : yes
RECOVERY : yes
EXPERIMENTAL : yes
SCHNORRSIG : yes
CTIMETEST : no
<< : *MERGE_BASE
test_script :
- ./ci/cirrus.sh
<< : *CAT_LOGS
# Sanitizers
task :
2022-03-08 19:45:41 +00:00
<< : *LINUX_CONTAINER
2021-06-14 14:55:38 +00:00
env :
ECDH : yes
RECOVERY : yes
EXPERIMENTAL : yes
SCHNORRSIG : yes
CTIMETEST : no
matrix :
- name : "Valgrind (memcheck)"
2022-03-08 19:45:41 +00:00
container :
cpu : 2
2021-06-14 14:55:38 +00:00
env :
# The `--error-exitcode` is required to make the test fail if valgrind found errors, otherwise it'll return 0 (https://www.valgrind.org/docs/manual/manual-core.html)
WRAPPER_CMD : "valgrind --error-exitcode=42"
2022-03-08 19:45:41 +00:00
SECP256K1_TEST_ITERS : 2
2021-06-14 14:55:38 +00:00
- name : "UBSan, ASan, LSan"
2022-03-08 19:45:41 +00:00
container :
memory : 2G
2021-06-14 14:55:38 +00:00
env :
2022-03-08 19:45:41 +00:00
CFLAGS : "-fsanitize=undefined,address -g"
2021-06-14 14:55:38 +00:00
UBSAN_OPTIONS : "print_stacktrace=1:halt_on_error=1"
ASAN_OPTIONS : "strict_string_checks=1:detect_stack_use_after_return=1:detect_leaks=1"
LSAN_OPTIONS : "use_unaligned=1"
2022-03-08 19:45:41 +00:00
SECP256K1_TEST_ITERS : 32
2021-06-14 14:55:38 +00:00
# Try to cover many configurations with just a tiny matrix.
matrix :
- env :
ASM : auto
- env :
ASM : no
ECMULTGENPRECISION : 2
2022-03-08 19:45:41 +00:00
ECMULTWINDOW : 2
2021-06-14 14:55:38 +00:00
matrix :
- env :
CC : clang
- env :
HOST : i686-linux-gnu
CC : i686-linux-gnu-gcc
<< : *MERGE_BASE
test_script :
- ./ci/cirrus.sh
<< : *CAT_LOGS
2022-03-08 19:45:41 +00:00
task :
name : "C++ -fpermissive"
<< : *LINUX_CONTAINER
env :
# ./configure correctly errors out when given CC=g++.
# We hack around this by passing CC=g++ only to make.
CC : gcc
MAKEFLAGS : -j4 CC=g++ CFLAGS=-fpermissive\ -g
WERROR_CFLAGS :
EXPERIMENTAL : yes
ECDH : yes
RECOVERY : yes
SCHNORRSIG : yes
<< : *MERGE_BASE
test_script :
- ./ci/cirrus.sh
<< : *CAT_LOGS