diff --git a/.github/workflows/update-dependencies.yaml b/.github/workflows/update-dependencies.yaml index d0101c1..239a26f 100644 --- a/.github/workflows/update-dependencies.yaml +++ b/.github/workflows/update-dependencies.yaml @@ -29,6 +29,7 @@ jobs: - name: update dependencies url run: | ./bin/update-deps.sh -d ${{ secrets.DEPENDENCY_BUCKET_NAME }} + ./bin/update-rootfs.sh -d ${{ secrets.DEPENDENCY_BUCKET_NAME }} - name: create PR uses: peter-evans/create-pull-request@v5 diff --git a/Makefile b/Makefile index 1f77a92..c365f51 100644 --- a/Makefile +++ b/Makefile @@ -31,6 +31,9 @@ ifneq (,$(findstring arm64,$(ARCH))) FINCH_OS_IMAGE_URL := $(FINCH_OS_AARCH64_URL) FINCH_OS_DIGEST ?= $(FINCH_OS_AARCH64_DIGEST) HOMEBREW_PREFIX ?= /opt/homebrew + + # TODO: Use Finch rootfs in Finch on Windows testing + FINCH_ROOTFS_URL ?= https://deps.runfinch.com/finch-rootfs-production-arm64-1690563031.tar.zst else ifneq (,$(findstring x86_64,$(ARCH))) LIMA_ARCH = x86_64 LIMA_URL ?= https://deps.runfinch.com/x86-64/lima-and-qemu.macos-x86_64.1689037160.tar.gz @@ -38,6 +41,9 @@ else ifneq (,$(findstring x86_64,$(ARCH))) FINCH_OS_IMAGE_URL := $(FINCH_OS_x86_URL) FINCH_OS_DIGEST ?= $(FINCH_OS_x86_DIGEST) HOMEBREW_PREFIX ?= /usr/local + + # TODO: Use Finch rootfs in Finch on Windows testing + FINCH_ROOTFS_URL ?= https://deps.runfinch.com/finch-rootfs-production-amd64-1690563027.tar.zst endif FINCH_OS_IMAGE_LOCATION ?= $(OUTDIR)/os/$(FINCH_OS_BASENAME) diff --git a/bin/update-rootfs.sh b/bin/update-rootfs.sh new file mode 100755 index 0000000..47a6108 --- /dev/null +++ b/bin/update-rootfs.sh @@ -0,0 +1,26 @@ +#!/bin/sh +set -euxo pipefail + +DEPENDENCY_CLOUDFRONT_URL="https://deps.runfinch.com/" +AARCH64_FILENAME_PATTERN="finch-rootfs-production-arm64-[0-9].*\.tar.zst$" +AMD64_FILENAME_PATTERN="finch-rootfs-production-amd64-[0-9].*\.tar.zst$" + +while getopts d: flag +do + case "${flag}" in + d) dependency_bucket=${OPTARG};; + esac +done + +[[ -z "$dependency_bucket" ]] && { echo "Error: Dependency bucket not set"; exit 1; } + +aarch64Deps=$(aws s3 ls s3://${dependency_bucket}/ | grep "$AARCH64_FILENAME_PATTERN" | sort | tail -n 1 | awk '{print $4}') + +[[ -z "$aarch64Deps" ]] && { echo "Error: aarch64 dependency not found"; exit 1; } + +amd64Deps=$(aws s3 ls s3://${dependency_bucket}/ | grep "$AMD64_FILENAME_PATTERN" | sort | tail -n 1 | awk '{print $4}') + +[[ -z "$amd64Deps" ]] && { echo "Error: x86_64 dependency not found"; exit 1; } + +sed -E -i.bak 's|^([[:blank:]]*FINCH_ROOTFS_URL[[:blank:]]*\?=[[:blank:]]*'${DEPENDENCY_CLOUDFRONT_URL}')('${AARCH64_FILENAME_PATTERN}')|\1'$aarch64Deps'|' Makefile +sed -E -i.bak 's|^([[:blank:]]*FINCH_ROOTFS_URL[[:blank:]]*\?=[[:blank:]]*'${DEPENDENCY_CLOUDFRONT_URL}')('${AMD64_FILENAME_PATTERN}')|\1'$amd64Deps'|' Makefile