From 3f570dfa61a04081c52573918c6415bdc570cfc1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Guido=20Mart=C3=ADnez?= Date: Wed, 15 Jan 2025 10:41:27 -0800 Subject: [PATCH] Restoring self-hosted windows build --- .github/workflows/build-all.yml | 10 +-- .../workflows/build-windows-selfhosted.yml | 87 +++++++++++++++++++ .github/workflows/build-windows.yml | 2 +- .github/workflows/ci.yml | 2 + mk/src_package_mk.mk | 17 ++-- mk/stage0.mk | 1 - 6 files changed, 106 insertions(+), 13 deletions(-) create mode 100644 .github/workflows/build-windows-selfhosted.yml diff --git a/.github/workflows/build-all.yml b/.github/workflows/build-all.yml index 68739869a62..27dbfe5ab47 100644 --- a/.github/workflows/build-all.yml +++ b/.github/workflows/build-all.yml @@ -5,9 +5,9 @@ on: workflow_dispatch: jobs: - # Disable when Windows is reenabled. - build-src: - uses: ./.github/workflows/build-src.yml + # Windows build call this as a substep + # build-src: + # uses: ./.github/workflows/build-src.yml build-linux: uses: ./.github/workflows/build-linux.yml @@ -15,5 +15,5 @@ jobs: build-macos: uses: ./.github/workflows/build-macos.yml - # build-windows: - # uses: ./.github/workflows/build-windows.yml + build-windows: + uses: ./.github/workflows/build-windows-selfhosted.yml diff --git a/.github/workflows/build-windows-selfhosted.yml b/.github/workflows/build-windows-selfhosted.yml new file mode 100644 index 00000000000..9657e9dbbe5 --- /dev/null +++ b/.github/workflows/build-windows-selfhosted.yml @@ -0,0 +1,87 @@ +name: Build F* (Windows, self-hosted) + +on: + workflow_call: + workflow_dispatch: + push: + +jobs: + # We begin from a source package (built in Linux) + build-src: + uses: ./.github/workflows/build-src.yml + + build-windows: + needs: build-src + runs-on: [self-hosted, Windows, X64, opam-2-3] + # NOTE: no setup, the self-hosted runner already has all that is needed. + # This workflow also has many weird restrictions like + # having to set cygwin bash, cd into $GITHUB_WORKSPACE, and keep + # shell commands to a single line. + steps: + - name: clean + shell: C:\cygwin64\bin\bash.exe --login '{0}' + run: rm -vfr $GITHUB_WORKSPACE/* && echo "There is a CR at the end of this line" + # ^ clean the workspace + + - uses: actions/download-artifact@v4 + with: + name: package-src + - run: cd $GITHUB_WORKSPACE && tar xzf fstar-src.tar.gz + shell: C:\cygwin64\bin\bash.exe --login '{0}' + + - name: Set version + shell: C:\cygwin64\bin\bash.exe --login '{0}' + run: | + # Setting FSTAR_VERSION for nightly and release builds. If unset, + # we use $(version.txt)~dev. Setting it avoids the ~dev. + cd $GITHUB_WORKSPACE && if [[ "${{github.workflow_ref}}" =~ "nightly.yml" ]]; then echo FSTAR_VERSION="nightly-$(date -I)" >> $GITHUB_ENV; elif [[ "${{github.workflow_ref}}" =~ "release.yml" ]]; then echo FSTAR_VERSION="$(cat fstar/version.txt)" >> $GITHUB_ENV; echo FSTAR_RELEASE=1 >> $GITHUB_ENV; fi && echo "There is a CR at the end of this line" + + - name: Prepare environment + shell: C:\cygwin64\bin\bash.exe --login '{0}' + run: | + echo "CC=x86_64-w64-mingw32-gcc.exe" >> $GITHUB_ENV + echo "FSTAR_DUNE_OPTIONS=-j1" >> $GITHUB_ENV + echo "DUNE_CONFIG__BACKGROUND_SANDBOXES=disabled" >> $GITHUB_ENV + # ^ Related issues: + # https://github.com/ocaml/dune/issues/2324 + # https://github.com/ocaml/dune/issues/10076 + + - name: Build a package + shell: C:\cygwin64\bin\bash.exe --login '{0}' + run: | + cd $GITHUB_WORKSPACE && cd fstar && eval $(opam env) && make clean && make -j$(nproc) package V=1 ADMIT=1 && mv fstar.zip fstar-Windows_NT-x86_64.zip && echo "There is a CR at the end of this line" + # paranoid make clean above, seeing a bunch of these non predictably: + # File "libapp/dune", line 18, characters 13-56: + # 18 | (preprocess (pps ppx_deriving.show ppx_deriving_yojson)) + # ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + # Error: failed to delete sandbox in + # _build/.sandbox/e99d5dd0c933464aff5f4e9946b620a8) + + # - name: Test the package + # shell: C:\cygwin64\bin\bash.exe --login '{0}' + # run: | + # cd $GITHUB_WORKSPACE && cd fstar && eval $(opam env) && export CC=x86_64-w64-mingw32-gcc.exe && export CI_THREADS=$(nproc) && .scripts/test_package.sh && echo "There is a CR at the end of this line" + + - name: Upload artifact + uses: actions/upload-artifact@v4 + with: + path: fstar/fstar*.zip + name: package-win + + binary-smoke: + needs: build-windows + # This is a cloud job. + runs-on: windows-latest + steps: + - name: Get package + uses: actions/download-artifact@v4 + with: + name: package-win + + - run: unzip fstar*.zip + shell: bash + + - name: Smoke test + working-directory: fstar + run: | + ./bin/fstar.exe lib/fstar/ulib/Prims.fst -f -d diff --git a/.github/workflows/build-windows.yml b/.github/workflows/build-windows.yml index 86f6485602e..6d227606d37 100644 --- a/.github/workflows/build-windows.yml +++ b/.github/workflows/build-windows.yml @@ -20,7 +20,7 @@ defaults: bash jobs: - # We being from a source package (built in Linux) + # We begin from a source package (built in Linux) build-src: uses: ./.github/workflows/build-src.yml diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index e51bb02926a..53992ea86d0 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -2,6 +2,8 @@ name: CI on: push: + branches-ignore: + - _** pull_request: workflow_dispatch: merge_group: diff --git a/mk/src_package_mk.mk b/mk/src_package_mk.mk index 480a857c9da..f603169b785 100644 --- a/mk/src_package_mk.mk +++ b/mk/src_package_mk.mk @@ -22,12 +22,14 @@ # (version 4.4.1-1 at least) to (sometimes) freeze , and halt the build. # Not running this makefile (and sub-makes) in parallel *seems* to help, # though obviously makes this significantly slower in Windows. -ifeq ($(OS),Windows_NT) -.NOTPARALLEL: -MAYBEJ1=-j1 -else -MAYBEJ1= -endif +# LATER EDIT: For the self-hosted runner, this does not seem to be a problem, +# so do not restrict parallelism. +# ifeq ($(OS),Windows_NT) +# .NOTPARALLEL: +# MAYBEJ1=-j1 +# else +# MAYBEJ1= +# endif include mk/common.mk @@ -49,6 +51,9 @@ else cygpath=$(abspath "$(1)") endif +.NOTPARALLEL: +# ^ Prevent concurrent dune invocations + build: $(call msg, "DUNE BUILD") dune build --root=dune $(FSTAR_DUNE_BUILD_OPTIONS) diff --git a/mk/stage0.mk b/mk/stage0.mk index ea9e676f35f..ba2786f5ab2 100644 --- a/mk/stage0.mk +++ b/mk/stage0.mk @@ -1,4 +1,3 @@ -# This file is used (or created) by the bring-stage0 rule in the toplevel Makefile include $(FSTAR_ROOT)/mk/common.mk