Skip to content

ci: experiment with a binary release build #16

ci: experiment with a binary release build

ci: experiment with a binary release build #16

name: zizmor binary releases for GitHub 🐙
on:
workflow_dispatch:
inputs:
tag:
description: "The release to attach binaries to"
required: true
clobber:
description: "Whether to clobber existing files"
required: true
default: false
type: boolean
dry-run:
description: "Whether to perform a dry run"
required: true
default: false
type: boolean
release:
types: [published]
pull_request:
permissions: {}
env:
DRY_RUN: "${{ github.event_name == 'pull_request' || github.event.inputs.dry-run }}"
jobs:
build:
name: Build for ${{ matrix.target }} on ${{ matrix.runner }}
runs-on: ${{ matrix.runner }}
strategy:
matrix:
include:
- runner: ubuntu-latest
target: x86_64-unknown-linux-gnu
- runner: ubuntu-24.04-arm
target: aarch64-unknown-linux-gnu
- runner: macos-latest
target: x86_64-apple-darwin
- runner: macos-latest
target: aarch64-apple-darwin
- runner: windows-latest
target: x86_64-pc-windows-msvc
- runner: windows-latest
target: i686-pc-windows-msvc
steps:
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
with:
persist-credentials: false
- name: Rust toolchain and target information
run: |
rustup show
- name: Install Rust target for ${{ matrix.target }}
run: rustup target add "${TARGET}"
env:
TARGET: ${{ matrix.target }}
shell: bash
- name: Build release
run: cargo build --release --target "${TARGET}"
env:
TARGET: ${{ matrix.target }}
shell: bash
- name: Archive release
id: archive-release
run: |
./support/archive-release.sh
env:
TARGET: ${{ matrix.target }}
shell: bash
- name: Upload artifact
uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2
with:
name: artifacts-${{ matrix.target }}
path: ${{ steps.archive-release.outputs.filename }}
if-no-files-found: error
release:
name: Release binaries
runs-on: ubuntu-latest
needs: build
permissions:
id-token: write # for attestations
attestations: write # for attestations
steps:
- name: Download artifacts
uses: actions/download-artifact@d3f86a106a0bac45b974a628896c90dbdf5c8093 # v4.3.0
with:
pattern: artifacts-*
path: distrib/
merge-multiple: true
- name: List artifacts
run: ls -l distrib/
- name: Attest to artifacts
uses: actions/attest-build-provenance@db473fddc028af60658334401dc6fa3ffd8669fd # v2.3.0
with:
subject-path: "distrib/*"
# - name: Upload to release
# if: ${{ github.event_name == 'release' || github.event_name == 'workflow_dispatch' }}
# run: |
# gh release upload ${CLOBBER} "${RELEASE_TAG}"
# env:
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
# RELEASE_TAG: ${{ github.event.inputs.tag || github.ref_name }}
# CLOBBER: ${{ github.event.inputs.clobber && '--clobber' || '' }}
# shell: bash