Skip to content

Merge pull request #6939 from zcash/fix_gitian_parallel #12

Merge pull request #6939 from zcash/fix_gitian_parallel

Merge pull request #6939 from zcash/fix_gitian_parallel #12

Workflow file for this run

name: CI
on:
pull_request:
# Any update here needs to be done for `push` (see below), and mirrored into
# `no-ci.yml`.
paths-ignore:
# Workflows that have no effect on this workflow.
- '.github/dependabot.yml'
- '.github/workflows/audits.yml'
- '.github/workflows/book.yml'
- '.github/workflows/ci-skip.yml'
- '.github/workflows/lints.yml'
- '.github/workflows/release-docker-hub.yml'
# Documentation.
- 'contrib/debian/copyright'
- 'doc/**'
- '**.md'
- 'COPYING'
- 'INSTALL'
push:
branches: master
# Any update here needs to be done for `pull_request` (see above), and
# mirrored into `no-ci.yml`.
paths-ignore:
# Workflows that have no effect on this workflow.
- '.github/dependabot.yml'
- '.github/workflows/audits.yml'
- '.github/workflows/book.yml'
- '.github/workflows/ci-skip.yml'
- '.github/workflows/lints.yml'
- '.github/workflows/release-docker-hub.yml'
# Documentation.
- 'contrib/debian/copyright'
- 'doc/**'
- '**.md'
- 'COPYING'
- 'INSTALL'
permissions:
contents: read
jobs:
setup:
name: Define CI matrix
runs-on: ubuntu-latest
strategy:
matrix:
cfg:
- data:
- name: Debian-bookworm
tier: 1
platform: Debian Bookworm
build_os: ubuntu-20.04-8cores
test_os: ubuntu-20.04
container: electriccoinco/debian-helper:bookworm
host: x86_64-pc-linux-gnu
- name: Debian-bullseye
tier: 1
platform: Debian bullseye
build_os: ubuntu-20.04-8cores
test_os: ubuntu-20.04
container: electriccoinco/debian-helper:bullseye
host: x86_64-pc-linux-gnu
- name: ubuntu-20.04
tier: 1
platform: Ubuntu 20.04
build_os: ubuntu-20.04-8cores
test_os: ubuntu-20.04
host: x86_64-pc-linux-gnu
- name: ubuntu-22.04
tier: 3
platform: Ubuntu 22.04
build_os: ubuntu-22.04-8cores
test_os: ubuntu-22.04
host: x86_64-pc-linux-gnu
# - name: macos-12
# tier: 3
# platform: macOS 12 Monterey
# build_os: macos-12
# test_os: macos-12
# brew_deps: >
# autoconf
# automake
# coreutils
# libtool
# pkgconfig
# host: x86_64-apple-darwin
- name: mingw32
tier: 3
platform: Windows (64-bit MinGW)
build_os: ubuntu-22.04-8cores
test_os: windows-latest
cross_deps: >
mingw-w64
host: x86_64-w64-mingw32
file_ext: ".exe"
- name: aarch64-linux
tier: 3
platform: ARM64 Linux
build_os: ubuntu-22.04-8cores
cross_deps: >
g++-aarch64-linux-gnu
host: aarch64-linux-gnu
outputs:
build_matrix: ${{ steps.set-matrices.outputs.build_matrix }}
build_names: ${{ steps.set-matrices.outputs.build_names }}
test_matrix: ${{ steps.set-matrices.outputs.test_matrix }}
test_names: ${{ steps.set-matrices.outputs.test_names }}
unix_test_matrix: ${{ steps.set-matrices.outputs.unix_test_matrix }}
unix_test_names: ${{ steps.set-matrices.outputs.unix_test_names }}
rpc_test_matrix: ${{ steps.set-matrices.outputs.rpc_test_matrix }}
rpc_test_names: ${{ steps.set-matrices.outputs.rpc_test_names }}
rpc_test_shards: ${{ steps.set-rpc-tests.outputs.rpc_test_shards }}
rpc_test_shards_matrix: ${{ steps.set-rpc-tests.outputs.rpc_test_shards_matrix }}
steps:
- uses: actions/checkout@v4
# Configure the build and test matrices. Notes:
# - The `*_names` lists of platforms are combined with job-specific lists to build
# strategy matrices. The `*_matrix` lists then augment the matrix with parameters
# for each platform.
# - We can only run tests on the subset of platforms that have a compatible runner
# (i.e. excluding cross-compiled platforms).
# - Some tests don't currently work on Windows platforms, so we have a Unix subset.
# - We only run RPC tests on Tier 1 platforms, to save costs.
- id: set-matrices
env:
CFG: ${{ toJSON(matrix.cfg) }}
run: |
jq -r -n 'env.CFG | fromjson | @json "build_matrix=\(.data)"' >> $GITHUB_OUTPUT
jq -r -n 'env.CFG | fromjson | [.data[] | .name] | @json "build_names=\(.)"' >> $GITHUB_OUTPUT
jq -r -n 'env.CFG | fromjson | [.data[] | select(.test_os)] | @json "test_matrix=\(.)"' >> $GITHUB_OUTPUT
jq -r -n 'env.CFG | fromjson | [.data[] | select(.test_os) | .name] | @json "test_names=\(.)"' >> $GITHUB_OUTPUT
jq -r -n 'env.CFG | fromjson | [.data[] | select(.test_os and .test_os != "windows-latest")] | @json "unix_test_matrix=\(.)"' >> $GITHUB_OUTPUT
jq -r -n 'env.CFG | fromjson | [.data[] | select(.test_os and .test_os != "windows-latest") | .name] | @json "unix_test_names=\(.)"' >> $GITHUB_OUTPUT
jq -r -n 'env.CFG | fromjson | [.data[] | select(.test_os and .tier == 1)] | @json "rpc_test_matrix=\(.)"' >> $GITHUB_OUTPUT
jq -r -n 'env.CFG | fromjson | [.data[] | select(.test_os and .tier == 1) | .name] | @json "rpc_test_names=\(.)"' >> $GITHUB_OUTPUT
- id: set-rpc-tests
run: |
cat <<EOF > ./subclass.py
import importlib
import json
import os
import sys
sys.path.append('qa/pull-tester')
rpc_tests = importlib.import_module('rpc-tests')
src_dir = os.environ["SRC_DIR"]
SHARDS = 10
# These tests are ordered longest-test-first, to favor running tests in
# parallel with the regular test runner. For chunking purposes, assign
# tests to shards in round-robin order.
test_shards = {}
for i, test in enumerate(rpc_tests.BASE_SCRIPTS + rpc_tests.ZMQ_SCRIPTS):
test_shards.setdefault(i % SHARDS, []).append(test)
test_list = []
for i, tests in test_shards.items():
test_list.append({
'shard': 'shard-%d' % i,
'rpc_tests': tests,
})
# These tests involve enough shielded spends (consuming all CPU cores)
# that we can't run them in parallel, or fail intermittently so we run
# them separately to enable not requiring that they pass.
for test in rpc_tests.SERIAL_SCRIPTS + rpc_tests.FLAKY_SCRIPTS:
test_list.append({
'shard': test,
'rpc_tests': [test],
})
print(json.dumps(test_list))
EOF
RPC_MATRIX_JSON=$(echo '${{ steps.set-matrices.outputs.rpc_test_matrix }}')
RPC_SHARDS_JSON=$(SRC_DIR=$(pwd) python3 ./subclass.py)
echo "$RPC_SHARDS_JSON" | jq -r '[.[] | .shard] | @json "rpc_test_shards=\(.)"' >> $GITHUB_OUTPUT
echo -e "$RPC_MATRIX_JSON\n$RPC_SHARDS_JSON" | jq -r -s 'add | @json "rpc_test_shards_matrix=\(.)"' >> $GITHUB_OUTPUT
- name: Cache Sprout parameters
uses: actions/cache@v4
with:
path: zcash-params
key: zcash-params
restore-keys: |
zcash-params
- name: Download Sprout parameters
# In case the Sprout parameters are not currently cached
shell: bash
run: |
mkdir zcash-params || echo ""
curl -L -C - https://download.z.cash/downloads/sprout-groth16.params -o zcash-params/sprout-groth16.params
build:
name: Build tier ${{ matrix.tier }} platform ${{ matrix.platform }}
needs: setup
runs-on: ${{ matrix.build_os }}
container:
image: ${{ matrix.container }}
env:
HOME: /root
PATH: /root/.cargo/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:$PATH
continue-on-error: ${{ matrix.tier == 3 }}
strategy:
matrix:
include: ${{ fromJson(needs.setup.outputs.build_matrix) }}
steps:
- uses: actions/checkout@v4
- name: Install Homebrew build dependencies
if: matrix.brew_deps != ''
run: brew install ${{ matrix.brew_deps }}
- name: Install cross-compilation build dependencies
if: matrix.cross_deps != ''
run: sudo apt update && sudo apt install ${{ matrix.cross_deps }}
- name: Configure MinGW to use POSIX variant
if: matrix.name == 'mingw32'
run: |
sudo update-alternatives --set x86_64-w64-mingw32-gcc $(update-alternatives --query x86_64-w64-mingw32-gcc | grep Alternative | grep posix | cut -d' ' -f2)
sudo update-alternatives --set x86_64-w64-mingw32-g++ $(update-alternatives --query x86_64-w64-mingw32-g++ | grep Alternative | grep posix | cut -d' ' -f2)
- name: Cache built dependencies
uses: actions/cache@v4
with:
path: depends/built
key: ${{ matrix.name }}-built-${{ hashFiles('depends/Makefile', 'depends/funcs.mk') }}-${{ hashFiles('depends/packages/*.mk', 'depends/patches/**/*') }}
restore-keys: |
${{ matrix.name }}-built-${{ hashFiles('depends/Makefile', 'depends/funcs.mk') }}-
- name: Prepare ccache timestamp
id: ccache_cache_timestamp
shell: bash
run: echo "timestamp=$(date +'%Y-%m-%d-%H;%M;%S')" >> "$GITHUB_OUTPUT"
- name: Cache ccache files
uses: actions/cache@v4
with:
path: ${{ runner.os == 'macOS' && '~/Library/Caches/ccache' || '~/.cache/ccache' }}
key: ${{ matrix.name }}-ccache-${{ steps.ccache_cache_timestamp.outputs.timestamp }}
restore-keys: |
${{ matrix.name }}-ccache-
- name: Get the number of available processing cores
id: nproc
shell: bash
run: echo "count=$(nproc 2> /dev/null || sysctl -n hw.logicalcpu)" >> "$GITHUB_OUTPUT"
- name: Build zcashd
id: build
env:
HOST: ${{ matrix.host }}
run: >
./zcutil/build.sh
-j"${{ steps.nproc.outputs.count }}"
- name: Upload zcashd and related executables (src)
uses: actions/upload-artifact@v4
with:
name: zcashd-${{ matrix.name }}
path: |
${{ format('./src/zcashd{0}', matrix.file_ext) }}
${{ format('./src/zcash-cli{0}', matrix.file_ext) }}
${{ format('./src/zcashd-wallet-tool{0}', matrix.file_ext) }}
${{ format('./src/zcash-tx{0}', matrix.file_ext) }}
${{ format('./src/test/test_bitcoin{0}', matrix.file_ext) }}
${{ format('./src/zcash-gtest{0}', matrix.file_ext) }}
./src/test/buildenv.py
${{ format('./src/bench/bench_bitcoin{0}', matrix.file_ext) }}
- name: Upload src/secp256k1
uses: actions/upload-artifact@v4
with:
name: secp256k1-${{ matrix.name }}
path: ./src/secp256k1
- name: Upload src/univalue
uses: actions/upload-artifact@v4
with:
name: univalue-${{ matrix.name }}
path: ./src/univalue
- name: Upload depends/${{ matrix.host }}/native/bin as depends-native-bin artifact
uses: actions/upload-artifact@v4
with:
name: depends-native-bin-${{ matrix.name }}
path: ./depends/${{ matrix.host }}/native/bin
- name: Upload depends/${{ matrix.host }}/lib as depends-lib artifact
uses: actions/upload-artifact@v4
with:
name: depends-lib-${{ matrix.name }}
path: ./depends/${{ matrix.host }}/lib
bitrot:
name: Bitrot check tier ${{ matrix.tier }} platform ${{ matrix.platform }} flag '${{ matrix.configure_flag }}'
needs: [setup, build]
runs-on: ${{ matrix.build_os }}
container:
image: ${{ matrix.container }}
env:
HOME: /root
PATH: /root/.cargo/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:$PATH
continue-on-error: ${{ matrix.tier == 3 }}
strategy:
matrix:
name: ${{ fromJson(needs.setup.outputs.build_names) }}
configure_flag:
- '--with-libs'
- '--disable-wallet'
- '--disable-mining'
include: ${{ fromJson(needs.setup.outputs.build_matrix) }}
steps:
- uses: actions/checkout@v4
- name: Install Homebrew build dependencies
if: matrix.brew_deps != ''
run: brew install ${{ matrix.brew_deps }}
- name: Install cross-compilation build dependencies
if: matrix.cross_deps != ''
run: sudo apt update && sudo apt install ${{ matrix.cross_deps }}
- name: Configure MinGW to use POSIX variant
if: matrix.name == 'mingw32'
run: |
sudo update-alternatives --set x86_64-w64-mingw32-gcc $(update-alternatives --query x86_64-w64-mingw32-gcc | grep Alternative | grep posix | cut -d' ' -f2)
sudo update-alternatives --set x86_64-w64-mingw32-g++ $(update-alternatives --query x86_64-w64-mingw32-g++ | grep Alternative | grep posix | cut -d' ' -f2)
- name: Cache built dependencies
uses: actions/cache@v4
with:
path: depends/built
key: ${{ matrix.name }}-built-${{ hashFiles('depends/Makefile', 'depends/funcs.mk') }}-${{ hashFiles('depends/packages/*.mk', 'depends/patches/**/*') }}
restore-keys: |
${{ matrix.name }}-built-${{ hashFiles('depends/Makefile', 'depends/funcs.mk') }}-
- name: Prepare ccache timestamp
id: ccache_cache_timestamp
shell: bash
run: echo "timestamp=$(date +'%Y-%m-%d-%H;%M;%S')" >> "$GITHUB_OUTPUT"
- name: Cache ccache files
uses: actions/cache@v4
with:
path: ${{ runner.os == 'macOS' && '~/Library/Caches/ccache' || '~/.cache/ccache' }}
key: ${{ matrix.name }}-ccache-${{ steps.ccache_cache_timestamp.outputs.timestamp }}
restore-keys: |
${{ matrix.name }}-ccache-
- name: Get the number of available processing cores
id: nproc
shell: bash
run: echo "count=$(nproc 2> /dev/null || sysctl -n hw.logicalcpu)" >> "$GITHUB_OUTPUT"
- name: Build zcashd with the flag being checked
env:
CONFIGURE_FLAGS: "${{ matrix.configure_flag }}"
HOST: ${{ matrix.host }}
run: >
./zcutil/build.sh
-j"${{ steps.nproc.outputs.count }}"
test-btest:
name: Boost.Test tier ${{ matrix.tier }} platform ${{ matrix.platform }}
needs: [setup, build]
runs-on: ${{ matrix.test_os }}
container:
image: ${{ matrix.container }}
env:
HOME: /root
PATH: /root/.cargo/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:$PATH
continue-on-error: ${{ matrix.tier != 1 }}
strategy:
matrix:
include: ${{ fromJson(needs.setup.outputs.test_matrix) }}
steps:
- uses: actions/checkout@v4
- name: Download src artifact
uses: actions/download-artifact@v4
with:
name: zcashd-${{ matrix.name }}
path: ./src
- name: Make artifact executable
if: runner.os != 'Windows'
run: chmod +x ${{ format('./src/test/test_bitcoin{0}', matrix.file_ext) }}
- name: Run Boost.Tests
run: ${{ format('./src/test/test_bitcoin{0}', matrix.file_ext) }} -p
test-gtest:
name: GoogleTest tier ${{ matrix.tier }} platform ${{ matrix.platform }} - shard ${{ matrix.shard_index }}
needs: [setup, build]
runs-on: ${{ matrix.test_os }}
container:
image: ${{ matrix.container }}
env:
HOME: /root
PATH: /root/.cargo/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:$PATH
continue-on-error: ${{ matrix.tier != 1 }}
strategy:
matrix:
name: ${{ fromJson(needs.setup.outputs.test_names) }}
shard_index: [0, 1]
include: ${{ fromJson(needs.setup.outputs.test_matrix) }}
steps:
- uses: actions/checkout@v4
- name: Download src artifact
uses: actions/download-artifact@v4
with:
name: zcashd-${{ matrix.name }}
path: ./src
- name: Make artifact executable
if: runner.os != 'Windows'
run: chmod +x ${{ format('./src/zcash-gtest{0}', matrix.file_ext) }}
- name: Cache Sprout parameters
uses: actions/cache@v4
with:
path: zcash-params
key: zcash-params
restore-keys: |
zcash-params
- name: Download Sprout parameters
# In case the cache of Sprout parameters step fails
shell: bash
run: |
mkdir zcash-params || echo ""
curl -L -C - https://download.z.cash/downloads/sprout-groth16.params -o zcash-params/sprout-groth16.params
- name: Setup zcash-params
shell: bash
run: |
if [ "${{ runner.os }}" == "Windows" ]; then
mv zcash-params "$APPDATA/ZcashParams"
elif [ "${{ runner.os }}" == "macOS" ]; then
mv zcash-params "$HOME/Library/Application Support/ZcashParams"
elif [ "${{ runner.os }}" == "Linux" ]; then
mv zcash-params "$HOME/.zcash-params"
fi
- name: Run GoogleTests
env:
GTEST_TOTAL_SHARDS: 2
GTEST_SHARD_INDEX: ${{ matrix.shard_index }}
run: ${{ format('./src/zcash-gtest{0}', matrix.file_ext) }}
test-rust:
name: Rust test tier ${{ matrix.tier }} platform ${{ matrix.platform }}
needs: [setup, build]
runs-on: ${{ matrix.test_os }}
container:
image: ${{ matrix.container }}
env:
HOME: /root
PATH: /root/.cargo/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:$PATH
continue-on-error: ${{ matrix.tier != 1 }}
strategy:
matrix:
include: ${{ fromJson(needs.setup.outputs.test_matrix) }}
steps:
- uses: actions/checkout@v4
- name: Run Rust tests
run: cargo test
# Not designed for Windows
test-secp256k1:
name: secp256k1 tier ${{ matrix.tier }} platform ${{ matrix.platform }}
needs: [setup, build]
runs-on: ${{ matrix.test_os }}
container:
image: ${{ matrix.container }}
env:
HOME: /root
PATH: /root/.cargo/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:$PATH
continue-on-error: ${{ matrix.tier != 1 }}
strategy:
matrix:
include: ${{ fromJson(needs.setup.outputs.unix_test_matrix) }}
steps:
- uses: actions/checkout@v4
- name: Install Homebrew build dependencies
if: matrix.brew_deps != ''
run: brew install ${{ matrix.brew_deps }}
- name: Download src/secp256k1 artifact
uses: actions/download-artifact@v4
with:
name: secp256k1-${{ matrix.name }}
path: ./src/secp256k1
- name: Run secp256k1 test
shell: bash
run: python3 ./qa/zcash/full_test_suite.py secp256k1
env:
HOST: ${{ matrix.host }}
# Not designed for Windows
test-univalue:
name: univalue tier ${{ matrix.tier }} platform ${{ matrix.platform }}
needs: [setup, build]
runs-on: ${{ matrix.test_os }}
container:
image: ${{ matrix.container }}
env:
HOME: /root
PATH: /root/.cargo/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:$PATH
continue-on-error: ${{ matrix.tier != 1 }}
strategy:
matrix:
include: ${{ fromJson(needs.setup.outputs.unix_test_matrix) }}
steps:
- uses: actions/checkout@v4
- name: Install Homebrew build dependencies
if: matrix.brew_deps != ''
run: brew install ${{ matrix.brew_deps }}
- name: Download native/bin artifact
uses: actions/download-artifact@v4
with:
name: depends-native-bin-${{ matrix.name }}
path: ./depends/${{ matrix.host }}/
- name: Download src/univalue artifact
uses: actions/download-artifact@v4
with:
name: univalue-${{ matrix.name }}
path: ./src/univalue
- name: Make artifact executable
if: runner.os != 'Windows'
run: chmod +x ./src/univalue/build-aux/install-sh
- name: Run univalue test
shell: bash
run: python3 ./qa/zcash/full_test_suite.py univalue
env:
HOST: ${{ matrix.host }}
# Not designed for Windows
test-util:
name: util-test tier ${{ matrix.tier }} platform ${{ matrix.platform }}
needs: [setup, build]
runs-on: ${{ matrix.test_os }}
container:
image: ${{ matrix.container }}
env:
HOME: /root
PATH: /root/.cargo/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:$PATH
continue-on-error: ${{ matrix.tier != 1 }}
strategy:
matrix:
include: ${{ fromJson(needs.setup.outputs.unix_test_matrix) }}
steps:
- uses: actions/checkout@v4
- name: Download src artifact
uses: actions/download-artifact@v4
with:
name: zcashd-${{ matrix.name }}
path: ./src
- name: Make artifact executable
if: runner.os != 'Windows'
run: chmod +x ${{ format('./src/zcash-tx{0}', matrix.file_ext) }}
- name: Run util-test test
shell: bash
run: python3 ./qa/zcash/full_test_suite.py util-test
env:
HOST: ${{ matrix.host }}
no-dot-so:
name: no-dot-so tier ${{ matrix.tier }} platform ${{ matrix.platform }}
needs: [setup, build]
runs-on: ${{ matrix.test_os }}
container:
image: ${{ matrix.container }}
env:
HOME: /root
PATH: /root/.cargo/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:$PATH
continue-on-error: ${{ matrix.tier != 1 }}
strategy:
matrix:
include: ${{ fromJson(needs.setup.outputs.test_matrix) }}
steps:
- uses: actions/checkout@v4
- name: Download depends/${{ matrix.host }}/lib
uses: actions/download-artifact@v4
with:
name: depends-lib-${{ matrix.name }}
path: ./depends/${{ matrix.host }}/lib
- name: Run no-dot-so test
run: python3 ./qa/zcash/full_test_suite.py no-dot-so
env:
HOST: ${{ matrix.host }}
# Not working in Windows
sec-hard:
name: sec-hard tier ${{ matrix.tier }} platform ${{ matrix.platform }}
needs: [setup, build]
runs-on: ${{ matrix.test_os }}
container:
image: ${{ matrix.container }}
env:
HOME: /root
PATH: /root/.cargo/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:$PATH
continue-on-error: ${{ matrix.tier != 1 }}
strategy:
matrix:
include: ${{ fromJson(needs.setup.outputs.unix_test_matrix) }}
steps:
- uses: actions/checkout@v4
- name: Download src artifact
uses: actions/download-artifact@v4
with:
name: zcashd-${{ matrix.name }}
path: ./src
- name: Make artifact executable
if: runner.os != 'Windows'
run: |
chmod +x ${{ format('./src/test/test_bitcoin{0}', matrix.file_ext) }}
chmod +x ${{ format('./src/bench/bench_bitcoin{0}', matrix.file_ext) }}
chmod +x ${{ format('./src/zcashd{0}', matrix.file_ext) }}
chmod +x ${{ format('./src/zcash-cli{0}', matrix.file_ext) }}
chmod +x ${{ format('./src/zcash-gtest{0}', matrix.file_ext) }}
chmod +x ${{ format('./src/zcashd-wallet-tool{0}', matrix.file_ext) }}
chmod +x ${{ format('./src/zcash-tx{0}', matrix.file_ext) }}
- name: Run sec-hard test
shell: bash
run: python3 ./qa/zcash/full_test_suite.py sec-hard
env:
HOST: ${{ matrix.host }}
rpc-depends:
name: RPC set up tier ${{ matrix.tier }} platform ${{ matrix.platform }}
needs: setup
runs-on: ${{ matrix.test_os }}
container:
image: ${{ matrix.container }}
env:
HOME: /root
PATH: /root/.cargo/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:$PATH
continue-on-error: ${{ matrix.tier != 1 }}
strategy:
matrix:
name: ${{ fromJson(needs.setup.outputs.rpc_test_names) }}
include: ${{ fromJson(needs.setup.outputs.rpc_test_matrix) }}
steps:
- name: Cache Python dependencies for RPC tests
uses: actions/cache@v4
with:
enableCrossOsArchive: true
path: venv
key: test-rpc-venv-${{ matrix.name }}
- name: Get Python dependencies for RPC tests
run: |
python3 -m venv ./venv
. ./venv/bin/activate
pip install zmq asyncio base58
test-rpc:
name: RPC tests tier ${{ matrix.tier }} platform ${{ matrix.platform }} ${{ matrix.shard }}
needs: [setup, build, rpc-depends]
runs-on: ${{ matrix.test_os }}
container:
image: ${{ matrix.container }}
env:
HOME: /root
PATH: /root/.cargo/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:$PATH
continue-on-error: ${{ matrix.tier != 1 }}
strategy:
fail-fast: false
matrix:
name: ${{ fromJson(needs.setup.outputs.rpc_test_names) }}
shard : ${{ fromJson(needs.setup.outputs.rpc_test_shards) }}
include: ${{ fromJson(needs.setup.outputs.rpc_test_shards_matrix) }}
steps:
- uses: actions/checkout@v4
- name: Cache Python dependencies for RPC tests
uses: actions/cache@v4
with:
enableCrossOsArchive: true
path: venv
key: test-rpc-venv-${{ matrix.name }}
- name: Get Python dependencies for RPC tests if not cached
run: |
python3 -m venv ./venv
. ./venv/bin/activate
pip install zmq asyncio base58
- name: Download src artifact
uses: actions/download-artifact@v4
with:
name: zcashd-${{ matrix.name }}
path: ./src
- name: Make artifact executable
if: runner.os != 'Windows'
run: |
chmod +x ${{ format('./src/zcashd{0}', matrix.file_ext) }}
chmod +x ${{ format('./src/zcash-cli{0}', matrix.file_ext) }}
- name: Get Sprout parameters
uses: actions/cache@v4
with:
path: zcash-params
key: zcash-params
restore-keys: |
zcash-params
- name: Download Sprout parameters
# In case the cache of Sprout parameters step fails
shell: bash
run: |
mkdir zcash-params || echo ""
curl -L -C - https://download.z.cash/downloads/sprout-groth16.params -o zcash-params/sprout-groth16.params
- name: Setup zcash-params
shell: bash
run: |
if [ "${{ runner.os }}" == "Windows" ]; then
mv zcash-params "$APPDATA/ZcashParams"
elif [ "${{ runner.os }}" == "macOS" ]; then
mv zcash-params "$HOME/Library/Application Support/ZcashParams"
elif [ "${{ runner.os }}" == "Linux" ]; then
mv zcash-params "$HOME/.zcash-params"
fi
- name: RPC test ${{ matrix.shard }}
run: |
cat <<EOF > ./subclass.py
import importlib
import os
import subprocess
import sys
sys.path.append('qa/pull-tester')
rpc_tests = importlib.import_module('rpc-tests')
src_dir = os.environ["SRC_DIR"]
build_dir = '.'
exeext = '${{ matrix.file_ext }}'
class MyTestHandler(rpc_tests.RPCTestHandler):
def start_test(self, args, stdout, stderr):
return subprocess.Popen(
args,
universal_newlines=True,
stdout=stdout,
stderr=stderr)
test_list = ${{ toJSON(matrix.rpc_tests) }}
all_passed = rpc_tests.run_tests(MyTestHandler, test_list, src_dir, build_dir, exeext, jobs=len(test_list))
if all_passed == False:
sys.exit(1)
EOF
. ./venv/bin/activate
ZCASHD=$(pwd)/${{ format('src/zcashd{0}', matrix.file_ext) }} SRC_DIR=$(pwd) python3 ./subclass.py