From 8444d71d2f85169b216a8fb92d7004635839853c Mon Sep 17 00:00:00 2001 From: Shubhranshu153 Date: Fri, 15 Nov 2024 02:32:30 +0000 Subject: [PATCH] fix: Add arm64 build and release Signed-off-by: Shubhranshu153 --- .github/workflows/release-automation.yaml | 97 ++++++++++++++++------- scripts/create-releases.sh | 35 +++++--- scripts/verify-release-artifacts.sh | 9 ++- 3 files changed, 101 insertions(+), 40 deletions(-) diff --git a/.github/workflows/release-automation.yaml b/.github/workflows/release-automation.yaml index 2b97d22..d27ba2d 100644 --- a/.github/workflows/release-automation.yaml +++ b/.github/workflows/release-automation.yaml @@ -7,6 +7,7 @@ env: permissions: contents: write deployments: write + jobs: get-latest-tag: name: Get the latest release tag @@ -22,12 +23,16 @@ jobs: uses: "WyriHaximus/github-action-get-previous-tag@04e8485ecb6487243907e330d522ff60f02283ce" # v1.4.0 generate-artifacts: needs: get-latest-tag - runs-on: ubuntu-20.04 + runs-on: ${{ matrix.os }} + strategy: + matrix: + os: [ubuntu-latest] # Use ubuntu-latest for both amd64 and arm64 + arch: [amd64, arm64] # Define the architectures env: - # Set during setup. RELEASE_TAG: ${{ needs.get-latest-tag.outputs.tag }} DYNAMIC_BINARY_NAME: '' STATIC_BINARY_NAME: '' + RELEASE_VERSION: '' steps: - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 with: @@ -42,68 +47,106 @@ jobs: run: | export release_tag=${{ env.RELEASE_TAG }} export release_version=${release_tag/v/} # Remove v from tag name - echo "DYNAMIC_BINARY_NAME=finch-daemon-${release_version}-linux-amd64.tar.gz" >> $GITHUB_ENV - echo "STATIC_BINARY_NAME=finch-daemon-${release_version}-linux-amd64-static.tar.gz" >> $GITHUB_ENV - + echo "DYNAMIC_BINARY_NAME=finch-daemon-${release_version}-linux-${{ matrix.arch }}.tar.gz" >> $GITHUB_ENV + echo "STATIC_BINARY_NAME=finch-daemon-${release_version}-linux-${{ matrix.arch }}-static.tar.gz" >> $GITHUB_ENV + echo "RELEASE_VERSION=${release_version}" >> $GITHUB_ENV mkdir release - name: Install Go licenses run: go install github.com/google/go-licenses@latest + - name: Install Cross Arch dependencies + run: | + if [ "${{ matrix.arch }}" = "arm64" ]; then + sudo apt update + sudo apt install -y gcc-aarch64-linux-gnu g++-aarch64-linux-gnu + fi - name: Create Third Party Licences File run: make licenses - - name: setup static dependecies + - name: setup static dependencies run: | sudo apt-get update sudo apt-get install libc6-dev -f - name: Create release binaries - run: make RELEASE_TAG=${{ env.RELEASE_TAG }} release - - name: Verify Release version run: | - mkdir -p output/static output/dynamic - tar -xzf release/${{ env.DYNAMIC_BINARY_NAME }} -C ./output/dynamic - tar -xzf release/${{ env.STATIC_BINARY_NAME }} -C ./output/static - DYNAMIC_BINARY_VERSION=$(./output/dynamic/finch-daemon --version | grep -oP '\d+\.\d+\.\d+') - STATIC_BINARY_VERSION=$(./output/static/finch-daemon --version | grep -oP '\d+\.\d+\.\d+') - export release_tag=${{ env.RELEASE_TAG }} - export release_version=${release_tag/v/} - if ["$STATIC_BINARY_VERSION" != "$release_version"] || ["$DYNAMIC_BINARY_VERSION" != "$release_version"]; then - echo "Version mismatch" - exit 1 + if [ "${{ matrix.arch }}" = "amd64" ]; then + make TARGET_ARCH=${{ matrix.arch }} RELEASE_TAG=${{ env.RELEASE_TAG }} release + elif [ "${{ matrix.arch }}" = "arm64" ]; then + make CC=aarch64-linux-gnu-gcc TARGET_ARCH=${{ matrix.arch }} RELEASE_TAG=${{ env.RELEASE_TAG }} release fi + - name: Verify Release version + run: | + HOST_ARCH='' + case $(uname -m) in + x86_64) HOST_ARCH="amd64" ;; + aarch64) HOST_ARCH="arm64" ;; + *) echo "Error: Unsupported arch $(uname -m)"; exit 1 ;; + esac + if [ "${{ matrix.arch }}" = "$HOST_ARCH" ]; then + mkdir -p output/static output/dynamic + tar -xzf release/${{ env.DYNAMIC_BINARY_NAME }} -C ./output/dynamic + tar -xzf release/${{ env.STATIC_BINARY_NAME }} -C ./output/static + DYNAMIC_BINARY_VERSION=$(./output/dynamic/finch-daemon --version | grep -oP '\d+\.\d+\.\d+') + STATIC_BINARY_VERSION=$(./output/static/finch-daemon --version | grep -oP '\d+\.\d+\.\d+') + export release_tag=${{ env.RELEASE_TAG }} + export release_version=${release_tag/v/} + if [ "$STATIC_BINARY_VERSION" != "$release_version" ] || [ "$DYNAMIC_BINARY_VERSION" != "$release_version" ]; then + echo "Version mismatch" + exit 1 + fi + else + echo "Architecture mismatch: Cross Arch validation is not supported. Skipping version verification" + fi shell: bash - uses: actions/upload-artifact@v4 with: - name: artifacts + name: artifacts-${{ matrix.arch }} path: release/ if-no-files-found: error outputs: release_tag: ${{ env.RELEASE_TAG }} + release_version: ${{ env.RELEASE_VERSION }} dynamic_binary_name: ${{ env.DYNAMIC_BINARY_NAME }} static_binary_name: ${{ env.STATIC_BINARY_NAME }} + validate-artifacts: needs: generate-artifacts - runs-on: ubuntu-latest + runs-on: ${{ matrix.os }} + strategy: + matrix: + os: [ubuntu-latest] + arch: [amd64, arm64] steps: - uses: actions/checkout@v4 - uses: actions/download-artifact@v4 with: - name: artifacts + name: artifacts-${{ matrix.arch }} path: release/ - run: bash scripts/verify-release-artifacts.sh ${{ needs.generate-artifacts.outputs.release_tag }} + env: + TARGET_ARCH: ${{ matrix.arch }} create-release: needs: [generate-artifacts, validate-artifacts] runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - - uses: actions/download-artifact@v4 + - name: Download Artifact amd64 + uses: actions/download-artifact@v4 + with: + name: artifacts-amd64 + - name: Download Artifact arm64 + uses: actions/download-artifact@v4 with: - name: artifacts + name: artifacts-arm64 - uses: softprops/action-gh-release@v2 with: tag_name: ${{ needs.generate-artifacts.outputs.release_tag }} prerelease: false generate_release_notes: false files: | - ${{ needs.generate-artifacts.outputs.dynamic_binary_name }} - ${{ needs.generate-artifacts.outputs.dynamic_binary_name }}.sha256sum - ${{ needs.generate-artifacts.outputs.static_binary_name }} - ${{ needs.generate-artifacts.outputs.static_binary_name }}.sha256sum + finch-daemon-${{ needs.generate-artifacts.outputs.release_version }}-linux-amd64.tar.gz + finch-daemon-${{ needs.generate-artifacts.outputs.release_version }}-linux-amd64.tar.gz.sha256sum + finch-daemon-${{ needs.generate-artifacts.outputs.release_version }}-linux-amd64-static.tar.gz + finch-daemon-${{ needs.generate-artifacts.outputs.release_version }}-linux-amd64-static.tar.gz.sha256sum + finch-daemon-${{ needs.generate-artifacts.outputs.release_version }}-linux-arm64.tar.gz + finch-daemon-${{ needs.generate-artifacts.outputs.release_version }}-linux-arm64.tar.gz.sha256sum + finch-daemon-${{ needs.generate-artifacts.outputs.release_version }}-linux-arm64-static.tar.gz + finch-daemon-${{ needs.generate-artifacts.outputs.release_version }}-linux-arm64-static.tar.gz.sha256sum diff --git a/scripts/create-releases.sh b/scripts/create-releases.sh index 93c164d..c8fa44a 100755 --- a/scripts/create-releases.sh +++ b/scripts/create-releases.sh @@ -29,15 +29,22 @@ RELEASE_DIR="${FINCH_DAEMON_PROJECT_ROOT}/release" LICENSE_FILE=${FINCH_DAEMON_PROJECT_ROOT}/THIRD_PARTY_LICENSES TAG_REGEX="v[0-9]+.[0-9]+.[0-9]+" -ARCH="" -case $(uname -m) in - x86_64) ARCH="amd64" ;; - *) echo "Error: Unsupported arch"; exit 1 ;; -esac - -if [ "$#" -ne 1 ]; then - echo "Expected 1 parameter, got $#." - echo "Usage: $0 [release_tag]" +ARCH="${TARGET_ARCH:-}" + +if [ -z "$ARCH" ]; then + case $(uname -m) in + x86_64) ARCH="amd64" ;; + aarch64) ARCH="arm64" ;; + *) echo "Error: Unsupported arch $(uname -m)"; exit 1 ;; + esac +fi + +echo "Using ARCH: $ARCH" + +if [ "$#" -lt 1 ]; then + echo "Expected 1 parameter (release_tag), got $#." + echo "Usage: $0 [architecture] [release_tag]" + echo "Supported architectures: amd64, arm64, arm" exit 1 fi @@ -46,30 +53,34 @@ if ! [[ "$1" =~ $TAG_REGEX ]]; then exit 1 fi +release_version=${1/v/} # Remove v from tag name +shift # Remove the release version argument + if [ -d "$RELEASE_DIR" ]; then rm -rf "${RELEASE_DIR:?}"/* else mkdir "$RELEASE_DIR" fi -release_version=${1/v/} # Remove v from tag name dynamic_binary_name=finch-daemon-${release_version}-linux-${ARCH}.tar.gz static_binary_name=finch-daemon-${release_version}-linux-${ARCH}-static.tar.gz -make build +# Build for the selected architecture +GOARCH=$ARCH make build cp "$LICENSE_FILE" "${OUT_DIR}" pushd "$OUT_DIR" tar -czvf "$RELEASE_DIR"/"$dynamic_binary_name" -- * popd rm -rf "{$OUT_DIR:?}"/* -STATIC=1 make build +STATIC=1 GOARCH=$ARCH make build cp "$LICENSE_FILE" "${OUT_DIR}" pushd "$OUT_DIR" tar -czvf "$RELEASE_DIR"/"$static_binary_name" -- * popd rm -rf "{$OUT_DIR:?}"/* +# Create checksums pushd "$RELEASE_DIR" sha256sum "$dynamic_binary_name" > "$RELEASE_DIR"/"$dynamic_binary_name".sha256sum sha256sum "$static_binary_name" > "$RELEASE_DIR"/"$static_binary_name".sha256sum diff --git a/scripts/verify-release-artifacts.sh b/scripts/verify-release-artifacts.sh index d90a9d3..181277f 100755 --- a/scripts/verify-release-artifacts.sh +++ b/scripts/verify-release-artifacts.sh @@ -22,7 +22,14 @@ cur_dir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" dinch_daemon_project_root="$(cd -- "$cur_dir"/.. && pwd)" release_dir="${dinch_daemon_project_root}/release" -arch="amd64" +arch="${TARGET_ARCH:-}" +if [ -z "$arch" ]; then + case $(uname -m) in + x86_64) arch="amd64" ;; + aarch64) arch="arm64" ;; + *) echo "Error: Unsupported arch $(uname -m)"; exit 1 ;; + esac +fi function usage { echo "Usage: $0 "