From 3755e54306896bb2d13f6712e900b4340c3c0bd1 Mon Sep 17 00:00:00 2001 From: Karim Date: Mon, 20 May 2024 00:07:50 +0200 Subject: [PATCH] chore(repo): re-org workflows and limit runs to relative changes --- .github/workflows/ci-all.yml | 76 ++++++++++ .github/workflows/ci-build-test-reusable.yml | 56 +++++++ .github/workflows/ci-native.yml | 12 ++ .github/workflows/ci-risc0.yml | 17 +++ .github/workflows/ci-sgx-all.yml | 52 +++++++ .github/workflows/ci-sgx-docker.yml | 23 +++ .github/workflows/ci-sp1.yml | 17 +++ .github/workflows/ci-zkVMs.yml | 30 ++++ .github/workflows/ci.yml | 150 ------------------- 9 files changed, 283 insertions(+), 150 deletions(-) create mode 100644 .github/workflows/ci-all.yml create mode 100644 .github/workflows/ci-build-test-reusable.yml create mode 100644 .github/workflows/ci-native.yml create mode 100644 .github/workflows/ci-risc0.yml create mode 100644 .github/workflows/ci-sgx-all.yml create mode 100644 .github/workflows/ci-sgx-docker.yml create mode 100644 .github/workflows/ci-sp1.yml create mode 100644 .github/workflows/ci-zkVMs.yml delete mode 100644 .github/workflows/ci.yml diff --git a/.github/workflows/ci-all.yml b/.github/workflows/ci-all.yml new file mode 100644 index 000000000..8085ce78e --- /dev/null +++ b/.github/workflows/ci-all.yml @@ -0,0 +1,76 @@ +name: CI - All + +on: + push: + branches: ["main"] + paths: + - "host/**" + - "lib/**" + - "primitives/**" + - "script/**" + pull_request: + +env: + CARGO_TERM_COLOR: always + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + +concurrency: + group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }} + cancel-in-progress: true + +jobs: + build-test-native: + uses: ./.github/workflows/ci-native.yml + + build-test-risc0: + uses: ./.github/workflows/ci-risc0.yml + + build-test-sp1: + uses: ./.github/workflows/ci-sp1.yml + + build-test-sgx-all: + uses: ./.github/workflows/ci-ngx-all.yml + + test-lib: + name: Test raiko-lib + runs-on: ubuntu-latest + timeout-minutes: 60 + + steps: + - uses: actions/checkout@v4 + + - uses: actions-rs/toolchain@v1 + with: + profile: minimal + + - run: cargo test -p raiko-lib --features=std + + clippy: + name: clippy + runs-on: ubuntu-latest + timeout-minutes: 30 + + steps: + - uses: actions/checkout@v4 + + - uses: risc0/risc0/.github/actions/rustup@release-0.19 + + - uses: risc0/risc0/.github/actions/sccache@release-0.19 + + - uses: risc0/clippy-action@main + with: + reporter: 'github-pr-check' + fail_on_error: true + clippy_flags: --workspace --all-targets --all-features -- -D warnings + + fmt: + name: fmt + runs-on: ubuntu-latest + timeout-minutes: 10 + + steps: + - uses: actions/checkout@v4 + + - uses: risc0/risc0/.github/actions/rustup@release-0.19 + + - run: make fmt diff --git a/.github/workflows/ci-build-test-reusable.yml b/.github/workflows/ci-build-test-reusable.yml new file mode 100644 index 000000000..77e2815ac --- /dev/null +++ b/.github/workflows/ci-build-test-reusable.yml @@ -0,0 +1,56 @@ +name: CI Build and Test - Reusable + +on: + workflow_call: + inputs: + version_name: + type: string + required: true + version_toolchain: + type: string + required: true + +env: + CARGO_TERM_COLOR: always + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + +jobs: + build-test: + name: Build and test + runs-on: ubuntu-latest + timeout-minutes: 120 + + env: + TARGET: ${{ inputs.version_name}} + CI: 1 + MOCK: 1 + + steps: + - uses: actions/checkout@v4 + with: + submodules: recursive + + - uses: actions-rs/toolchain@v1 + with: + toolchain: ${{ inputs.version_toolchain }} + profile: minimal + + - name: Install cargo-binstall + uses: cargo-bins/cargo-binstall@v1.6.4 + + - name: Setup sccache + if: ${{ inputs.version_name }} == risc0 + uses: risc0/risc0/.github/actions/sccache@release-0.19 + + - name: Install ${{ inputs.version_name }} + run: make install + + - name: Build ${{ inputs.version_name }} prover + run: make build + + - name: Test ${{ inputs.version_name }} prover + run: make test + + - name: Build with tracer + if: ${{ inputs.version_name }} == native + run: cargo build -F tracer \ No newline at end of file diff --git a/.github/workflows/ci-native.yml b/.github/workflows/ci-native.yml new file mode 100644 index 000000000..9413a94f3 --- /dev/null +++ b/.github/workflows/ci-native.yml @@ -0,0 +1,12 @@ +name: CI - Native + +on: workflow_call + + +jobs: + build-test-sgx: + name: Build and test sgx with Docker + uses: ./.github/workflows/build-test.yml + with: + version_name: "native" + toolchain: "nightly-2024-04-17" \ No newline at end of file diff --git a/.github/workflows/ci-risc0.yml b/.github/workflows/ci-risc0.yml new file mode 100644 index 000000000..f47f5d80a --- /dev/null +++ b/.github/workflows/ci-risc0.yml @@ -0,0 +1,17 @@ +name: CI - RISC0 + +on: + push: + branches: ["main"] + paths: + - "provers/risc0/**" + pull_request: + + +jobs: + build-test-sgx: + name: Build and test sgx with Docker + uses: ./.github/workflows/build-test.yml + with: + version_name: "risc0" + toolchain: "stable" \ No newline at end of file diff --git a/.github/workflows/ci-sgx-all.yml b/.github/workflows/ci-sgx-all.yml new file mode 100644 index 000000000..58c75bfc1 --- /dev/null +++ b/.github/workflows/ci-sgx-all.yml @@ -0,0 +1,52 @@ +name: CI - SGX ALL + +on: + push: + branches: ["main"] + paths: + - "provers/sgx/**" + pull_request: + + +jobs: + build-test-sgx: + name: Build and test sgx with Docker + uses: ./.github/workflows/build-test.yml + with: + version_name: "sgx" + toolchain: "stable" + + build-test-sgx-docker: + name: Build and test sgx with Docker + uses: ./.github/workflows/sgx-docker.yml + + build-test-sgx-hardware: + name: Build and test sgx in hardware + runs-on: [self-hosted, sgx, linux] + timeout-minutes: 120 + env: + TARGET: sgx + CI: 1 + EDMM: 0 + + steps: + - uses: actions/checkout@v4 + with: + submodules: recursive + + - uses: actions-rs/toolchain@v1 + with: + toolchain: stable + profile: minimal + + - name: Install cargo-binstall + uses: cargo-bins/cargo-binstall@v1.6.4 + + - name: Install sgx + run: make install + + - name: Build sgx prover + run: make build + + - name: Test sgx prover + run: make test \ No newline at end of file diff --git a/.github/workflows/ci-sgx-docker.yml b/.github/workflows/ci-sgx-docker.yml new file mode 100644 index 000000000..c83bb18bf --- /dev/null +++ b/.github/workflows/ci-sgx-docker.yml @@ -0,0 +1,23 @@ +name: CI - SGX Docker + +on: + push: + branches: ["main"] + paths: + - "docker/**" + pull_request: + + +jobs: + build-test-sgx-with-docker: + name: Build and test sgx with Docker + runs-on: ubuntu-latest + timeout-minutes: 60 + + steps: + - uses: actions/checkout@v4 + - name: Setup and build + run: | + cd docker + docker compose build --no-cache + shell: bash \ No newline at end of file diff --git a/.github/workflows/ci-sp1.yml b/.github/workflows/ci-sp1.yml new file mode 100644 index 000000000..697500a95 --- /dev/null +++ b/.github/workflows/ci-sp1.yml @@ -0,0 +1,17 @@ +name: CI - SP1 + +on: + push: + branches: ["main"] + paths: + - "provers/sp1/**" + pull_request: + + +jobs: + build-test-sgx: + name: Build and test sgx with Docker + uses: ./.github/workflows/build-test.yml + with: + version_name: "sp1" + toolchain: "nightly-2024-04-17" \ No newline at end of file diff --git a/.github/workflows/ci-zkVMs.yml b/.github/workflows/ci-zkVMs.yml new file mode 100644 index 000000000..1c34e9dc2 --- /dev/null +++ b/.github/workflows/ci-zkVMs.yml @@ -0,0 +1,30 @@ +name: CI - All zkVMs + +on: + push: + branches: ["main"] + paths: + - "pipelines/**" + - "harness/**" + pull_request: + +env: + CARGO_TERM_COLOR: always + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + +concurrency: + group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }} + cancel-in-progress: true + +jobs: + build-test-native: + uses: ./.github/workflows/ci-native.yml + + build-test-risc0: + uses: ./.github/workflows/ci-risc0.yml + + build-test-sp1: + uses: ./.github/workflows/ci-sp1.yml + + build-test-sgx-all: + uses: ./.github/workflows/ci-ngx-all.yml \ No newline at end of file diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml deleted file mode 100644 index 6a4cafa53..000000000 --- a/.github/workflows/ci.yml +++ /dev/null @@ -1,150 +0,0 @@ -name: CI - -on: - push: - branches: ["main"] - pull_request: - -env: - CARGO_TERM_COLOR: always - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - -concurrency: - group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }} - cancel-in-progress: true - -jobs: - build-test: - name: Build and test - runs-on: ubuntu-latest - timeout-minutes: 120 - strategy: - matrix: - VERSIONS: [ - {name: native, toolchain: nightly-2024-04-17}, - {name: sp1, toolchain: nightly-2024-04-17}, - {name: risc0, toolchain: stable}, - {name: sgx, toolchain: stable}, - ] - env: - TARGET: ${{ matrix.VERSIONS.name }} - CI: 1 - MOCK: 1 - - steps: - - uses: actions/checkout@v4 - with: - submodules: recursive - - - uses: actions-rs/toolchain@v1 - with: - toolchain: ${{ matrix.VERSIONS.toolchain }} - profile: minimal - - - name: Install cargo-binstall - uses: cargo-bins/cargo-binstall@v1.6.4 - - - name: Setup sccache - if: ${{ matrix.VERSIONS.name }} == risc0 - uses: risc0/risc0/.github/actions/sccache@release-0.19 - - - name: Install ${{ matrix.VERSIONS.name }} - run: make install - - - name: Build ${{ matrix.VERSIONS.name }} prover - run: make build - - - name: Test ${{ matrix.VERSIONS.name }} prover - run: make test - - - name: Build with tracer - if: ${{ matrix.VERSIONS.name }} == native - run: cargo build -F tracer - - build-test-sgx-hardware: - name: Build and test sgx in hardware - runs-on: [self-hosted, sgx, linux] - timeout-minutes: 120 - env: - TARGET: sgx - CI: 1 - EDMM: 0 - - steps: - - uses: actions/checkout@v4 - with: - submodules: recursive - - - uses: actions-rs/toolchain@v1 - with: - toolchain: stable - profile: minimal - - - name: Install cargo-binstall - uses: cargo-bins/cargo-binstall@v1.6.4 - - - name: Install sgx - run: make install - - - name: Build sgx prover - run: make build - - - name: Test sgx prover - run: make test - - build-test-sgx-with-docker: - name: Build and test sgx with Docker - runs-on: ubuntu-latest - timeout-minutes: 60 - - steps: - - uses: actions/checkout@v4 - - name: Setup and build - run: | - cd docker - docker compose build --no-cache - shell: bash - - test-lib: - name: Test raiko-lib - runs-on: ubuntu-latest - timeout-minutes: 60 - - steps: - - uses: actions/checkout@v4 - - - uses: actions-rs/toolchain@v1 - with: - profile: minimal - - - run: cargo test -p raiko-lib --features=std - - clippy: - name: clippy - runs-on: ubuntu-latest - timeout-minutes: 30 - - steps: - - uses: actions/checkout@v4 - - - uses: risc0/risc0/.github/actions/rustup@release-0.19 - - - uses: risc0/risc0/.github/actions/sccache@release-0.19 - - - uses: risc0/clippy-action@main - with: - reporter: 'github-pr-check' - fail_on_error: true - clippy_flags: --workspace --all-targets --all-features -- -D warnings - - fmt: - name: fmt - runs-on: ubuntu-latest - timeout-minutes: 10 - - steps: - - uses: actions/checkout@v4 - - - uses: risc0/risc0/.github/actions/rustup@release-0.19 - - - run: make fmt