name: CI on: pull_request: push: branches: - '**' tags-ignore: - '**' concurrency: group: ${{ github.ref }} cancel-in-progress: ${{ github.event_name == 'pull_request' }} env: ### compiler options HOST: WRAPPER_CMD: # 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' ECMULTGENPRECISION: 'auto' ASM: 'no' WIDEMUL: 'auto' WITH_VALGRIND: 'yes' EXTRAFLAGS: ### secp256k1 modules EXPERIMENTAL: 'no' ECDH: 'no' RECOVERY: 'no' SCHNORRSIG: 'no' ELLSWIFT: 'no' ### test options SECP256K1_TEST_ITERS: BENCH: 'yes' SECP256K1_BENCH_ITERS: 2 CTIMETESTS: 'yes' # Compile and run the examples. EXAMPLES: 'yes' jobs: docker_cache: name: "Build Docker image" runs-on: ubuntu-latest steps: - name: Set up Docker Buildx uses: docker/setup-buildx-action@v2 with: # See: https://github.com/moby/buildkit/issues/3969. driver-opts: | network=host - name: Build container uses: docker/build-push-action@v4 with: file: ./ci/linux-debian.Dockerfile tags: linux-debian-image cache-from: type=gha cache-to: type=gha,mode=min linux_debian: name: "x86_64: Linux (Debian stable)" runs-on: ubuntu-latest needs: docker_cache strategy: fail-fast: false matrix: configuration: - env_vars: { WIDEMUL: 'int64', RECOVERY: 'yes' } - env_vars: { WIDEMUL: 'int64', ECDH: 'yes', SCHNORRSIG: 'yes', ELLSWIFT: 'yes' } - env_vars: { WIDEMUL: 'int128' } - env_vars: { WIDEMUL: 'int128_struct', ELLSWIFT: 'yes' } - env_vars: { WIDEMUL: 'int128', RECOVERY: 'yes', SCHNORRSIG: 'yes', ELLSWIFT: 'yes' } - env_vars: { WIDEMUL: 'int128', ECDH: 'yes', SCHNORRSIG: 'yes' } - env_vars: { WIDEMUL: 'int128', ASM: 'x86_64', ELLSWIFT: 'yes' } - env_vars: { RECOVERY: 'yes', SCHNORRSIG: 'yes' } - env_vars: { CTIMETESTS: 'no', RECOVERY: 'yes', ECDH: 'yes', SCHNORRSIG: 'yes', CPPFLAGS: '-DVERIFY' } - env_vars: { BUILD: 'distcheck', WITH_VALGRIND: 'no', CTIMETESTS: 'no', BENCH: 'no' } - env_vars: { CPPFLAGS: '-DDETERMINISTIC' } - env_vars: { CFLAGS: '-O0', CTIMETESTS: 'no' } - env_vars: { CFLAGS: '-O1', RECOVERY: 'yes', ECDH: 'yes', SCHNORRSIG: 'yes', ELLSWIFT: 'yes' } - env_vars: { ECMULTGENPRECISION: 2, ECMULTWINDOW: 2 } - env_vars: { ECMULTGENPRECISION: 8, ECMULTWINDOW: 4 } cc: - 'gcc' - 'clang' - 'gcc-snapshot' - 'clang-snapshot' env: CC: ${{ matrix.cc }} steps: - name: Checkout uses: actions/checkout@v3 - name: CI script env: ${{ matrix.configuration.env_vars }} uses: ./.github/actions/run-in-docker-action with: dockerfile: ./ci/linux-debian.Dockerfile tag: linux-debian-image command: > git config --global --add safe.directory ${{ github.workspace }} && ./ci/ci.sh - run: cat tests.log || true if: ${{ always() }} - run: cat noverify_tests.log || true if: ${{ always() }} - run: cat exhaustive_tests.log || true if: ${{ always() }} - run: cat ctime_tests.log || true if: ${{ always() }} - run: cat bench.log || true if: ${{ always() }} - run: cat config.log || true if: ${{ always() }} - run: cat test_env.log || true if: ${{ always() }} - name: CI env run: env if: ${{ always() }} i686_debian: name: "i686: Linux (Debian stable)" runs-on: ubuntu-latest needs: docker_cache strategy: fail-fast: false matrix: cc: - 'i686-linux-gnu-gcc' - 'clang --target=i686-pc-linux-gnu -isystem /usr/i686-linux-gnu/include' env: HOST: 'i686-linux-gnu' ECDH: 'yes' RECOVERY: 'yes' SCHNORRSIG: 'yes' ELLSWIFT: 'yes' CC: ${{ matrix.cc }} steps: - name: Checkout uses: actions/checkout@v3 - name: CI script uses: ./.github/actions/run-in-docker-action with: dockerfile: ./ci/linux-debian.Dockerfile tag: linux-debian-image command: > git config --global --add safe.directory ${{ github.workspace }} && ./ci/ci.sh - run: cat tests.log || true if: ${{ always() }} - run: cat noverify_tests.log || true if: ${{ always() }} - run: cat exhaustive_tests.log || true if: ${{ always() }} - run: cat ctime_tests.log || true if: ${{ always() }} - run: cat bench.log || true if: ${{ always() }} - run: cat config.log || true if: ${{ always() }} - run: cat test_env.log || true if: ${{ always() }} - name: CI env run: env if: ${{ always() }} s390x_debian: name: "s390x (big-endian): Linux (Debian stable, QEMU)" runs-on: ubuntu-latest needs: docker_cache env: WRAPPER_CMD: 'qemu-s390x' SECP256K1_TEST_ITERS: 16 HOST: 's390x-linux-gnu' WITH_VALGRIND: 'no' ECDH: 'yes' RECOVERY: 'yes' SCHNORRSIG: 'yes' ELLSWIFT: 'yes' CTIMETESTS: 'no' steps: - name: Checkout uses: actions/checkout@v3 - name: CI script uses: ./.github/actions/run-in-docker-action with: dockerfile: ./ci/linux-debian.Dockerfile tag: linux-debian-image command: > git config --global --add safe.directory ${{ github.workspace }} && ./ci/ci.sh - run: cat tests.log || true if: ${{ always() }} - run: cat noverify_tests.log || true if: ${{ always() }} - run: cat exhaustive_tests.log || true if: ${{ always() }} - run: cat ctime_tests.log || true if: ${{ always() }} - run: cat bench.log || true if: ${{ always() }} - run: cat config.log || true if: ${{ always() }} - run: cat test_env.log || true if: ${{ always() }} - name: CI env run: env if: ${{ always() }} arm32_debian: name: "ARM32: Linux (Debian stable, QEMU)" runs-on: ubuntu-latest needs: docker_cache strategy: fail-fast: false matrix: configuration: - env_vars: {} - env_vars: { EXPERIMENTAL: 'yes', ASM: 'arm32' } env: WRAPPER_CMD: 'qemu-arm' SECP256K1_TEST_ITERS: 16 HOST: 'arm-linux-gnueabihf' WITH_VALGRIND: 'no' ECDH: 'yes' RECOVERY: 'yes' SCHNORRSIG: 'yes' ELLSWIFT: 'yes' CTIMETESTS: 'no' steps: - name: Checkout uses: actions/checkout@v3 - name: CI script env: ${{ matrix.configuration.env_vars }} uses: ./.github/actions/run-in-docker-action with: dockerfile: ./ci/linux-debian.Dockerfile tag: linux-debian-image command: > git config --global --add safe.directory ${{ github.workspace }} && ./ci/ci.sh - run: cat tests.log || true if: ${{ always() }} - run: cat noverify_tests.log || true if: ${{ always() }} - run: cat exhaustive_tests.log || true if: ${{ always() }} - run: cat ctime_tests.log || true if: ${{ always() }} - run: cat bench.log || true if: ${{ always() }} - run: cat config.log || true if: ${{ always() }} - run: cat test_env.log || true if: ${{ always() }} - name: CI env run: env if: ${{ always() }} mingw_debian: name: ${{ matrix.configuration.job_name }} runs-on: ubuntu-latest needs: docker_cache env: WRAPPER_CMD: 'wine' WITH_VALGRIND: 'no' ECDH: 'yes' RECOVERY: 'yes' SCHNORRSIG: 'yes' ELLSWIFT: 'yes' CTIMETESTS: 'no' strategy: fail-fast: false matrix: configuration: - job_name: 'x86_64 (mingw32-w64): Windows (Debian stable, Wine)' env_vars: HOST: 'x86_64-w64-mingw32' - job_name: 'i686 (mingw32-w64): Windows (Debian stable, Wine)' env_vars: HOST: 'i686-w64-mingw32' steps: - name: Checkout uses: actions/checkout@v3 - name: CI script env: ${{ matrix.configuration.env_vars }} uses: ./.github/actions/run-in-docker-action with: dockerfile: ./ci/linux-debian.Dockerfile tag: linux-debian-image command: > git config --global --add safe.directory ${{ github.workspace }} && ./ci/ci.sh - run: cat tests.log || true if: ${{ always() }} - run: cat noverify_tests.log || true if: ${{ always() }} - run: cat exhaustive_tests.log || true if: ${{ always() }} - run: cat ctime_tests.log || true if: ${{ always() }} - run: cat bench.log || true if: ${{ always() }} - run: cat config.log || true if: ${{ always() }} - run: cat test_env.log || true if: ${{ always() }} - name: CI env run: env if: ${{ always() }} macos-native: name: "x86_64: macOS Ventura" # See: https://github.com/actions/runner-images#available-images. runs-on: macos-13 # Use M1 once available https://github.com/github/roadmap/issues/528 env: ASM: 'no' WITH_VALGRIND: 'no' CTIMETESTS: 'no' CC: 'clang' strategy: fail-fast: false matrix: env_vars: - { WIDEMUL: 'int64', RECOVERY: 'yes', ECDH: 'yes', SCHNORRSIG: 'yes', ELLSWIFT: 'yes' } - { WIDEMUL: 'int64', RECOVERY: 'yes', ECDH: 'yes', SCHNORRSIG: 'yes', ELLSWIFT: 'yes', CC: 'gcc' } - { WIDEMUL: 'int128_struct', ECMULTGENPRECISION: 2, ECMULTWINDOW: 4 } - { WIDEMUL: 'int128', ECDH: 'yes', SCHNORRSIG: 'yes', ELLSWIFT: 'yes' } - { WIDEMUL: 'int128', RECOVERY: 'yes', SCHNORRSIG: 'yes' } - { WIDEMUL: 'int128', RECOVERY: 'yes', ECDH: 'yes', SCHNORRSIG: 'yes', ELLSWIFT: 'yes', CC: 'gcc' } - { WIDEMUL: 'int128', RECOVERY: 'yes', ECDH: 'yes', SCHNORRSIG: 'yes', ELLSWIFT: 'yes', CPPFLAGS: '-DVERIFY' } - BUILD: 'distcheck' steps: - name: Checkout uses: actions/checkout@v3 - name: Install Homebrew packages env: HOMEBREW_NO_AUTO_UPDATE: 1 HOMEBREW_NO_INSTALL_CLEANUP: 1 run: | brew install automake libtool gcc ln -s $(brew --prefix gcc)/bin/gcc-?? /usr/local/bin/gcc - name: CI script env: ${{ matrix.env_vars }} run: ./ci/ci.sh - run: cat tests.log || true if: ${{ always() }} - run: cat noverify_tests.log || true if: ${{ always() }} - run: cat exhaustive_tests.log || true if: ${{ always() }} - run: cat ctime_tests.log || true if: ${{ always() }} - run: cat bench.log || true if: ${{ always() }} - run: cat config.log || true if: ${{ always() }} - run: cat test_env.log || true if: ${{ always() }} - name: CI env run: env if: ${{ always() }} win64-native: name: ${{ matrix.configuration.job_name }} # See: https://github.com/actions/runner-images#available-images. runs-on: windows-2022 strategy: fail-fast: false matrix: configuration: - job_name: 'x64 (MSVC): Windows (VS 2022, shared)' cmake_options: '-A x64 -DBUILD_SHARED_LIBS=ON' - job_name: 'x64 (MSVC): Windows (VS 2022, static)' cmake_options: '-A x64 -DBUILD_SHARED_LIBS=OFF' - job_name: 'x64 (MSVC): Windows (VS 2022, int128_struct)' cmake_options: '-A x64 -DSECP256K1_TEST_OVERRIDE_WIDE_MULTIPLY=int128_struct' - job_name: 'x64 (MSVC): Windows (VS 2022, int128_struct with __(u)mulh)' cmake_options: '-A x64 -DSECP256K1_TEST_OVERRIDE_WIDE_MULTIPLY=int128_struct' cpp_flags: '/DSECP256K1_MSVC_MULH_TEST_OVERRIDE' - job_name: 'x86 (MSVC): Windows (VS 2022)' cmake_options: '-A Win32' steps: - name: Checkout uses: actions/checkout@v3 - name: Generate buildsystem run: cmake -E env CFLAGS="/WX ${{ matrix.configuration.cpp_flags }}" cmake -B build -DSECP256K1_ENABLE_MODULE_RECOVERY=ON -DSECP256K1_BUILD_EXAMPLES=ON ${{ matrix.configuration.cmake_options }} - name: Build run: cmake --build build --config RelWithDebInfo -- /p:UseMultiToolTask=true /maxCpuCount - name: Binaries info # Use the bash shell included with Git for Windows. shell: bash run: | cd build/src/RelWithDebInfo && file *tests.exe bench*.exe libsecp256k1-*.dll || true - name: Check run: | ctest -C RelWithDebInfo --test-dir build -j ([int]$env:NUMBER_OF_PROCESSORS + 1) build\src\RelWithDebInfo\bench_ecmult.exe build\src\RelWithDebInfo\bench_internal.exe build\src\RelWithDebInfo\bench.exe win64-native-headers: name: "x64 (MSVC): C++ (public headers)" # See: https://github.com/actions/runner-images#available-images. runs-on: windows-2022 steps: - name: Checkout uses: actions/checkout@v3 - name: Add cl.exe to PATH uses: ilammy/msvc-dev-cmd@v1 - name: C++ (public headers) run: | cl.exe -c -WX -TP include/*.h sage: name: "SageMath prover" runs-on: ubuntu-latest container: image: sagemath/sagemath:latest options: --user root steps: - name: Checkout uses: actions/checkout@v3 - name: CI script run: | cd sage sage prove_group_implementations.sage