Skip to content

Release version 1.0.1 #200

Release version 1.0.1

Release version 1.0.1 #200

Workflow file for this run

---
# This workflow runs when PRs are merged and tags/builds/publishes a release.
# Run when PRs to main are closed.
on:
pull_request:
types:
- closed
branches:
- main
name: Build and publish a release
jobs:
# We make `if_merged` a `needs:` of the other jobs here to only run this
# workflow on merged PRs.
if_merged:
name: Check that PR was merged and not closed
if: github.event.pull_request.merged == true
&& contains(github.event.pull_request.labels.*.name, 'release')
runs-on: ubuntu-latest
steps:
- run: |
echo "This is a canonical hack to run GitHub Actions on merged PRs"
echo "See: https://docs.github.com/en/actions/using-workflows/events-that-trigger-workflows#running-your-pull_request-workflow-when-a-pull-request-merges"
- name: Comment on PR with link to this action
uses: peter-evans/create-or-update-comment@v2
with:
issue-number: ${{ github.event.pull_request.number }}
body: |
[This release is now being built.][run]
[run]: ${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}
version:
name: Get version number
needs: if_merged
runs-on: ubuntu-latest
outputs:
version: ${{ steps.get_cargo_metadata.outputs.version }}
steps:
- name: Checkout code
uses: actions/checkout@v3
- uses: cachix/install-nix-action@v22
with:
github_access_token: ${{ secrets.GITHUB_TOKEN }}
extra_nix_config: |
extra-experimental-features = nix-command flakes
accept-flake-config = true
- name: Get version number
id: get_cargo_metadata
run: echo "version=$(nix run .#get-crate-version)" >> "$GITHUB_OUTPUT"
build:
name: Release Build
# Now we're ready to do the release build. In this step, we upload
# "artifacts" which lets us share files between jobs (the artifacts are
# downloaded by the next job, `upload`) and aggregate files from different
# parts of the matrix (so we can have the macOS and Linux executables in
# the next job).
needs: if_merged
runs-on: ${{ matrix.os }}
strategy:
matrix:
os: [ubuntu-latest, macos-latest]
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Install rustup
uses: dtolnay/rust-toolchain@stable
if: runner.os == 'macOS'
with:
target: x86_64-apple-darwin, aarch64-apple-darwin
- name: Log versions
if: runner.os == 'macOS'
run: which -a rustup && rustup --version
- name: Build (macOS, x86_64)
if: runner.os == 'macOS'
# Nix cross-compilation is broken on macOS, but cargo works fine.
# See: https://github.com/NixOS/nixpkgs/issues/180771
run: cargo build --release --target x86_64-apple-darwin
- name: Build (macOS, aarch64)
if: runner.os == 'macOS'
run: cargo build --release --target aarch64-apple-darwin
- name: Create macOS universal executable
if: runner.os == 'macOS'
run: |
lipo -create -output target/release/ghciwatch-macos \
target/x86_64-apple-darwin/release/ghciwatch \
target/aarch64-apple-darwin/release/ghciwatch
- uses: cachix/install-nix-action@v22
if: runner.os == 'Linux'
with:
github_access_token: ${{ secrets.GITHUB_TOKEN }}
extra_nix_config: |
extra-experimental-features = nix-command flakes
accept-flake-config = true
- name: Create target directory (Linux)
if: runner.os == 'Linux'
run: mkdir -p target/
- name: Build (Linux, x86_64)
if: runner.os == 'Linux'
run: |
mkdir -p target/
RESULT=$(nix build --no-link --print-out-paths --print-build-logs .#ghciwatch)
cp "$RESULT/bin/ghciwatch" target/ghciwatch-x86_64-linux
- name: Build (Linux, aarch64)
if: runner.os == 'Linux'
run: |
RESULT=$(nix build --no-link --print-out-paths --print-build-logs .#ghciwatch-aarch64-linux)
cp "$RESULT/bin/ghciwatch" target/ghciwatch-aarch64-linux
- name: Build user manual
if: runner.os == 'Linux'
run: |
RESULT=$(nix build --no-link --print-out-paths --print-build-logs .#ghciwatch.user-manual-tar-xz)
cp "$RESULT" target/ghciwatch-user-manual.tar.xz
- name: Upload macOS executable
uses: actions/upload-artifact@v3
if: runner.os == 'macOS'
with:
name: macos
path: target/release/ghciwatch-macos
- name: Upload Linux executables
uses: actions/upload-artifact@v3
if: runner.os == 'Linux'
with:
name: linux
path: |
target/ghciwatch-x86_64-linux
target/ghciwatch-aarch64-linux
target/ghciwatch-user-manual.tar.xz
- name: Publish to crates.io
if: runner.os == 'Linux'
env:
CARGO_REGISTRY_TOKEN: ${{ secrets.CARGO_REGISTRY_TOKEN }}
run: |
nix run .#cargo -- publish --no-verify
upload:
name: Upload assets to release
runs-on: ubuntu-latest
needs:
- if_merged
- build
- version
steps:
- name: Tag the release
uses: mathieudutour/[email protected]
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
commit_sha: ${{ github.event.pull_request.merge_commit_sha }}
custom_tag: ${{ needs.version.outputs.version }}
- name: Download artifacts
# This downloads the uploaded artifacts to the current directory; the
# path format for downloaded artifacts is `{name}/{basename}`, where
# `{basename}` is the basename of the upload `path`.
#
# For example, the following artifact:
#
# - uses: actions/upload-artifact@v3
# with:
# name: linux
# path: target/release/ghciwatch-aarch64-linux
#
# will be downloaded to `linux/ghciwatch-aarch64-linux`.
uses: actions/download-artifact@v3
- name: Create release
id: create_release
uses: softprops/action-gh-release@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
draft: false
prerelease: false
generate_release_notes: true
tag_name: v${{ needs.version.outputs.version }}
files: |
macos/ghciwatch-macos
linux/ghciwatch-x86_64-linux
linux/ghciwatch-aarch64-linux
linux/ghciwatch-user-manual.tar.xz
- name: Comment on PR with link to the release
uses: peter-evans/create-or-update-comment@v2
with:
issue-number: ${{ github.event.pull_request.number }}
body: |
[Release ${{ needs.version.outputs.version }}][release] was built and published successfully!
[release]: ${{ steps.create_release.outputs.url }}
github-pages:
name: Publish user manual to GitHub Pages
runs-on: ubuntu-latest
needs:
- build
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Download artifacts
# This downloads the uploaded artifacts to the current directory; the
# path format for downloaded artifacts is `{name}/{basename}`, where
# `{basename}` is the basename of the upload `path`.
#
# For example, the following artifact:
#
# - uses: actions/upload-artifact@v3
# with:
# name: linux
# path: target/release/ghciwatch-aarch64-linux
#
# will be downloaded to `linux/ghciwatch-aarch64-linux`.
uses: actions/download-artifact@v3
- name: Extract user manual
run: |
tar --extract \
--verbose \
--file linux/ghciwatch-user-manual.tar.xz
- name: Publish to GitHub Pages
uses: JamesIves/github-pages-deploy-action@v4
with:
folder: ghciwatch-user-manual/