variables: GIT_SSL_NO_VERIFY: "1" # Commit of ghc/ci-images repository from which to pull Docker images DOCKER_REV: e1cdfaea745989faa266f09c1d6c4c981aa34dc6 # Sequential version number capturing the versions of all tools fetched by # .gitlab/ci.sh. WINDOWS_TOOLCHAIN_VERSION: 2 # Disable shallow clones; they break our linting rules GIT_DEPTH: 0 # Overridden by individual jobs CONFIGURE_ARGS: "" GIT_SUBMODULE_STRATEGY: "recursive" stages: - lint # Source linting - quick-build # A very quick smoke-test to weed out broken commits - build # A quick smoke-test to weed out broken commits - full-build # Build all the things - cleanup # See Note [Cleanup after the shell executor] - packaging # Source distribution, etc. - testing # head.hackage correctness and compiler performance testing - deploy # push documentation # Note [The CI Story] # ~~~~~~~~~~~~~~~~~~~ # # There are two different types of pipelines: # # - marge-bot merges to `master`. Here we perform an exhaustive validation # across all of the platforms which we support. In addition, we push # performance metric notes upstream, providing a persistent record of the # performance characteristics of the compiler. # # - merge requests. Here we perform a slightly less exhaustive battery of # testing. Namely we omit some configurations (e.g. the unregisterised job). # These use the merge request's base commit for performance metric # comparisons. # workflow: # N.B. Don't run on wip/ branches, instead on run on merge requests. rules: - if: $CI_MERGE_REQUEST_ID - if: $CI_COMMIT_TAG - if: '$CI_COMMIT_BRANCH == "master"' - if: '$CI_COMMIT_BRANCH == "wip/marge_bot_batch_merge_job"' - if: '$CI_COMMIT_BRANCH =~ /ghc-[0-9]+\.[0-9]+/' - if: '$CI_PIPELINE_SOURCE == "web"' .nightly: &nightly rules: - if: $NIGHTLY artifacts: when: always expire_in: 8 weeks .release: &release variables: BUILD_FLAVOUR: "perf" FLAVOUR: "perf" artifacts: when: always expire_in: 1 year rules: - if: '$RELEASE_JOB == "yes"' ############################################################ # Runner Tags ############################################################ # # * x86_64-linux: Any Docker-capable x86_64 Linux machine # * aarch64-linux: Any Docker-capable AArch64 Linux machine # * x86_64-windows: A x86_64 Windows machine # * lint: Any Docker-capable x86_64 Linux machine; distinct from # x86_64-linux to ensure low-latency availability. # ############################################################ # Linting ############################################################ ghc-linters: stage: lint image: "registry.gitlab.haskell.org/ghc/ci-images/linters:$DOCKER_REV" script: - git fetch "$CI_MERGE_REQUEST_PROJECT_URL" $CI_MERGE_REQUEST_TARGET_BRANCH_NAME - base="$(git merge-base FETCH_HEAD $CI_COMMIT_SHA)" - "echo Linting changes between $base..$CI_COMMIT_SHA" # - validate-commit-msg .git $(git rev-list $base..$CI_COMMIT_SHA) - validate-whitespace .git $(git rev-list $base..$CI_COMMIT_SHA) - .gitlab/linters/check-makefiles.py commits $base $CI_COMMIT_SHA - .gitlab/linters/check-cpp.py commits $base $CI_COMMIT_SHA - .gitlab/linters/check-version-number.sh - python3 utils/checkUniques/check-uniques.py . dependencies: [] tags: - lint rules: - if: $CI_MERGE_REQUEST_ID # Run mypy Python typechecker on linter scripts. lint-linters: stage: lint image: "registry.gitlab.haskell.org/ghc/ci-images/linters:$DOCKER_REV" script: - mypy .gitlab/linters/*.py dependencies: [] tags: - lint # Check that .T files all parse by listing broken tests. lint-testsuite: stage: lint image: "registry.gitlab.haskell.org/ghc/ci-images/x86_64-linux-deb9:$DOCKER_REV" script: - make -Ctestsuite list_broken TEST_HC=$GHC dependencies: [] tags: - lint # Run mypy Python typechecker on testsuite driver typecheck-testsuite: stage: lint image: "registry.gitlab.haskell.org/ghc/ci-images/linters:$DOCKER_REV" script: - mypy testsuite/driver/runtests.py dependencies: [] tags: - lint # We allow the submodule checker to fail when run on merge requests (to # accommodate, e.g., haddock changes not yet upstream) but not on `master` or # Marge jobs. .lint-submods: stage: lint image: "registry.gitlab.haskell.org/ghc/ci-images/linters:$DOCKER_REV" script: - git fetch "$CI_MERGE_REQUEST_PROJECT_URL" $CI_MERGE_REQUEST_TARGET_BRANCH_NAME - base="$(git merge-base FETCH_HEAD $CI_COMMIT_SHA)" - "echo Linting submodule changes between $base..$CI_COMMIT_SHA" - git submodule foreach git remote update - submodchecker . $(git rev-list $base..$CI_COMMIT_SHA) dependencies: [] tags: - lint lint-submods: extends: .lint-submods # Allow failure on merge requests since any necessary submodule patches may # not be upstreamed yet. rules: - if: '$CI_MERGE_REQUEST_LABELS =~ /.*marge_bot_batch_merge_job.*/' allow_failure: false - allow_failure: true lint-submods-branch: extends: .lint-submods script: - "echo Linting submodule changes between $CI_COMMIT_BEFORE_SHA..$CI_COMMIT_SHA" - git submodule foreach git remote update - submodchecker . $(git rev-list $CI_COMMIT_BEFORE_SHA..$CI_COMMIT_SHA) rules: - if: '$CI_COMMIT_BRANCH == "master"' - if: '$CI_COMMIT_BRANCH =~ /ghc-[0.9]+\.[0-9]+/' .lint-changelogs: stage: lint image: "registry.gitlab.haskell.org/ghc/ci-images/linters:$DOCKER_REV" dependencies: [] tags: - lint script: - bash .gitlab/linters/check-changelogs.sh lint-changelogs: extends: .lint-changelogs # Allow failure since this isn't a final release. allow_failure: true rules: - if: '$CI_COMMIT_BRANCH =~ /ghc-[0.9]+\.[0-9]+/' lint-release-changelogs: extends: .lint-changelogs rules: - if: '$CI_COMMIT_BRANCH =~ /ghc-[0.9]+\.[0-9]+/' ############################################################ # Validation via Pipelines (hadrian) ############################################################ .validate-hadrian: variables: FLAVOUR: "validate" script: - .gitlab/ci.sh setup - .gitlab/ci.sh configure - .gitlab/ci.sh build_hadrian - .gitlab/ci.sh test_hadrian cache: key: hadrian paths: - cabal-cache dependencies: [] artifacts: reports: junit: junit.xml expire_in: 2 week paths: - ghc.tar.xz - junit.xml .validate-linux-hadrian: extends: .validate-hadrian image: "registry.gitlab.haskell.org/ghc/ci-images/x86_64-linux-deb9:$DOCKER_REV" variables: TEST_ENV: "x86_64-linux-deb9-hadrian" before_script: # workaround for docker permissions - sudo chown ghc:ghc -R . - git submodule sync --recursive - git submodule update --init --recursive - git checkout .gitmodules - "git fetch https://gitlab.haskell.org/ghc/ghc-performance-notes.git refs/notes/perf:refs/notes/perf || true" after_script: - cp -Rf $HOME/.cabal cabal-cache - .gitlab/ci.sh clean tags: - x86_64-linux validate-x86_64-linux-deb9-hadrian: extends: .validate-linux-hadrian stage: build validate-x86_64-linux-deb9-unreg-hadrian: extends: .validate-linux-hadrian stage: full-build variables: CONFIGURE_ARGS: --enable-unregisterised TEST_ENV: "x86_64-linux-deb9-unreg-hadrian" hadrian-ghc-in-ghci: stage: quick-build image: "registry.gitlab.haskell.org/ghc/ci-images/x86_64-linux-deb9:$DOCKER_REV" before_script: # workaround for docker permissions - sudo chown ghc:ghc -R . - git submodule sync --recursive - git submodule update --init --recursive - git checkout .gitmodules variables: GHC_FLAGS: -Werror tags: - x86_64-linux script: - .gitlab/ci.sh setup - cabal update - cd hadrian; cabal new-build -j`../mk/detect-cpu-count.sh` --with-compiler=$GHC --project-file=ci.project; cd .. - git clean -xdf && git submodule foreach git clean -xdf - ./boot - ./configure $CONFIGURE_ARGS # Load ghc-in-ghci then immediately exit and check the modules loaded - echo ":q" | hadrian/ghci -j`mk/detect-cpu-count.sh`| tail -n2 | grep "Ok," after_script: - cp -Rf $HOME/.cabal cabal-cache cache: key: hadrian-ghci paths: - cabal-cache ############################################################ # Validation via Pipelines (make) ############################################################ .validate: variables: TEST_TYPE: test MAKE_ARGS: "-Werror" script: - .gitlab/ci.sh setup - .gitlab/ci.sh configure - .gitlab/ci.sh build_make - .gitlab/ci.sh test_make dependencies: [] artifacts: reports: junit: junit.xml expire_in: 2 week paths: - $BIN_DIST_PREP_TAR_COMP - junit.xml - performance-metrics.tsv ################################# # x86_64-freebsd ################################# .build-x86_64-freebsd: extends: .validate tags: - x86_64-freebsd allow_failure: true variables: # N.B. we use iconv from ports as I see linker errors when we attempt # to use the "native" iconv embedded in libc as suggested by the # porting guide [1]. # [1] https://www.freebsd.org/doc/en/books/porters-handbook/using-iconv.html) CONFIGURE_ARGS: "--with-gmp-includes=/usr/local/include --with-gmp-libraries=/usr/local/lib --with-iconv-includes=/usr/local/include --with-iconv-libraries=/usr/local/lib" GHC_VERSION: "8.10.1" CABAL_INSTALL_VERSION: "3.2.0.0" BIN_DIST_PREP_TAR_COMP: "ghc-x86_64-portbld-freebsd.tar.xz" TEST_ENV: "x86_64-freebsd" BUILD_FLAVOUR: "validate" after_script: - cp -Rf $HOME/.cabal cabal-cache - .gitlab/ci.sh clean artifacts: when: always expire_in: 2 week cache: key: "freebsd-$GHC_VERSION" paths: - cabal-cache - toolchain # Conditional due to lack of builder capacity validate-x86_64-freebsd: extends: .build-x86_64-freebsd stage: full-build rules: - if: '$CI_MERGE_REQUEST_LABELS =~ /.*FreeBSD.*/' nightly-x86_64-freebsd: <<: *nightly extends: .build-x86_64-freebsd stage: full-build release-x86_64-freebsd: <<: *release extends: .build-x86_64-freebsd stage: full-build .build-x86_64-freebsd-hadrian: extends: .validate-hadrian stage: full-build tags: - x86_64-freebsd allow_failure: true variables: CONFIGURE_ARGS: "--with-gmp-includes=/usr/local/include --with-gmp-libraries=/usr/local/lib --with-iconv-includes=/usr/local/include --with-iconv-libraries=/usr/local/lib" HADRIAN_ARGS: "--docs=no-sphinx" GHC_VERSION: 8.6.3 CABAL_INSTALL_VERSION: 3.0.0.0 BIN_DIST_PREP_TAR_COMP: "ghc-x86_64-portbld-freebsd.tar.xz" TEST_ENV: "x86_64-freebsd-hadrian" FLAVOUR: "validate" after_script: - cp -Rf $HOME/.cabal cabal-cache - .gitlab/ci.sh clean artifacts: when: always expire_in: 2 week cache: key: "freebsd-$GHC_VERSION" paths: - cabal-cache - toolchain # Disabled due to lack of builder capacity .validate-x86_64-freebsd-hadrian: extends: .build-x86_64-freebsd-hadrian stage: full-build ################################# # x86_64-darwin ################################# validate-x86_64-darwin: extends: .validate stage: full-build tags: - x86_64-darwin variables: GHC_VERSION: 8.8.4 CABAL_INSTALL_VERSION: 3.0.0.0 BIN_DIST_PREP_TAR_COMP: "ghc-x86_64-apple-darwin.tar.xz" MACOSX_DEPLOYMENT_TARGET: "10.7" # Only Sierra and onwards supports clock_gettime. See #12858 ac_cv_func_clock_gettime: "no" LANG: "en_US.UTF-8" CONFIGURE_ARGS: "--with-intree-gmp" TEST_ENV: "x86_64-darwin" BUILD_FLAVOUR: "perf" after_script: - cp -Rf $HOME/.cabal cabal-cache - .gitlab/ci.sh clean artifacts: when: always expire_in: 2 week cache: key: "darwin-$GHC_VERSION" paths: - cabal-cache - toolchain # Disabled because of OS X CI capacity .validate-x86_64-darwin-hadrian: stage: full-build tags: - x86_64-darwin variables: GHC_VERSION: 8.8.4 MACOSX_DEPLOYMENT_TARGET: "10.7" ac_cv_func_clock_gettime: "no" LANG: "en_US.UTF-8" CONFIGURE_ARGS: --with-intree-gmp TEST_ENV: "x86_64-darwin-hadrian" FLAVOUR: "validate" script: - .gitlab/ci.sh setup - .gitlab/ci.sh configure - .gitlab/ci.sh build_hadrian - .gitlab/ci.sh test_hadrian after_script: - cp -Rf $HOME/.cabal cabal-cache - .gitlab/ci.sh clean artifacts: when: always expire_in: 2 week reports: junit: junit.xml paths: - ghc.tar.xz - junit.xml .validate-linux: extends: .validate tags: - x86_64-linux variables: BUILD_FLAVOUR: "perf" before_script: # Build hyperlinked sources for documentation when building releases - | if [[ -n "$CI_COMMIT_TAG" ]]; then HADDOCK_HYPERLINKED_SOURCES=1 fi # workaround for docker permissions - sudo chown ghc:ghc -R . after_script: - cp -Rf $HOME/.cabal cabal-cache cache: key: linux paths: - cabal-cache - toolchain ################################# # aarch64-linux-deb10 ################################# .build-aarch64-linux-deb10: extends: .validate-linux stage: full-build image: "registry.gitlab.haskell.org/ghc/ci-images/aarch64-linux-deb10:$DOCKER_REV" allow_failure: true variables: TEST_ENV: "aarch64-linux-deb10" BIN_DIST_PREP_TAR_COMP: "ghc-aarch64-linux-deb10.tar.xz" cache: key: linux-aarch64-deb10 tags: - aarch64-linux validate-aarch64-linux-deb10: extends: .build-aarch64-linux-deb10 artifacts: when: always expire_in: 2 week nightly-aarch64-linux-deb10: <<: *nightly extends: .build-aarch64-linux-deb10 variables: TEST_TYPE: slowtest ################################# # armv7-linux-deb10 ################################# .build-armv7-linux-deb10: extends: .validate-linux stage: full-build image: "registry.gitlab.haskell.org/ghc/ci-images/armv7-linux-deb10:$DOCKER_REV" # Due to linker issues allow_failure: true variables: TEST_ENV: "armv7-linux-deb10" BIN_DIST_PREP_TAR_COMP: "ghc-armv7-linux-deb10.tar.xz" CONFIGURE_ARGS: "--host=armv7-linux-gnueabihf --build=armv7-linux-gnueabihf --target=armv7-linux-gnueabihf" # N.B. We disable ld.lld explicitly here because it appears to fail # non-deterministically on ARMv7. See #18280. LD: "ld.gold" GccUseLdOpt: "-fuse-ld=gold" cache: key: linux-armv7-deb10 tags: - armv7-linux validate-armv7-linux-deb10: extends: .build-armv7-linux-deb10 artifacts: when: always expire_in: 2 week nightly-armv7-linux-deb10: <<: *nightly extends: .build-armv7-linux-deb10 variables: TEST_TYPE: slowtest ################################# # i386-linux-deb9 ################################# .build-i386-linux-deb9: extends: .validate-linux stage: full-build image: "registry.gitlab.haskell.org/ghc/ci-images/i386-linux-deb9:$DOCKER_REV" variables: TEST_ENV: "i386-linux-deb9" BIN_DIST_PREP_TAR_COMP: "ghc-i386-deb9-linux.tar.xz" cache: key: linux-i386-deb9 validate-i386-linux-deb9: extends: .build-i386-linux-deb9 artifacts: when: always expire_in: 2 week nightly-i386-linux-deb9: <<: *nightly extends: .build-i386-linux-deb9 variables: TEST_TYPE: slowtest ################################# # x86_64-linux-deb9 ################################# .build-x86_64-linux-deb9: extends: .validate-linux image: "registry.gitlab.haskell.org/ghc/ci-images/x86_64-linux-deb9:$DOCKER_REV" variables: TEST_ENV: "x86_64-linux-deb9" BIN_DIST_PREP_TAR_COMP: "./ghc-x86_64-deb9-linux.tar.xz" cache: key: linux-x86_64-deb9 # Disabled to reduce CI load .validate-x86_64-linux-deb9: extends: .build-x86_64-linux-deb9 stage: full-build artifacts: when: always expire_in: 2 week release-x86_64-linux-deb9: <<: *release extends: .build-x86_64-linux-deb9 stage: full-build nightly-x86_64-linux-deb9: <<: *nightly extends: .build-x86_64-linux-deb9 stage: full-build variables: TEST_TYPE: slowtest # N.B. Has DEBUG assertions enabled in stage2 validate-x86_64-linux-deb9-debug: extends: .build-x86_64-linux-deb9 stage: full-build variables: BUILD_FLAVOUR: validate # Ensure that stage2 also has DEBUG enabled ValidateSpeed: SLOW # Override validate flavour default; see #16890. BUILD_SPHINX_PDF: "YES" TEST_TYPE: slowtest TEST_ENV: "x86_64-linux-deb9-debug" BIN_DIST_PREP_TAR_COMP: "ghc-x86_64-deb9-linux-debug.tar.xz" artifacts: when: always expire_in: 2 week # Disabled to alleviate CI load .validate-x86_64-linux-deb9-llvm: extends: .build-x86_64-linux-deb9 stage: full-build variables: BUILD_FLAVOUR: perf-llvm TEST_ENV: "x86_64-linux-deb9-llvm" nightly-x86_64-linux-deb9-llvm: <<: *nightly extends: .build-x86_64-linux-deb9 stage: full-build variables: BUILD_FLAVOUR: perf-llvm TEST_ENV: "x86_64-linux-deb9-llvm" validate-x86_64-linux-deb9-integer-simple: extends: .build-x86_64-linux-deb9 stage: full-build variables: BUILD_FLAVOUR: validate BIGNUM_BACKEND: native TEST_ENV: "x86_64-linux-deb9-integer-simple-validate" BIN_DIST_PREP_TAR_COMP: "ghc-x86_64-deb9-linux-integer-simple.tar.xz" nightly-x86_64-linux-deb9-integer-simple: <<: *nightly extends: .build-x86_64-linux-deb9 stage: full-build variables: BIGNUM_BACKEND: native TEST_ENV: "x86_64-linux-deb9-integer-simple" TEST_TYPE: slowtest validate-x86_64-linux-deb9-dwarf: extends: .build-x86_64-linux-deb9 stage: full-build variables: CONFIGURE_ARGS: "--enable-dwarf-unwind" BUILD_FLAVOUR: dwarf TEST_ENV: "x86_64-linux-deb9-dwarf" BIN_DIST_PREP_TAR_COMP: "ghc-x86_64-deb9-linux-dwarf.tar.xz" ################################# # x86_64-linux-deb10 ################################# .build-x86_64-linux-deb10: extends: .validate-linux stage: full-build image: "registry.gitlab.haskell.org/ghc/ci-images/x86_64-linux-deb10:$DOCKER_REV" variables: TEST_ENV: "x86_64-linux-deb10" BIN_DIST_PREP_TAR_COMP: "./ghc-x86_64-deb10-linux.tar.xz" cache: key: linux-x86_64-deb10 # Disabled to alleviate CI load .validate-x86_64-linux-deb10: extends: .build-x86_64-linux-deb10 stage: full-build nightly-x86_64-linux-deb10: <<: *nightly extends: .build-x86_64-linux-deb10 variables: TEST_TYPE: slowtest release-x86_64-linux-deb10: <<: *release extends: .build-x86_64-linux-deb10 ################################# # x86_64-linux-ubuntu 20.04 ################################# .build-x86_64-linux-ubuntu2004: extends: .validate-linux stage: full-build image: "registry.gitlab.haskell.org/ghc/ci-images/x86_64-linux-ubuntu2004:$DOCKER_REV" variables: TEST_ENV: "x86_64-linux-ubuntu2004" BIN_DIST_PREP_TAR_COMP: "./ghc-x86_64-ubuntu2004-linux.tar.xz" cache: key: linux-x86_64-ubuntu2004 # Disabled to alleviate CI load .validate-x86_64-linux-ubuntu2004: extends: .build-x86_64-linux-ubuntu2004 stage: full-build nightly-x86_64-linux-ubuntu2004: <<: *nightly extends: .build-x86_64-linux-ubuntu2004 variables: TEST_TYPE: slowtest release-x86_64-linux-ubuntu2004: <<: *release extends: .build-x86_64-linux-ubuntu2004 ################################# # x86_64-linux-deb8 ################################# .build-x86_64-linux-deb8: extends: .validate-linux stage: full-build image: "registry.gitlab.haskell.org/ghc/ci-images/x86_64-linux-deb8:$DOCKER_REV" # Due to #18298. allow_failure: true variables: TEST_ENV: "x86_64-linux-deb8" BIN_DIST_PREP_TAR_COMP: "ghc-x86_64-deb8-linux.tar.xz" # Debian 8's Sphinx is too old to support the table directive's :widths: # option: https://sourceforge.net/p/docutils/patches/120/ BUILD_SPHINX_HTML: "NO" BUILD_SPHINX_INFO: "NO" BUILD_SPHINX_PDF: "NO" BUILD_SPHINX_MAN: "NO" cache: key: linux-x86_64-deb8 release-x86_64-linux-deb8: <<: *release extends: .build-x86_64-linux-deb8 ################################# # x86_64-linux-alpine ################################# .build-x86_64-linux-alpine-hadrian: extends: .validate-linux-hadrian stage: full-build image: "registry.gitlab.haskell.org/ghc/ci-images/x86_64-linux-alpine3_12:$DOCKER_REV" # There are currently a few failing tests allow_failure: true variables: TEST_ENV: "x86_64-linux-alpine" BIN_DIST_PREP_TAR_COMP: "ghc-x86_64-alpine-linux.tar.xz" # Can't use ld.gold due to #13958. CONFIGURE_ARGS: "--disable-ld-override" HADRIAN_ARGS: "--docs=no-sphinx" # encoding004 due to lack of locale support # T10458 due to fact that dynamic linker tries to reload libAS BROKEN_TESTS: "encoding004 T10458" cache: key: linux-x86_64-alpine artifacts: when: always expire_in: 2 week release-x86_64-linux-alpine: <<: *release extends: .build-x86_64-linux-alpine-hadrian nightly-x86_64-linux-alpine: <<: *nightly extends: .build-x86_64-linux-alpine-hadrian ################################# # x86_64-linux-centos7 ################################# .build-x86_64-linux-centos7: extends: .validate-linux stage: full-build image: "registry.gitlab.haskell.org/ghc/ci-images/x86_64-linux-centos7:$DOCKER_REV" variables: # The sphinx release shipped with Centos 7 fails to build out documentation BUILD_SPHINX_HTML: "NO" BUILD_SPHINX_PDF: "NO" TEST_ENV: "x86_64-linux-centos7" BIN_DIST_PREP_TAR_COMP: "ghc-x86_64-centos7-linux.tar.xz" # CentOS seems to default to ascii LANG: "en_US.UTF-8" cache: key: linux-x86_64-centos7 release-x86_64-linux-centos7: <<: *release extends: .build-x86_64-linux-centos7 ################################# # x86_64-linux-fedora27 ################################# validate-x86_64-linux-fedora27: extends: .validate-linux stage: full-build image: "registry.gitlab.haskell.org/ghc/ci-images/x86_64-linux-fedora27:$DOCKER_REV" variables: TEST_ENV: "x86_64-linux-fedora27" BIN_DIST_PREP_TAR_COMP: "ghc-x86_64-fedora27-linux.tar.xz" cache: key: linux-x86_64-fedora27 artifacts: when: always # These are used for head.hackage jobs therefore we keep them around for # longer. expire_in: 8 week ############################################################ # Validation via Pipelines (Windows) ############################################################ .build-windows: # For the reasons given in #17777 this build isn't reliable. allow_failure: true before_script: - git clean -xdf # Setup toolchain - bash .gitlab/ci.sh setup after_script: - | Copy-Item -Recurse -Path $Env:APPDATA\cabal -Destination cabal-cache - bash .gitlab/ci.sh clean dependencies: [] variables: #FORCE_SYMLINKS: 1 LANG: "en_US.UTF-8" SPHINXBUILD: "/mingw64/bin/sphinx-build.exe" CABAL_INSTALL_VERSION: "3.0.0.0" GHC_VERSION: "8.8.4" cache: paths: - cabal-cache - toolchain - ghc-tarballs .build-windows-hadrian: extends: .build-windows stage: full-build variables: FLAVOUR: "validate" # skipping perf tests for now since we build a quick-flavoured GHC, # which might result in some broken perf tests? HADRIAN_ARGS: "--docs=no-sphinx --skip-perf" script: - bash .gitlab/ci.sh configure - bash .gitlab/ci.sh build_hadrian - bash .gitlab/ci.sh test_hadrian tags: - new-x86_64-windows - test artifacts: reports: junit: junit.xml expire_in: 2 week when: always paths: - ghc.tar.xz - junit.xml .build-x86_64-windows-hadrian: extends: .build-windows-hadrian variables: MSYSTEM: MINGW64 TEST_ENV: "x86_64-windows" cache: key: "x86_64-windows-$WINDOWS_TOOLCHAIN_VERSION" validate-x86_64-windows-hadrian: extends: .build-x86_64-windows-hadrian .build-windows-make: extends: .build-windows stage: full-build variables: BUILD_FLAVOUR: "quick" BIN_DIST_PREP_TAR_COMP: "ghc-x86_64-mingw32.tar.xz" script: - bash .gitlab/ci.sh configure - bash .gitlab/ci.sh build_make - bash .gitlab/ci.sh test_make tags: - new-x86_64-windows - test artifacts: when: always expire_in: 2 week reports: junit: junit.xml paths: # N.B. variable interpolation apparently doesn't work on Windows so # this can't be $BIN_DIST_PREP_TAR_COMP - "ghc-x86_64-mingw32.tar.xz" - junit.xml .build-x86_64-windows-make: extends: .build-windows-make variables: MSYSTEM: MINGW64 TEST_ENV: "x86_64-windows" cache: key: "x86_64-windows-$WINDOWS_TOOLCHAIN_VERSION" nightly-x86_64-windows: <<: *nightly extends: .build-x86_64-windows-make stage: full-build variables: BUILD_FLAVOUR: "validate" # Normal Windows validate builds lack profiled libraries; that won't do for # releases. release-x86_64-windows: <<: *release extends: .build-x86_64-windows-hadrian variables: BUILD_FLAVOUR: "perf" release-x86_64-windows-integer-simple: <<: *release extends: .build-x86_64-windows-hadrian variables: BIGNUM_BACKEND: native BUILD_FLAVOUR: "perf" ############################################################ # Cleanup ############################################################ # Note [Cleaning up after shell executor] # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ # # As noted in [1], gitlab-runner's shell executor doesn't clean up its working # directory after builds. Unfortunately, we are forced to use the shell executor # on Darwin. To avoid running out of disk space we add a stage at the end of # the build to remove the /.../GitLabRunner/builds directory. Since we only run a # single build at a time on Darwin this should be safe. # # We used to have a similar cleanup job on Windows as well however it ended up # being quite fragile as we have multiple Windows builders yet there is no # guarantee that the cleanup job is run on the same machine as the build itself # was run. Consequently we were forced to instead handle cleanup with a separate # cleanup cron job on Windows. # # [1] https://gitlab.com/gitlab-org/gitlab-runner/issues/3856 # See Note [Cleanup after shell executor] cleanup-darwin: stage: cleanup tags: - x86_64-darwin when: always dependencies: [] before_script: - echo "Time to clean up" script: - echo "Let's go" after_script: - BUILD_DIR=$CI_PROJECT_DIR - echo "Cleaning $BUILD_DIR" - cd $HOME - rm -Rf $BUILD_DIR/* - exit 0 ############################################################ # Packaging ############################################################ doc-tarball: stage: packaging tags: - x86_64-linux image: "registry.gitlab.haskell.org/ghc/ci-images/x86_64-linux-deb9:$DOCKER_REV" dependencies: - validate-x86_64-linux-deb9-debug - validate-x86_64-windows-hadrian variables: LINUX_BINDIST: "ghc-x86_64-deb9-linux-debug.tar.xz" WINDOWS_BINDIST: "ghc-x86_64-mingw32.tar.xz" # Due to Windows allow_failure allow_failure: true artifacts: paths: - haddock.html.tar.xz - libraries.html.tar.xz - users_guide.html.tar.xz - index.html - "*.pdf" script: - | if [ ! -f "$LINUX_BINDIST" ]; then echo "Error: $LINUX_BINDIST does not exist. Did the Debian 9 job fail?" exit 1 fi if [ ! -f "$WINDOWS_BINDIST" ]; then echo "Error: $WINDOWS_BINDIST does not exist. Did the 64-bit Windows job fail?" exit 1 fi - rm -Rf docs - bash -ex distrib/mkDocs/mkDocs $LINUX_BINDIST $WINDOWS_BINDIST - ls -lh - mv docs/*.tar.xz docs/index.html . source-tarball: stage: packaging tags: - x86_64-linux image: "registry.gitlab.haskell.org/ghc/ci-images/x86_64-linux-deb9:$DOCKER_REV" dependencies: [] rules: - if: $CI_COMMIT_TAG when: always artifacts: paths: - ghc-*.tar.xz - version script: - python3 mk/get-win32-tarballs.py download all - ./boot - ./configure - make sdist - mv sdistprep/*.xz . - make show! --quiet VALUE=ProjectVersion > version - source version - echo "$ProjectVersion" > version ############################################################ # Testing via head.hackage ############################################################ # Triggering jobs in the ghc/head.hackage project requires that we have a job # token for that repository. Furthermore the head.hackage CI job must have # access to an unprivileged access token with the ability to query the ghc/ghc # project such that it can find the job ID of the fedora27 job for the current # pipeline. .hackage: stage: testing image: ghcci/x86_64-linux-deb9:0.2 tags: - x86_64-linux dependencies: [] variables: HEAD_HACKAGE_PROJECT_ID: "78" script: - bash .gitlab/start-head.hackage.sh hackage: extends: .hackage when: manual hackage-label: extends: .hackage rules: - if: '$CI_MERGE_REQUEST_LABELS =~ /.*user-facing.*/' nightly-hackage: <<: *nightly extends: .hackage ############################################################ # Nofib testing ############################################################ perf-nofib: stage: testing dependencies: - validate-x86_64-linux-deb9-dwarf image: "registry.gitlab.haskell.org/ghc/ci-images/x86_64-linux-deb9:$DOCKER_REV" rules: - if: $CI_MERGE_REQUEST_ID - if: '$CI_COMMIT_BRANCH == "master"' - if: '$CI_COMMIT_BRANCH =~ /ghc-[0.9]+\.[0-9]+/' tags: - x86_64-linux script: - root=$(pwd)/ghc - | mkdir tmp tar -xf ghc-x86_64-deb9-linux-dwarf.tar.xz -C tmp pushd tmp/ghc-*/ ./configure --prefix=$root make install popd rm -Rf tmp - export BOOT_HC=$GHC - cabal update; cabal install -w "$BOOT_HC" --lib regex-compat - export PATH=$root/bin:$PATH - make -C nofib boot mode=fast -j$CPUS - "make -C nofib EXTRA_RUNTEST_OPTS='-cachegrind +RTS -V0 -RTS' NoFibRuns=1 mode=fast -j$CPUS 2>&1 | tee nofib.log" artifacts: expire_in: 12 week when: always paths: - nofib.log ############################################################ # Documentation deployment via GitLab Pages ############################################################ pages: stage: deploy dependencies: - doc-tarball image: ghcci/x86_64-linux-deb9:0.2 # Due to Windows allow_failure allow_failure: true tags: - x86_64-linux script: - mkdir -p public/doc - tar -xf haddock.html.tar.xz -C public/doc - tar -xf libraries.html.tar.xz -C public/doc - tar -xf users_guide.html.tar.xz -C public/doc - | cat >public/index.html < EOF - cp -f index.html public/doc rules: - if: '$CI_COMMIT_BRANCH == "master"' artifacts: paths: - public