ci: Regenerate haskell-ci #129
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# This GitHub workflow config has been generated by a script via | |
# | |
# haskell-ci 'github' 'cabal.project' | |
# | |
# To regenerate the script (for example after adjusting tested-with) run | |
# | |
# haskell-ci regenerate | |
# | |
# For more information, see https://github.com/haskell-CI/haskell-ci | |
# | |
# version: 0.19.20241223 | |
# | |
# REGENDATA ("0.19.20241223",["github","cabal.project"]) | |
# | |
name: Haskell-CI | |
on: | |
push: | |
pull_request: | |
release: | |
types: | |
- published | |
workflow_dispatch: | |
inputs: | |
version: | |
description: candidate version (must match version in cabal file) | |
jobs: | |
linux: | |
name: Haskell-CI - Linux - ${{ matrix.compiler }} | |
runs-on: ubuntu-20.04 | |
timeout-minutes: | |
60 | |
container: | |
image: buildpack-deps:jammy | |
continue-on-error: ${{ matrix.allow-failure }} | |
strategy: | |
matrix: | |
include: | |
- compiler: ghc-9.12.1 | |
compilerKind: ghc | |
compilerVersion: 9.12.1 | |
setup-method: ghcup | |
allow-failure: false | |
- compiler: ghc-9.10.1 | |
compilerKind: ghc | |
compilerVersion: 9.10.1 | |
setup-method: ghcup | |
allow-failure: false | |
- compiler: ghc-9.8.4 | |
compilerKind: ghc | |
compilerVersion: 9.8.4 | |
setup-method: ghcup | |
allow-failure: false | |
upload: true | |
- compiler: ghc-9.6.6 | |
compilerKind: ghc | |
compilerVersion: 9.6.6 | |
setup-method: ghcup | |
allow-failure: false | |
- compiler: ghc-9.4.8 | |
compilerKind: ghc | |
compilerVersion: 9.4.8 | |
setup-method: ghcup | |
allow-failure: false | |
- compiler: ghc-9.2.8 | |
compilerKind: ghc | |
compilerVersion: 9.2.8 | |
setup-method: ghcup | |
allow-failure: false | |
- compiler: ghc-9.0.2 | |
compilerKind: ghc | |
compilerVersion: 9.0.2 | |
setup-method: ghcup | |
allow-failure: false | |
- compiler: ghc-8.10.7 | |
compilerKind: ghc | |
compilerVersion: 8.10.7 | |
setup-method: ghcup | |
allow-failure: false | |
- compiler: ghc-8.8.4 | |
compilerKind: ghc | |
compilerVersion: 8.8.4 | |
setup-method: ghcup | |
allow-failure: false | |
- compiler: ghc-8.6.5 | |
compilerKind: ghc | |
compilerVersion: 8.6.5 | |
setup-method: ghcup | |
allow-failure: false | |
- compiler: ghc-8.4.4 | |
compilerKind: ghc | |
compilerVersion: 8.4.4 | |
setup-method: ghcup | |
allow-failure: false | |
- compiler: ghc-8.2.2 | |
compilerKind: ghc | |
compilerVersion: 8.2.2 | |
setup-method: ghcup | |
allow-failure: false | |
- compiler: ghc-8.0.2 | |
compilerKind: ghc | |
compilerVersion: 8.0.2 | |
setup-method: ghcup | |
allow-failure: false | |
fail-fast: false | |
steps: | |
- name: apt-get install | |
run: | | |
apt-get update | |
apt-get install -y --no-install-recommends gnupg ca-certificates dirmngr curl git software-properties-common libtinfo5 libnuma-dev | |
apt-get install -y libx11-dev libxext-dev libxft-dev libxinerama-dev libxrandr-dev libxss-dev | |
- name: Install GHCup | |
run: | | |
mkdir -p "$HOME/.ghcup/bin" | |
curl -sL https://downloads.haskell.org/ghcup/0.1.30.0/x86_64-linux-ghcup-0.1.30.0 > "$HOME/.ghcup/bin/ghcup" | |
chmod a+x "$HOME/.ghcup/bin/ghcup" | |
- name: Install cabal-install | |
run: | | |
"$HOME/.ghcup/bin/ghcup" install cabal 3.14.1.0 || (cat "$HOME"/.ghcup/logs/*.* && false) | |
echo "CABAL=$HOME/.ghcup/bin/cabal-3.14.1.0 -vnormal+nowrap" >> "$GITHUB_ENV" | |
- name: Install GHC (GHCup) | |
if: matrix.setup-method == 'ghcup' | |
run: | | |
"$HOME/.ghcup/bin/ghcup" install ghc "$HCVER" || (cat "$HOME"/.ghcup/logs/*.* && false) | |
HC=$("$HOME/.ghcup/bin/ghcup" whereis ghc "$HCVER") | |
HCPKG=$(echo "$HC" | sed 's#ghc$#ghc-pkg#') | |
HADDOCK=$(echo "$HC" | sed 's#ghc$#haddock#') | |
echo "HC=$HC" >> "$GITHUB_ENV" | |
echo "HCPKG=$HCPKG" >> "$GITHUB_ENV" | |
echo "HADDOCK=$HADDOCK" >> "$GITHUB_ENV" | |
env: | |
HCKIND: ${{ matrix.compilerKind }} | |
HCNAME: ${{ matrix.compiler }} | |
HCVER: ${{ matrix.compilerVersion }} | |
- name: Set PATH and environment variables | |
run: | | |
echo "$HOME/.cabal/bin" >> $GITHUB_PATH | |
echo "LANG=C.UTF-8" >> "$GITHUB_ENV" | |
echo "CABAL_DIR=$HOME/.cabal" >> "$GITHUB_ENV" | |
echo "CABAL_CONFIG=$HOME/.cabal/config" >> "$GITHUB_ENV" | |
HCNUMVER=$(${HC} --numeric-version|perl -ne '/^(\d+)\.(\d+)\.(\d+)(\.(\d+))?$/; print(10000 * $1 + 100 * $2 + ($3 == 0 ? $5 != 1 : $3))') | |
echo "HCNUMVER=$HCNUMVER" >> "$GITHUB_ENV" | |
echo "ARG_TESTS=--enable-tests" >> "$GITHUB_ENV" | |
echo "ARG_BENCH=--enable-benchmarks" >> "$GITHUB_ENV" | |
echo "HEADHACKAGE=false" >> "$GITHUB_ENV" | |
echo "ARG_COMPILER=--$HCKIND --with-compiler=$HC" >> "$GITHUB_ENV" | |
env: | |
HCKIND: ${{ matrix.compilerKind }} | |
HCNAME: ${{ matrix.compiler }} | |
HCVER: ${{ matrix.compilerVersion }} | |
- name: env | |
run: | | |
env | |
- name: write cabal config | |
run: | | |
mkdir -p $CABAL_DIR | |
cat >> $CABAL_CONFIG <<EOF | |
remote-build-reporting: anonymous | |
write-ghc-environment-files: never | |
remote-repo-cache: $CABAL_DIR/packages | |
logs-dir: $CABAL_DIR/logs | |
world-file: $CABAL_DIR/world | |
extra-prog-path: $CABAL_DIR/bin | |
symlink-bindir: $CABAL_DIR/bin | |
installdir: $CABAL_DIR/bin | |
build-summary: $CABAL_DIR/logs/build.log | |
store-dir: $CABAL_DIR/store | |
install-dirs user | |
prefix: $CABAL_DIR | |
repository hackage.haskell.org | |
url: http://hackage.haskell.org/ | |
EOF | |
cat >> $CABAL_CONFIG <<EOF | |
program-default-options | |
ghc-options: $GHCJOBS +RTS -M3G -RTS | |
EOF | |
cat $CABAL_CONFIG | |
- name: versions | |
run: | | |
$HC --version || true | |
$HC --print-project-git-commit-id || true | |
$CABAL --version || true | |
- name: update cabal index | |
run: | | |
$CABAL v2-update -v | |
- name: install cabal-plan | |
run: | | |
mkdir -p $HOME/.cabal/bin | |
curl -sL https://github.com/haskell-hvr/cabal-plan/releases/download/v0.7.3.0/cabal-plan-0.7.3.0-x86_64-linux.xz > cabal-plan.xz | |
echo 'f62ccb2971567a5f638f2005ad3173dba14693a45154c1508645c52289714cb2 cabal-plan.xz' | sha256sum -c - | |
xz -d < cabal-plan.xz > $HOME/.cabal/bin/cabal-plan | |
rm -f cabal-plan.xz | |
chmod a+x $HOME/.cabal/bin/cabal-plan | |
cabal-plan --version | |
- name: checkout | |
uses: actions/checkout@v4 | |
with: | |
path: source | |
- name: initial cabal.project for sdist | |
run: | | |
touch cabal.project | |
echo "packages: $GITHUB_WORKSPACE/source/." >> cabal.project | |
cat cabal.project | |
- name: sdist | |
run: | | |
mkdir -p sdist | |
$CABAL sdist all --output-dir $GITHUB_WORKSPACE/sdist | |
- name: unpack | |
run: | | |
mkdir -p unpacked | |
find sdist -maxdepth 1 -type f -name '*.tar.gz' -exec tar -C $GITHUB_WORKSPACE/unpacked -xzvf {} \; | |
- name: generate cabal.project | |
run: | | |
PKGDIR_X11_xft="$(find "$GITHUB_WORKSPACE/unpacked" -maxdepth 1 -type d -regex '.*/X11-xft-[0-9.]*')" | |
echo "PKGDIR_X11_xft=${PKGDIR_X11_xft}" >> "$GITHUB_ENV" | |
rm -f cabal.project cabal.project.local | |
touch cabal.project | |
touch cabal.project.local | |
echo "packages: ${PKGDIR_X11_xft}" >> cabal.project | |
if [ $((HCNUMVER >= 80200)) -ne 0 ] ; then echo "package X11-xft" >> cabal.project ; fi | |
if [ $((HCNUMVER >= 80200)) -ne 0 ] ; then echo " ghc-options: -Werror=missing-methods" >> cabal.project ; fi | |
cat >> cabal.project <<EOF | |
package X11-xft | |
flags: +pedantic | |
EOF | |
$HCPKG list --simple-output --names-only | perl -ne 'for (split /\s+/) { print "constraints: any.$_ installed\n" unless /^(X11-xft)$/; }' >> cabal.project.local | |
cat cabal.project | |
cat cabal.project.local | |
- name: dump install plan | |
run: | | |
$CABAL v2-build $ARG_COMPILER $ARG_TESTS $ARG_BENCH --dry-run all | |
cabal-plan | |
- name: restore cache | |
uses: actions/cache/restore@v4 | |
with: | |
key: ${{ runner.os }}-${{ matrix.compiler }}-${{ github.sha }} | |
path: ~/.cabal/store | |
restore-keys: ${{ runner.os }}-${{ matrix.compiler }}- | |
- name: install dependencies | |
run: | | |
$CABAL v2-build $ARG_COMPILER --disable-tests --disable-benchmarks --dependencies-only -j2 all | |
$CABAL v2-build $ARG_COMPILER $ARG_TESTS $ARG_BENCH --dependencies-only -j2 all | |
- name: build w/o tests | |
run: | | |
$CABAL v2-build $ARG_COMPILER --disable-tests --disable-benchmarks all | |
- name: build | |
run: | | |
$CABAL v2-build $ARG_COMPILER $ARG_TESTS $ARG_BENCH all --write-ghc-environment-files=always | |
- name: cabal check | |
run: | | |
cd ${PKGDIR_X11_xft} || false | |
${CABAL} -vnormal check | |
- name: haddock | |
run: | | |
$CABAL v2-haddock --disable-documentation $ARG_COMPILER --with-haddock $HADDOCK $ARG_TESTS $ARG_BENCH all | |
- name: haddock for hackage | |
if: matrix.upload | |
run: | | |
$CABAL v2-haddock $ARG_COMPILER --with-haddock $HADDOCK $ARG_TESTS $ARG_BENCH --haddock-for-hackage --builddir $GITHUB_WORKSPACE/haddock all | |
- name: unconstrained build | |
run: | | |
rm -f cabal.project.local | |
$CABAL v2-build $ARG_COMPILER --disable-tests --disable-benchmarks all | |
- name: save cache | |
if: always() | |
uses: actions/cache/save@v4 | |
with: | |
key: ${{ runner.os }}-${{ matrix.compiler }}-${{ github.sha }} | |
path: ~/.cabal/store | |
# must be separate artifacts because GitHub Actions are still broken: | |
# https://github.com/actions/upload-artifact/issues/441 | |
# https://github.com/actions/upload-artifact/issues/457 | |
- name: upload artifact (sdist) | |
if: matrix.upload | |
uses: actions/upload-artifact@v4 | |
with: | |
name: sdist | |
path: ${{ github.workspace }}/sdist/*.tar.gz | |
- name: upload artifact (haddock) | |
if: matrix.upload | |
uses: actions/upload-artifact@v4 | |
with: | |
name: haddock | |
path: ${{ github.workspace }}/haddock/*-docs.tar.gz | |
- name: hackage upload (candidate) | |
if: matrix.upload && github.event_name == 'workflow_dispatch' && github.event.inputs.version != '' | |
shell: bash | |
run: | | |
set -ex | |
PACKAGE_VERSION="${PACKAGE_VERSION#v}" | |
res=$( | |
curl \ | |
--silent --show-error --output /dev/stderr --write-out '%{http_code}' \ | |
--header "Accept: text/plain" \ | |
--header "Authorization: X-ApiKey $HACKAGE_API_KEY" \ | |
--form package=@"${GITHUB_WORKSPACE}/sdist/${PACKAGE_NAME}-${PACKAGE_VERSION}.tar.gz" \ | |
https://hackage.haskell.org/packages/candidates/ | |
) | |
[[ $res == 2?? ]] # TODO: --fail-with-body once curl 7.76.0 is available | |
res=$( | |
curl \ | |
--silent --show-error --output /dev/stderr --write-out '%{http_code}' \ | |
-X PUT \ | |
--header "Accept: text/plain" \ | |
--header "Authorization: X-ApiKey $HACKAGE_API_KEY" \ | |
--header "Content-Type: application/x-tar" \ | |
--header "Content-Encoding: gzip" \ | |
--data-binary @"${GITHUB_WORKSPACE}/haddock/${PACKAGE_NAME}-${PACKAGE_VERSION}-docs.tar.gz" \ | |
https://hackage.haskell.org/package/${PACKAGE_NAME}-${PACKAGE_VERSION}/candidate/docs | |
) | |
[[ $res == 2?? ]] | |
env: | |
HACKAGE_API_KEY: ${{ secrets.HACKAGE_API_KEY }} | |
PACKAGE_NAME: ${{ github.event.repository.name }} | |
PACKAGE_VERSION: ${{ github.event.inputs.version }} | |
- name: hackage upload (release) | |
if: matrix.upload && github.event_name == 'release' | |
shell: bash | |
run: | | |
set -ex | |
PACKAGE_VERSION="${PACKAGE_VERSION#v}" | |
res=$( | |
curl \ | |
--silent --show-error --output /dev/stderr --write-out '%{http_code}' \ | |
--header "Accept: text/plain" \ | |
--header "Authorization: X-ApiKey $HACKAGE_API_KEY" \ | |
--form package=@"${GITHUB_WORKSPACE}/sdist/${PACKAGE_NAME}-${PACKAGE_VERSION}.tar.gz" \ | |
https://hackage.haskell.org/packages/ | |
) | |
[[ $res == 2?? ]] # TODO: --fail-with-body once curl 7.76.0 is available | |
res=$( | |
curl \ | |
--silent --show-error --output /dev/stderr --write-out '%{http_code}' \ | |
-X PUT \ | |
--header "Accept: text/plain" \ | |
--header "Authorization: X-ApiKey $HACKAGE_API_KEY" \ | |
--header "Content-Type: application/x-tar" \ | |
--header "Content-Encoding: gzip" \ | |
--data-binary @"${GITHUB_WORKSPACE}/haddock/${PACKAGE_NAME}-${PACKAGE_VERSION}-docs.tar.gz" \ | |
https://hackage.haskell.org/package/${PACKAGE_NAME}-${PACKAGE_VERSION}/docs | |
) | |
[[ $res == 2?? ]] | |
env: | |
HACKAGE_API_KEY: ${{ secrets.HACKAGE_API_KEY }} | |
PACKAGE_NAME: ${{ github.event.repository.name }} | |
PACKAGE_VERSION: ${{ github.event.release.tag_name }} |