release #67
Workflow file for this run
This file contains 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
# The way this works is a little weird. But basically, the create-release job | |
# runs purely to initialize the GitHub release itself. Once done, the upload | |
# URL of the release is saved as an artifact. | |
# | |
# The build-release job runs only once create-release is finished. It gets | |
# the release upload URL by downloading the corresponding artifact (which was | |
# uploaded by create-release). It then builds the release executables for each | |
# supported platform and attaches them as release assets to the previously | |
# created release. | |
# | |
# The key here is that we create the release only once. | |
name: release | |
env: | |
RUST_BACKTRACE: 1 | |
CARGO_TERM_COLOR: always | |
CLICOLOR: 1 | |
on: | |
workflow_dispatch: | |
push: | |
# Enable when testing release infrastructure on a branch. | |
# branches: | |
# - fix-releases | |
tags: | |
- "v.*" | |
jobs: | |
create-release: | |
name: create-release | |
runs-on: ubuntu-latest | |
# env: | |
# # Set to force version number, e.g., when no tag exists. | |
# ARTIFACT_VERSION: TEST-0.0.0 | |
steps: | |
- name: Create artifacts directory | |
run: mkdir artifacts | |
- name: Get the release version from the tag | |
if: env.ARTIFACT_VERSION == '' | |
run: | | |
echo "ARTIFACT_VERSION=${GITHUB_REF#refs/tags/}" >> $GITHUB_ENV | |
echo "version is: ${{ env.ARTIFACT_VERSION }}" | |
- name: Create GitHub release | |
id: release | |
uses: ncipollo/release-action@v1 | |
with: | |
tag: ${{ env.ARTIFACT_VERSION }} | |
name: ${{ env.ARTIFACT_VERSION }} | |
allowUpdates: true | |
omitBody: true | |
omitPrereleaseDuringUpdate: true | |
token: ${{ secrets.GITHUB_TOKEN }} | |
- name: Save release upload URL to artifact | |
run: echo "${{ steps.release.outputs.upload_url }}" > artifacts/release-upload-url | |
- name: Save version number to artifact | |
run: echo "${{ env.ARTIFACT_VERSION }}" > artifacts/release-version | |
- name: Upload artifacts | |
uses: actions/upload-artifact@v3 | |
with: | |
name: artifacts | |
path: artifacts | |
build-release: | |
name: build-release | |
needs: [ "create-release" ] | |
env: | |
# For some builds, we use cross to test on 32-bit and big-endian | |
# systems. | |
CARGO: cargo | |
# When CARGO is set to CROSS, this is set to `--target matrix.target`. | |
TARGET_FLAGS: "" | |
# When CARGO is set to CROSS, TARGET_DIR includes matrix.target. | |
TARGET_DIR: ./target | |
# Emit backtraces on panics. | |
RUST_BACKTRACE: 1 | |
# The name of the executable to expect | |
EXE_NAME: ein | |
strategy: | |
matrix: | |
build: [ linux, linux-arm, macos, win-msvc, win-gnu, win32-msvc ] | |
feature: [ "small", "lean", "max", "max-pure" ] | |
include: | |
- build: linux | |
os: ubuntu-latest | |
rust: stable | |
target: x86_64-unknown-linux-musl | |
- build: linux-arm | |
os: ubuntu-latest | |
rust: nightly | |
target: arm-unknown-linux-gnueabihf | |
- build: macos | |
os: macos-latest | |
rust: stable | |
target: x86_64-apple-darwin | |
- build: win-msvc | |
os: windows-latest | |
rust: nightly | |
target: x86_64-pc-windows-msvc | |
- build: win-gnu | |
os: windows-latest | |
rust: nightly-x86_64-gnu | |
target: x86_64-pc-windows-gnu | |
- build: win32-msvc | |
os: windows-latest | |
rust: nightly | |
target: i686-pc-windows-msvc | |
# on linux we build with musl which causes trouble with open-ssl. For now, just build max-pure there | |
# even though we could also build with `--features max-control,http-client-reqwest,gitoxide-core-blocking-client,gix-features/fast-sha1` for fast hashing. | |
# It's a TODO. | |
exclude: | |
- build: linux | |
feature: small | |
- build: linux | |
feature: lean | |
- build: linux | |
feature: max | |
- build: linux-arm | |
feature: small | |
- build: linux-arm | |
feature: lean | |
- build: linux-arm | |
feature: max | |
runs-on: ${{ matrix.os }} | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: 1 | |
- name: Install packages (Ubuntu) | |
# Because openssl doesn't work on musl by default, we resort to max-pure. And that won't need any dependency, so we can skip this.continue-on-error | |
# Once we want to support better zlib performance, we might have to re-add it. | |
if: matrix.os == 'ubuntu-latest-disabled' | |
run: | | |
sudo apt-get update && sudo apt-get install -y --no-install-recommends xz-utils liblz4-tool musl-tools | |
- name: Install Rust | |
uses: dtolnay/rust-toolchain@master | |
with: | |
toolchain: ${{ matrix.rust }} | |
targets: ${{ matrix.target }} | |
- name: Use Cross | |
# if: matrix.os != 'windows-latest' | |
run: | | |
cargo install cross | |
echo "CARGO=cross" >> $GITHUB_ENV | |
echo "TARGET_FLAGS=--target ${{ matrix.target }}" >> $GITHUB_ENV | |
echo "TARGET_DIR=./target/${{ matrix.target }}" >> $GITHUB_ENV | |
- name: Show command used for Cargo | |
run: | | |
echo "cargo command is: ${{ env.CARGO }}" | |
echo "target flag is: ${{ env.TARGET_FLAGS }}" | |
echo "target dir is: ${{ env.TARGET_DIR }}" | |
- name: Get release download URL | |
uses: actions/download-artifact@v3 | |
with: | |
name: artifacts | |
path: artifacts | |
- name: Set release upload URL and release version | |
shell: bash | |
run: | | |
release_upload_url="$(cat artifacts/release-upload-url)" | |
echo "RELEASE_UPLOAD_URL=$release_upload_url" >> $GITHUB_ENV | |
echo "release upload url: $RELEASE_UPLOAD_URL" | |
release_version="$(cat artifacts/release-version)" | |
echo "RELEASE_VERSION=$release_version" >> $GITHUB_ENV | |
echo "release version: $RELEASE_VERSION" | |
- name: Build release binary | |
run: ${{ env.CARGO }} build --verbose --release ${{ env.TARGET_FLAGS }} --no-default-features --features ${{ matrix.feature }} | |
- name: Strip release binary (linux and macos) | |
if: matrix.build == 'linux' || matrix.build == 'macos' | |
run: strip target/${{ matrix.target }}/release/${{ env.EXE_NAME }} target/${{ matrix.target }}/release/gix | |
- name: Strip release binary (arm) | |
if: matrix.build == 'linux-arm' | |
run: | | |
docker run --rm -v \ | |
"$PWD/target:/target:Z" \ | |
rustembedded/cross:arm-unknown-linux-gnueabihf \ | |
arm-linux-gnueabihf-strip \ | |
/target/arm-unknown-linux-gnueabihf/release/${{ env.EXE_NAME }} \ | |
/target/arm-unknown-linux-gnueabihf/release/gix | |
- name: Build archive | |
shell: bash | |
run: | | |
staging="gitoxide-${{ matrix.feature }}-${{ env.RELEASE_VERSION }}-${{ matrix.target }}" | |
mkdir -p "$staging" | |
cp {README.md,LICENSE-*,CHANGELOG.md} "$staging/" | |
if [ "${{ matrix.os }}" = "windows-latest" ]; then | |
cp target/release/${{ env.EXE_NAME }}.exe target/release/gix.exe "$staging/" | |
7z a "$staging.zip" "$staging" | |
echo "ASSET=$staging.zip" >> $GITHUB_ENV | |
else | |
cp target/${{ matrix.target }}/release/${{ env.EXE_NAME }} target/${{ matrix.target }}/release/gix "$staging/" | |
tar czf "$staging.tar.gz" "$staging" | |
echo "ASSET=$staging.tar.gz" >> $GITHUB_ENV | |
fi | |
- name: Upload release archive | |
uses: actions/[email protected] | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
with: | |
upload_url: ${{ env.RELEASE_UPLOAD_URL }} | |
asset_path: ${{ env.ASSET }} | |
asset_name: ${{ env.ASSET }} | |
asset_content_type: application/octet-stream |