|
59 | 59 | path: ./crates/contracts/build |
60 | 60 | retention-days: 1 |
61 | 61 |
|
| 62 | + reproducibility-check: |
| 63 | + name: reproducibility-check (linux-amd64) |
| 64 | + needs: [prepare, build-contracts] |
| 65 | + runs-on: ubuntu-latest-8-cores |
| 66 | + env: |
| 67 | + TARGET: x86_64-unknown-linux-gnu |
| 68 | + steps: |
| 69 | + - uses: actions/checkout@v4 |
| 70 | + |
| 71 | + - name: Set SOURCE_DATE_EPOCH |
| 72 | + shell: bash |
| 73 | + run: | |
| 74 | + echo "SOURCE_DATE_EPOCH=$(git log -1 --format=%ct)" >> $GITHUB_ENV |
| 75 | +
|
| 76 | + - name: Download contract artifacts |
| 77 | + uses: actions/download-artifact@v4 |
| 78 | + with: |
| 79 | + name: contract-artifacts |
| 80 | + path: ./crates/contracts/build |
| 81 | + |
| 82 | + - uses: actions-rust-lang/setup-rust-toolchain@v1 |
| 83 | + name: Rust Toolchain Setup |
| 84 | + with: |
| 85 | + toolchain: ${{ env.RUST_VERSION }} |
| 86 | + target: ${{ env.TARGET }} |
| 87 | + cache-on-failure: true |
| 88 | + cache-key: reproducibility-${{ env.TARGET }} |
| 89 | + |
| 90 | + - name: Verify vendored dependency archive |
| 91 | + shell: bash |
| 92 | + run: | |
| 93 | + ./scripts/release/verify-vendor-archive.sh --extract-check |
| 94 | +
|
| 95 | + - name: Build (pass 1) |
| 96 | + shell: bash |
| 97 | + run: | |
| 98 | + ./scripts/release/build-katana-vendored.sh --target "$TARGET" |
| 99 | + SHA_ONE=$(sha256sum "./target/$TARGET/performance/katana" | awk '{ print $1 }') |
| 100 | + echo "sha_one=$SHA_ONE" >> $GITHUB_ENV |
| 101 | +
|
| 102 | + - name: Build (pass 2) |
| 103 | + shell: bash |
| 104 | + run: | |
| 105 | + rm -rf ./target |
| 106 | + ./scripts/release/build-katana-vendored.sh --target "$TARGET" |
| 107 | + SHA_TWO=$(sha256sum "./target/$TARGET/performance/katana" | awk '{ print $1 }') |
| 108 | + echo "sha_two=$SHA_TWO" >> $GITHUB_ENV |
| 109 | +
|
| 110 | + - name: Compare hashes |
| 111 | + shell: bash |
| 112 | + run: | |
| 113 | + echo "Build #1 SHA256: $sha_one" |
| 114 | + echo "Build #2 SHA256: $sha_two" |
| 115 | + if [[ "$sha_one" != "$sha_two" ]]; then |
| 116 | + echo "Reproducibility check failed: hashes differ." |
| 117 | + exit 1 |
| 118 | + fi |
| 119 | +
|
| 120 | + - name: Summary |
| 121 | + shell: bash |
| 122 | + run: | |
| 123 | + echo "## Reproducibility Check" >> $GITHUB_STEP_SUMMARY |
| 124 | + echo "" >> $GITHUB_STEP_SUMMARY |
| 125 | + echo "- target: \`$TARGET\`" >> $GITHUB_STEP_SUMMARY |
| 126 | + echo "- SOURCE_DATE_EPOCH: \`$SOURCE_DATE_EPOCH\`" >> $GITHUB_STEP_SUMMARY |
| 127 | + echo "- sha256(build #1): \`$sha_one\`" >> $GITHUB_STEP_SUMMARY |
| 128 | + echo "- sha256(build #2): \`$sha_two\`" >> $GITHUB_STEP_SUMMARY |
| 129 | +
|
62 | 130 | release: |
63 | 131 | name: ${{ matrix.job.target }} (${{ matrix.job.os }}${{ matrix.job.native_build == true && ', native' || '' }}) |
64 | | - needs: [prepare, build-contracts] |
| 132 | + needs: [prepare, build-contracts, reproducibility-check] |
65 | 133 | runs-on: ${{ matrix.job.os }} |
66 | 134 | env: |
67 | 135 | PLATFORM_NAME: ${{ matrix.job.platform }} |
@@ -118,6 +186,11 @@ jobs: |
118 | 186 | steps: |
119 | 187 | - uses: actions/checkout@v4 |
120 | 188 |
|
| 189 | + - name: Set SOURCE_DATE_EPOCH |
| 190 | + shell: bash |
| 191 | + run: | |
| 192 | + echo "SOURCE_DATE_EPOCH=$(git log -1 --format=%ct)" >> $GITHUB_ENV |
| 193 | +
|
121 | 194 | - name: Download contract artifacts |
122 | 195 | uses: actions/download-artifact@v4 |
123 | 196 | with: |
@@ -204,17 +277,22 @@ jobs: |
204 | 277 | # See: https://github.com/jemalloc/jemalloc/issues/467 |
205 | 278 | echo "JEMALLOC_SYS_WITH_LG_PAGE=16" >> $GITHUB_ENV |
206 | 279 |
|
| 280 | + - name: Verify vendored dependency archive |
| 281 | + shell: bash |
| 282 | + run: | |
| 283 | + ./scripts/release/verify-vendor-archive.sh --extract-check |
| 284 | +
|
207 | 285 | - name: Build binary |
208 | 286 | if: ${{ matrix.job.native_build == false }} |
209 | 287 | shell: bash |
210 | 288 | run: | |
211 | | - cargo build -p katana --bin katana --profile performance --target ${{ matrix.job.target }} |
| 289 | + ./scripts/release/build-katana-vendored.sh --target "${{ matrix.job.target }}" |
212 | 290 |
|
213 | 291 | - name: Build binary ( w/ cairo-native ) |
214 | 292 | if: ${{ matrix.job.native_build == true }} |
215 | 293 | shell: bash |
216 | 294 | run: | |
217 | | - cargo build -p katana --bin katana --profile performance --features native --target ${{ matrix.job.target }} |
| 295 | + ./scripts/release/build-katana-vendored.sh --target "${{ matrix.job.target }}" --native |
218 | 296 |
|
219 | 297 | - name: Archive binaries |
220 | 298 | id: artifacts |
|
0 commit comments