From c0c9e5a953aacc19ef23dc67cd6f3ffa45d53448 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Maxime=20D=C3=A9n=C3=A8s?= Date: Mon, 13 Feb 2023 20:40:45 +0100 Subject: [PATCH 1/9] Test CI with self hosted macOS runner --- .github/workflows/macos.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/macos.yml b/.github/workflows/macos.yml index 4f5989691e..2e395aa99e 100644 --- a/.github/workflows/macos.yml +++ b/.github/workflows/macos.yml @@ -45,7 +45,7 @@ env: jobs: Macos_platform: name: Macos - runs-on: macos-latest + runs-on: self-hosted strategy: fail-fast: false matrix: @@ -150,7 +150,7 @@ jobs: Macos_smoke: name: Smoke test Macos needs: Macos_platform - runs-on: macos-latest + runs-on: self-hosted strategy: fail-fast: false matrix: From bb52551c05913032252f8e49cc117ec5441530dc Mon Sep 17 00:00:00 2001 From: Romain Tetley Date: Fri, 15 Dec 2023 10:07:56 +0100 Subject: [PATCH 2/9] Add labels for self-hosted. --- .github/workflows/macos.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/macos.yml b/.github/workflows/macos.yml index 2e395aa99e..599e85024c 100644 --- a/.github/workflows/macos.yml +++ b/.github/workflows/macos.yml @@ -45,7 +45,7 @@ env: jobs: Macos_platform: name: Macos - runs-on: self-hosted + runs-on: [self-hosted, macOS, ARM64] strategy: fail-fast: false matrix: @@ -150,7 +150,7 @@ jobs: Macos_smoke: name: Smoke test Macos needs: Macos_platform - runs-on: self-hosted + runs-on: [self-hosted, macOS, ARM64] strategy: fail-fast: false matrix: From 648abd2406b680972c55da1904e4604b03eb2647 Mon Sep 17 00:00:00 2001 From: Romain Tetley Date: Fri, 15 Dec 2023 10:54:48 +0100 Subject: [PATCH 3/9] Try without ARM64 --- .github/workflows/macos.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/macos.yml b/.github/workflows/macos.yml index 599e85024c..b567994bed 100644 --- a/.github/workflows/macos.yml +++ b/.github/workflows/macos.yml @@ -45,7 +45,7 @@ env: jobs: Macos_platform: name: Macos - runs-on: [self-hosted, macOS, ARM64] + runs-on: [self-hosted, macOS] strategy: fail-fast: false matrix: @@ -150,7 +150,7 @@ jobs: Macos_smoke: name: Smoke test Macos needs: Macos_platform - runs-on: [self-hosted, macOS, ARM64] + runs-on: [self-hosted, macOS] strategy: fail-fast: false matrix: From 1bae21c07aab38e8221b3e9d59d85b9c07f20a08 Mon Sep 17 00:00:00 2001 From: Romain Tetley Date: Fri, 15 Dec 2023 10:57:30 +0100 Subject: [PATCH 4/9] Trying without any labels --- .github/workflows/macos.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/macos.yml b/.github/workflows/macos.yml index b567994bed..2e395aa99e 100644 --- a/.github/workflows/macos.yml +++ b/.github/workflows/macos.yml @@ -45,7 +45,7 @@ env: jobs: Macos_platform: name: Macos - runs-on: [self-hosted, macOS] + runs-on: self-hosted strategy: fail-fast: false matrix: @@ -150,7 +150,7 @@ jobs: Macos_smoke: name: Smoke test Macos needs: Macos_platform - runs-on: [self-hosted, macOS] + runs-on: self-hosted strategy: fail-fast: false matrix: From f415645225d8ae12a2691e41866cef4bfb37a65a Mon Sep 17 00:00:00 2001 From: Romain Tetley Date: Mon, 18 Dec 2023 10:10:24 +0100 Subject: [PATCH 5/9] Trying to fix ci --- .github/workflows/macos.yml | 3 +++ 1 file changed, 3 insertions(+) diff --git a/.github/workflows/macos.yml b/.github/workflows/macos.yml index 2e395aa99e..642bdc624d 100644 --- a/.github/workflows/macos.yml +++ b/.github/workflows/macos.yml @@ -75,6 +75,9 @@ jobs: brew cleanup # See https://github.com/orgs/Homebrew/discussions/4612#discussioncomment-6351357 brew config + # Trying to avoid Error: No available tap homebrew/core or homebrew/cask. + brew tap --force homebrew/cask + brew tap --force homebrew/core brew untap homebrew/core homebrew/cask brew config brew update From 21de09a8aea8d5943be94adc1f5864c2d7f80fa3 Mon Sep 17 00:00:00 2001 From: Romain Tetley Date: Mon, 18 Dec 2023 14:22:17 +0100 Subject: [PATCH 6/9] Trying retry action --- .github/workflows/macos.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/macos.yml b/.github/workflows/macos.yml index 642bdc624d..68154561ce 100644 --- a/.github/workflows/macos.yml +++ b/.github/workflows/macos.yml @@ -128,10 +128,11 @@ jobs: pip3 install macpack - name: 'Build DMG installer' - uses: Wandalen/wretry.action@v1.3.0 + uses: Wandalen/wretry.action@master with: attempt_limit: 5 attempt_delay: 5000 + shell: bash command: | eval $(opam env) macos/create_installer_macos.sh From 54798ea35eb8ea7c4221ee3a866451e3576ce257 Mon Sep 17 00:00:00 2001 From: Romain Tetley Date: Tue, 19 Dec 2023 14:48:44 +0100 Subject: [PATCH 7/9] Fixing CI + better strategy for finding brew path --- macos/create_installer_macos.sh | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/macos/create_installer_macos.sh b/macos/create_installer_macos.sh index 656befe5e4..6eabfb0bdc 100755 --- a/macos/create_installer_macos.sh +++ b/macos/create_installer_macos.sh @@ -115,12 +115,13 @@ echo "##### Coq version = ${COQ_VERSION} (Mac app version=${COQ_VERSION_MACOS}) set +e PORTCMD="$(which port)" +BREWCMD="$(which brew)" set -e if [ -z "${PORTCMD}" ]; then PKG_MANAGER=brew - PKG_MANAGER_ROOT="/usr/local/" - PKG_MANAGER_ROOT_STRIP="/usr/local/Cellar/*/*/" # one * for the package name and one for its version + PKG_MANAGER_ROOT="${BREWCMD%bin/brew}" + PKG_MANAGER_ROOT_STRIP="${PKG_MANAGER_ROOT}Cellar/*/*/" # one * for the package name and one for its version else PKG_MANAGER=port # If someone knows a better way to find out where port is installed, please let me know! From 07084e46d0dbbcb1b5e0af98ddcdbf2959617a22 Mon Sep 17 00:00:00 2001 From: Romain Tetley Date: Wed, 20 Dec 2023 15:51:11 +0100 Subject: [PATCH 8/9] Renaming yaml file --- .github/workflows/{macos.yml => macos-arm.yml} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename .github/workflows/{macos.yml => macos-arm.yml} (100%) diff --git a/.github/workflows/macos.yml b/.github/workflows/macos-arm.yml similarity index 100% rename from .github/workflows/macos.yml rename to .github/workflows/macos-arm.yml From d70e167488dc722722c7c9eed2dda4aace063e3d Mon Sep 17 00:00:00 2001 From: Romain Tetley Date: Wed, 24 Apr 2024 15:59:56 +0200 Subject: [PATCH 9/9] Add github hosted runners --- .github/workflows/macos-intel.yml | 190 ++++++++++++++++++++++++++++++ 1 file changed, 190 insertions(+) create mode 100644 .github/workflows/macos-intel.yml diff --git a/.github/workflows/macos-intel.yml b/.github/workflows/macos-intel.yml new file mode 100644 index 0000000000..106d7ddf65 --- /dev/null +++ b/.github/workflows/macos-intel.yml @@ -0,0 +1,190 @@ +# Main doc: https://docs.github.com/en/free-pro-team@latest/actions/learn-github-actions/introduction-to-github-actions +# Runners spec: https://docs.github.com/en/free-pro-team@latest/actions/reference/specifications-for-github-hosted-runners +# Glob expressions: https://github.com/actions/toolkit/tree/main/packages/glob + +name: Macos + +############################################################################### +# Schedule: +# - push on any branch whose name matches v** or master +# - any pull request +############################################################################### +on: + push: + branches: + - 2021.02 + - 2021.09 + - main + pull_request: + branches: + - '**' + schedule: + - cron: "0 0 * * *" + workflow_dispatch: + inputs: + platform: + description: 'Arguments for the platform script:' + required: true + default: '-extent=x -parallel=p -jobs=2 -large=e -compcert=y -set-switch=y' + +############################################################################### +# Platform script options shared among all jobs +############################################################################### +env: + PLATFORM_ARGS: -extent=x -parallel=p -jobs=2 -large=e -compcert=y -set-switch=y + COQREGTESTING: y + HOMEBREW_NO_INSTALL_FROM_API: + # See https://github.com/orgs/Homebrew/discussions/4612#discussioncomment-6351357 + +############################################################################### +# Macos +# +# CAVEATS: +# - COQREGTESTING broken, it makes the script loop, so we install opam by hand +############################################################################### +jobs: + Macos_platform: + name: Macos + runs-on: macos-latest + strategy: + fail-fast: false + matrix: + variant: + # Keep this in sync with the Smoke test below + - '8.18~2023.11' + - '8.18~mc2~2023.11' + - '8.17~2023.08' + + steps: + - name: Git checkout + uses: actions/checkout@v2 + + - name: Set PLATFORM + if: ${{ github.event.inputs.platform != '' }} + run: echo "PLATFORM=${{ github.event.inputs.platform }}" >> $GITHUB_ENV + + - name: Cleanup, update and upgrade HomeBrew + # This is to avoid errors of these kinds: + # - ==> Downloading https://ghcr.io/v2/homebrew/core/harfbuzz/manifests/5.1.0 + # Error: adwaita-icon-theme: Failed to download resource "harfbuzz_bottle_manifest" + # The downloaded GitHub Packages manifest was corrupted or modified (it is not valid JSON): + # - dyld[45184]: Library not loaded: '/usr/local/opt/libunistring/lib/libunistring.2.dylib' + # Referenced from: '/usr/local/Cellar/wget/1.21.3/bin/wget' + # Reason: tried: '/usr/local/opt/libunistring/lib/libunistring.2.dylib' (no such file), + run: | + brew cleanup + # See https://github.com/orgs/Homebrew/discussions/4612#discussioncomment-6351357 + brew config + # Trying to avoid Error: No available tap homebrew/core or homebrew/cask. + brew tap --force homebrew/cask + brew tap --force homebrew/core + brew untap homebrew/core homebrew/cask + brew config + brew update + # Note: brew upgrade does fail regularly, but brew is anyway in a better state afterwards + brew upgrade || true + + - name: Install homebrew packages required by main script + run: brew install wget + + - name: Run common platform script + shell: bash + run: ./coq_platform_make.sh -packages=${{matrix.variant}} $PLATFORM_ARGS -dumplogs + + - name: Install bash (needed by smoke scripts) + run: brew install bash + + - name: Create smoke test kit + shell: bash + run: | + eval $(opam env) + export MACOSX_DEPLOYMENT_TARGET=10.13 + shell_scripts/create_smoke_test_kit.sh + + - name: 'Upload smoke test kit' + uses: actions/upload-artifact@v2 + with: + name: 'Smoke Test Kit Macos ${{matrix.variant}}' + path: smoke-test-kit/ + retention-days: 5 + + - name: Install findutils, coreutils and macpack (needed by DMG script) + run: | + brew install findutils + brew install coreutils + pip3 install macpack + + - name: 'Build DMG installer' + uses: Wandalen/wretry.action@master + with: + attempt_limit: 5 + attempt_delay: 5000 + shell: bash + command: | + eval $(opam env) + macos/create_installer_macos.sh + + - name: 'Upload DMG script logs on failure' + uses: actions/upload-artifact@v2 + if: failure() + with: + name: 'DMG script error logs ${{matrix.variant}}' + path: macos_installer/logs/ + + - name: 'Upload Artifact' + uses: actions/upload-artifact@v2 + with: + name: 'Macos installer ${{matrix.variant}} x86_64' + path: macos_installer/Coq-Platform-*.dmg + retention-days: 5 + + Macos_smoke: + name: Smoke test Macos + needs: Macos_platform + runs-on: macos-latest + strategy: + fail-fast: false + matrix: + variant: + - '8.18~2023.11' + - '8.18~mc2~2023.11' + - '8.17~2023.08' + + steps: + - name: Install bash + run: brew install bash + + - name: 'Download Artifact' + uses: actions/download-artifact@v2 + id: download + with: + name: 'Macos installer ${{matrix.variant}} x86_64' + + - name: 'Download smoke test kit' + uses: actions/download-artifact@v2 + id: download-smoke + with: + name: 'Smoke Test Kit Macos ${{matrix.variant}}' + + - name: 'Run Installer' + shell: bash + run: | + cd ${{steps.download.outputs.download-path}} + DMG=$(ls Coq-Platform-*.dmg) + hdiutil attach $DMG + cp -r /Volumes/${DMG%%.dmg}/Coq-Platform*.app /Applications/ + hdiutil detach /Volumes/${DMG%%.dmg}/ + + - name: 'Smoke coqc' + shell: bash + run: | + cd /Applications/Coq-Platform*.app/Contents/Resources/bin/ + ./coqc -v + + - name: 'Run Macos smoke test kit' + shell: bash + run: | + export PATH="$PATH:$(cd /Applications/Coq-Platform*.app/Contents/Resources/bin/; pwd)" + cd ${{steps.download-smoke.outputs.download-path}} + chmod a+x ./run-smoke-test.sh + ./run-smoke-test.sh