perf(tree): worker pooling for storage in multiproof generation #49970
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: lint | |
on: | |
pull_request: | |
merge_group: | |
push: | |
branches: [main] | |
env: | |
CARGO_TERM_COLOR: always | |
jobs: | |
clippy-binaries: | |
name: clippy binaries / ${{ matrix.type }} | |
runs-on: ubuntu-latest | |
timeout-minutes: 30 | |
strategy: | |
matrix: | |
include: | |
- type: ethereum | |
args: --workspace --lib --examples --tests --benches --locked | |
features: "ethereum asm-keccak jemalloc jemalloc-prof min-error-logs min-warn-logs min-info-logs min-debug-logs min-trace-logs" | |
steps: | |
- uses: actions/checkout@v5 | |
- uses: rui314/setup-mold@v1 | |
- uses: dtolnay/rust-toolchain@clippy | |
with: | |
components: clippy | |
- uses: Swatinem/rust-cache@v2 | |
with: | |
cache-on-failure: true | |
- if: "${{ matrix.type == 'book' }}" | |
uses: arduino/setup-protoc@v3 | |
with: | |
repo-token: ${{ secrets.GITHUB_TOKEN }} | |
- name: Run clippy on binaries | |
run: cargo clippy ${{ matrix.args }} --features "${{ matrix.features }}" | |
env: | |
RUSTFLAGS: -D warnings | |
clippy: | |
name: clippy | |
runs-on: ubuntu-latest | |
timeout-minutes: 30 | |
steps: | |
- uses: actions/checkout@v5 | |
- uses: rui314/setup-mold@v1 | |
- uses: dtolnay/rust-toolchain@nightly | |
with: | |
components: clippy | |
- uses: Swatinem/rust-cache@v2 | |
with: | |
cache-on-failure: true | |
- run: cargo clippy --workspace --lib --examples --tests --benches --all-features --locked | |
env: | |
RUSTFLAGS: -D warnings | |
wasm: | |
runs-on: ubuntu-latest | |
timeout-minutes: 30 | |
steps: | |
- uses: actions/checkout@v5 | |
- uses: rui314/setup-mold@v1 | |
- uses: dtolnay/rust-toolchain@stable | |
with: | |
target: wasm32-wasip1 | |
- uses: taiki-e/install-action@cargo-hack | |
- uses: Swatinem/rust-cache@v2 | |
with: | |
cache-on-failure: true | |
- uses: dcarbone/install-jq-action@v3 | |
- name: Run Wasm checks | |
run: | | |
sudo apt update && sudo apt install gcc-multilib | |
.github/assets/check_wasm.sh | |
riscv: | |
runs-on: ubuntu-latest | |
timeout-minutes: 60 | |
steps: | |
- uses: actions/checkout@v5 | |
- uses: rui314/setup-mold@v1 | |
- uses: dtolnay/rust-toolchain@stable | |
with: | |
target: riscv32imac-unknown-none-elf | |
- uses: taiki-e/install-action@cargo-hack | |
- uses: Swatinem/rust-cache@v2 | |
with: | |
cache-on-failure: true | |
- uses: dcarbone/install-jq-action@v3 | |
- name: Run RISC-V checks | |
run: .github/assets/check_rv32imac.sh | |
crate-checks: | |
runs-on: ubuntu-latest | |
timeout-minutes: 30 | |
steps: | |
- uses: actions/checkout@v5 | |
- uses: rui314/setup-mold@v1 | |
- uses: dtolnay/rust-toolchain@stable | |
- uses: taiki-e/install-action@cargo-hack | |
- uses: Swatinem/rust-cache@v2 | |
with: | |
cache-on-failure: true | |
- run: cargo hack check --workspace | |
msrv: | |
name: MSRV | |
runs-on: ubuntu-latest | |
timeout-minutes: 30 | |
strategy: | |
matrix: | |
include: | |
- binary: reth | |
- binary: op-reth | |
steps: | |
- uses: actions/checkout@v5 | |
- uses: rui314/setup-mold@v1 | |
- uses: dtolnay/rust-toolchain@master | |
with: | |
toolchain: "1.88" # MSRV | |
- uses: Swatinem/rust-cache@v2 | |
with: | |
cache-on-failure: true | |
- run: cargo build --bin "${{ matrix.binary }}" --workspace | |
env: | |
RUSTFLAGS: -D warnings | |
docs: | |
name: docs | |
runs-on: ubuntu-latest | |
timeout-minutes: 30 | |
steps: | |
- uses: actions/checkout@v5 | |
- uses: rui314/setup-mold@v1 | |
- uses: dtolnay/rust-toolchain@nightly | |
- uses: Swatinem/rust-cache@v2 | |
with: | |
cache-on-failure: true | |
- run: cargo docs --document-private-items | |
env: | |
# Keep in sync with ./book.yml:jobs.build | |
# This should only add `-D warnings` | |
RUSTDOCFLAGS: --cfg docsrs --show-type-layout --generate-link-to-definition --enable-index-page -Zunstable-options -D warnings | |
fmt: | |
name: fmt | |
runs-on: ubuntu-latest | |
timeout-minutes: 30 | |
steps: | |
- uses: actions/checkout@v5 | |
- uses: rui314/setup-mold@v1 | |
- uses: dtolnay/rust-toolchain@nightly | |
with: | |
components: rustfmt | |
- name: Run fmt | |
run: cargo fmt --all --check | |
udeps: | |
name: udeps | |
runs-on: ubuntu-latest | |
timeout-minutes: 30 | |
steps: | |
- uses: actions/checkout@v5 | |
- uses: rui314/setup-mold@v1 | |
- uses: dtolnay/rust-toolchain@nightly | |
- uses: Swatinem/rust-cache@v2 | |
with: | |
cache-on-failure: true | |
- uses: taiki-e/install-action@cargo-udeps | |
- run: cargo udeps --workspace --lib --examples --tests --benches --all-features --locked | |
book: | |
name: book | |
runs-on: ubuntu-latest | |
timeout-minutes: 30 | |
steps: | |
- uses: actions/checkout@v5 | |
- uses: rui314/setup-mold@v1 | |
- uses: dtolnay/rust-toolchain@nightly | |
- uses: Swatinem/rust-cache@v2 | |
with: | |
cache-on-failure: true | |
- run: cargo build --bin reth --workspace --features ethereum | |
env: | |
RUSTFLAGS: -D warnings | |
- run: ./docs/cli/update.sh target/debug/reth | |
- name: Check docs changes | |
run: git diff --exit-code | |
typos: | |
runs-on: ubuntu-latest | |
timeout-minutes: 30 | |
steps: | |
- uses: actions/checkout@v5 | |
- uses: crate-ci/typos@v1 | |
check-toml: | |
runs-on: ubuntu-latest | |
timeout-minutes: 30 | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v5 | |
- name: Run dprint | |
uses: dprint/check@v2.3 | |
with: | |
config-path: dprint.json | |
grafana: | |
runs-on: ubuntu-latest | |
timeout-minutes: 30 | |
steps: | |
- uses: actions/checkout@v5 | |
- name: Check dashboard JSON with jq | |
uses: sergeysova/jq-action@v2 | |
with: | |
cmd: jq empty etc/grafana/dashboards/overview.json | |
no-test-deps: | |
runs-on: ubuntu-latest | |
timeout-minutes: 30 | |
steps: | |
- uses: actions/checkout@v5 | |
- uses: rui314/setup-mold@v1 | |
- uses: dtolnay/rust-toolchain@stable | |
- name: Ensure no arbitrary or proptest dependency on default build | |
run: cargo tree --package reth -e=features,no-dev | grep -Eq "arbitrary|proptest" && exit 1 || exit 0 | |
# Checks that selected rates can compile with power set of features | |
features: | |
name: features | |
runs-on: ubuntu-latest | |
timeout-minutes: 30 | |
steps: | |
- uses: actions/checkout@v5 | |
- uses: rui314/setup-mold@v1 | |
- uses: dtolnay/rust-toolchain@clippy | |
- uses: Swatinem/rust-cache@v2 | |
with: | |
cache-on-failure: true | |
- name: cargo install cargo-hack | |
uses: taiki-e/install-action@cargo-hack | |
- run: make check-features | |
env: | |
RUSTFLAGS: -D warnings | |
# Check crates correctly propagate features | |
feature-propagation: | |
runs-on: ubuntu-latest | |
timeout-minutes: 20 | |
steps: | |
- uses: actions/checkout@v5 | |
- uses: dtolnay/rust-toolchain@stable | |
- uses: rui314/setup-mold@v1 | |
- uses: taiki-e/cache-cargo-install-action@v2 | |
with: | |
tool: zepter | |
- name: Eagerly pull dependencies | |
run: cargo metadata --format-version=1 --locked > /dev/null | |
- run: zepter run check | |
deny: | |
uses: ithacaxyz/ci/.github/workflows/deny.yml@main | |
lint-success: | |
name: lint success | |
runs-on: ubuntu-latest | |
if: always() | |
needs: | |
- clippy-binaries | |
- clippy | |
- wasm | |
- crate-checks | |
- docs | |
- fmt | |
- udeps | |
- book | |
- typos | |
- grafana | |
- no-test-deps | |
- features | |
- feature-propagation | |
- deny | |
timeout-minutes: 30 | |
steps: | |
- name: Decide whether the needed jobs succeeded or failed | |
uses: re-actors/alls-green@release/v1 | |
with: | |
jobs: ${{ toJSON(needs) }} |