From 55201e6190a8968520389d44fd6b1b8d5863eb0a Mon Sep 17 00:00:00 2001 From: cloudhead Date: Tue, 12 Mar 2024 14:01:13 +0100 Subject: [PATCH] ci: Add version file to binary release --- .github/workflows/release.yml | 68 ++++++++++---------- .github/workflows/update-latest-symlink.bash | 19 ------ .github/workflows/update-latest-symlink.sh | 27 ++++++++ 3 files changed, 62 insertions(+), 52 deletions(-) delete mode 100755 .github/workflows/update-latest-symlink.bash create mode 100755 .github/workflows/update-latest-symlink.sh diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 69f7209c6..56f15ed38 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -12,7 +12,8 @@ jobs: runs-on: ubuntu-20.04 strategy: matrix: - target: [x86_64-unknown-linux-musl, aarch64-unknown-linux-musl] + # target: [x86_64-unknown-linux-musl, aarch64-unknown-linux-musl] + target: [x86_64-unknown-linux-musl] include: - target: x86_64-unknown-linux-musl docker_image: registry.gitlab.com/rust_musl_docker/image:stable-latest @@ -22,9 +23,9 @@ jobs: docker_options: -v /home/runner/work/heartwood/heartwood:/home/rust/src -v /home/runner/.cargo/git:/root/.cargo/git -v /home/runner/.cargo/registry:/root/.cargo/registry steps: - name: Checkout source code - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: Configure build cache - uses: actions/cache@v3 + uses: actions/cache@v4 with: path: | ~/.cargo/registry @@ -47,40 +48,41 @@ jobs: env: SSH_PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }} - release-macos-binaries: - permissions: - contents: 'read' - id-token: 'write' - runs-on: macos-11 - strategy: - matrix: - target: - - aarch64-apple-darwin - - x86_64-apple-darwin - steps: - - uses: actions/checkout@v3 - - name: Configure build cache - uses: actions/cache@v3 - with: - path: | - ~/.cargo/registry - ~/.cargo/git - target - key: cargo-${{ matrix.target }}-${{ hashFiles('**/Cargo.lock') }} - - uses: dtolnay/rust-toolchain@1.67 - - name: Build the release binaries - run: .github/workflows/build.bash "${{ matrix.target }}" - - name: Build the debug binaries - run: .github/workflows/build-debug.bash "${{ matrix.target }}" - - run: .github/workflows/upload.bash "${{ matrix.target }}" "${{ github.sha }}" - env: - SSH_PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }} + # release-macos-binaries: + # permissions: + # contents: 'read' + # id-token: 'write' + # runs-on: macos-11 + # strategy: + # matrix: + # target: + # - aarch64-apple-darwin + # - x86_64-apple-darwin + # steps: + # - uses: actions/checkout@v4 + # - name: Configure build cache + # uses: actions/cache@v4 + # with: + # path: | + # ~/.cargo/registry + # ~/.cargo/git + # target + # key: cargo-${{ matrix.target }}-${{ hashFiles('**/Cargo.lock') }} + # - uses: dtolnay/rust-toolchain@stable + # - name: Build the release binaries + # run: .github/workflows/build.bash "${{ matrix.target }}" + # - name: Build the debug binaries + # run: .github/workflows/build-debug.bash "${{ matrix.target }}" + # - run: .github/workflows/upload.bash "${{ matrix.target }}" "${{ github.sha }}" + # env: + # SSH_PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }} update-latest-symlink: - needs: [release-linux-binaries, release-macos-binaries] + # needs: [release-linux-binaries, release-macos-binaries] + needs: [release-linux-binaries] runs-on: ubuntu-20.04 steps: - - uses: actions/checkout@v3 + - uses: actions/checkout@v4 - run: .github/workflows/update-latest-symlink.bash "${{ github.sha }}" env: SSH_PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }} diff --git a/.github/workflows/update-latest-symlink.bash b/.github/workflows/update-latest-symlink.bash deleted file mode 100755 index 23781adba..000000000 --- a/.github/workflows/update-latest-symlink.bash +++ /dev/null @@ -1,19 +0,0 @@ -#!/bin/bash - -set -o errexit -set -o nounset -set -o pipefail - -main () { - if [[ $# -ne 1 ]]; then - echo "$#: Wrong number of arguments" - return 1 - fi - - local sha=$1 - echo "$SSH_PRIVATE_KEY" >ssh-private-key - chmod go-rwx ssh-private-key - ssh -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no -i ssh-private-key github-actions@files.radicle.xyz ln -snf "/mnt/radicle/releases/${sha}" "/mnt/radicle/releases/latest" -} - -main "$@" diff --git a/.github/workflows/update-latest-symlink.sh b/.github/workflows/update-latest-symlink.sh new file mode 100755 index 000000000..88104c0eb --- /dev/null +++ b/.github/workflows/update-latest-symlink.sh @@ -0,0 +1,27 @@ +#!/bin/sh + +set -o errexit +set -o nounset + +remotely() { + ssh -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no -i ssh-private-key github-actions@files.radicle.xyz "$@" +} + +main () { + if [ $# -ne 1 ]; then + echo "$#: Wrong number of arguments" + return 1 + fi + target="x86_64-unknown-linux-musl" + sha=$1 + + trap 'rm -f ssh-private-key' EXIT + + echo "$SSH_PRIVATE_KEY" > ssh-private-key + chmod go-rwx ssh-private-key + + remotely "/mnt/radicle/releases/${sha}/${target}/rad version --json > /mnt/radicle/releases/${sha}/version.json" + # remotely ln -snf "/mnt/radicle/releases/${sha}" "/mnt/radicle/releases/latest" +} + +main "$@"