Bump Cabal and Cabal-syntax to allow 3.12 #113
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/andreasabel/haskell-ci | |
# | |
# version: 0.18.0.20240225 | |
# | |
# REGENDATA ("0.18.0.20240225",["github","cabal.project"]) | |
# | |
name: Haskell-CI | |
on: | |
push: | |
branches: | |
- master | |
pull_request: | |
branches: | |
- master | |
jobs: | |
linux: | |
name: Haskell-CI - Linux - ${{ matrix.compiler }} | |
runs-on: ubuntu-20.04 | |
timeout-minutes: | |
60 | |
container: | |
image: buildpack-deps:focal | |
continue-on-error: ${{ matrix.allow-failure }} | |
strategy: | |
matrix: | |
include: | |
- compiler: ghc-9.8.1 | |
compilerKind: ghc | |
compilerVersion: 9.8.1 | |
setup-method: ghcup | |
allow-failure: false | |
- compiler: ghc-9.6.4 | |
compilerKind: ghc | |
compilerVersion: 9.6.4 | |
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 | |
fail-fast: false | |
steps: | |
- name: apt | |
run: | | |
apt-get update | |
apt-get install -y --no-install-recommends gnupg ca-certificates dirmngr curl git software-properties-common libtinfo5 libnuma-dev | |
mkdir -p "$HOME/.ghcup/bin" | |
curl -sL https://downloads.haskell.org/ghcup/0.1.20.0/x86_64-linux-ghcup-0.1.20.0 > "$HOME/.ghcup/bin/ghcup" | |
chmod a+x "$HOME/.ghcup/bin/ghcup" | |
"$HOME/.ghcup/bin/ghcup" install ghc "$HCVER" || (cat "$HOME"/.ghcup/logs/*.* && false) | |
"$HOME/.ghcup/bin/ghcup" install cabal 3.10.2.0 || (cat "$HOME"/.ghcup/logs/*.* && false) | |
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" | |
HCDIR=/opt/$HCKIND/$HCVER | |
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" | |
echo "CABAL=$HOME/.ghcup/bin/cabal-3.10.2.0 -vnormal+nowrap" >> "$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" | |
echo "GHCJSARITH=0" >> "$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/hackage-security" >> cabal.project | |
echo "packages: $GITHUB_WORKSPACE/source/hackage-security-http-client" >> cabal.project | |
echo "packages: $GITHUB_WORKSPACE/source/example-client" >> cabal.project | |
echo "packages: $GITHUB_WORKSPACE/source/hackage-security-curl" >> cabal.project | |
echo "packages: $GITHUB_WORKSPACE/source/hackage-root-tool" >> cabal.project | |
echo "packages: $GITHUB_WORKSPACE/source/hackage-repo-tool" >> cabal.project | |
echo "packages: $GITHUB_WORKSPACE/source/hackage-security-HTTP" >> cabal.project | |
echo "packages: $GITHUB_WORKSPACE/source/precompute-fileinfo" >> 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_hackage_security="$(find "$GITHUB_WORKSPACE/unpacked" -maxdepth 1 -type d -regex '.*/hackage-security-[0-9.]*')" | |
echo "PKGDIR_hackage_security=${PKGDIR_hackage_security}" >> "$GITHUB_ENV" | |
PKGDIR_hackage_security_http_client="$(find "$GITHUB_WORKSPACE/unpacked" -maxdepth 1 -type d -regex '.*/hackage-security-http-client-[0-9.]*')" | |
echo "PKGDIR_hackage_security_http_client=${PKGDIR_hackage_security_http_client}" >> "$GITHUB_ENV" | |
PKGDIR_example_client="$(find "$GITHUB_WORKSPACE/unpacked" -maxdepth 1 -type d -regex '.*/example-client-[0-9.]*')" | |
echo "PKGDIR_example_client=${PKGDIR_example_client}" >> "$GITHUB_ENV" | |
PKGDIR_hackage_security_curl="$(find "$GITHUB_WORKSPACE/unpacked" -maxdepth 1 -type d -regex '.*/hackage-security-curl-[0-9.]*')" | |
echo "PKGDIR_hackage_security_curl=${PKGDIR_hackage_security_curl}" >> "$GITHUB_ENV" | |
PKGDIR_hackage_root_tool="$(find "$GITHUB_WORKSPACE/unpacked" -maxdepth 1 -type d -regex '.*/hackage-root-tool-[0-9.]*')" | |
echo "PKGDIR_hackage_root_tool=${PKGDIR_hackage_root_tool}" >> "$GITHUB_ENV" | |
PKGDIR_hackage_repo_tool="$(find "$GITHUB_WORKSPACE/unpacked" -maxdepth 1 -type d -regex '.*/hackage-repo-tool-[0-9.]*')" | |
echo "PKGDIR_hackage_repo_tool=${PKGDIR_hackage_repo_tool}" >> "$GITHUB_ENV" | |
PKGDIR_hackage_security_HTTP="$(find "$GITHUB_WORKSPACE/unpacked" -maxdepth 1 -type d -regex '.*/hackage-security-HTTP-[0-9.]*')" | |
echo "PKGDIR_hackage_security_HTTP=${PKGDIR_hackage_security_HTTP}" >> "$GITHUB_ENV" | |
PKGDIR_precompute_fileinfo="$(find "$GITHUB_WORKSPACE/unpacked" -maxdepth 1 -type d -regex '.*/precompute-fileinfo-[0-9.]*')" | |
echo "PKGDIR_precompute_fileinfo=${PKGDIR_precompute_fileinfo}" >> "$GITHUB_ENV" | |
rm -f cabal.project cabal.project.local | |
touch cabal.project | |
touch cabal.project.local | |
echo "packages: ${PKGDIR_hackage_security}" >> cabal.project | |
echo "packages: ${PKGDIR_hackage_security_http_client}" >> cabal.project | |
echo "packages: ${PKGDIR_example_client}" >> cabal.project | |
echo "packages: ${PKGDIR_hackage_security_curl}" >> cabal.project | |
echo "packages: ${PKGDIR_hackage_root_tool}" >> cabal.project | |
echo "packages: ${PKGDIR_hackage_repo_tool}" >> cabal.project | |
echo "packages: ${PKGDIR_hackage_security_HTTP}" >> cabal.project | |
echo "packages: ${PKGDIR_precompute_fileinfo}" >> cabal.project | |
echo "package hackage-security" >> cabal.project | |
echo " ghc-options: -Werror=missing-methods" >> cabal.project | |
echo "package hackage-security-http-client" >> cabal.project | |
echo " ghc-options: -Werror=missing-methods" >> cabal.project | |
echo "package example-client" >> cabal.project | |
echo " ghc-options: -Werror=missing-methods" >> cabal.project | |
echo "package hackage-security-curl" >> cabal.project | |
echo " ghc-options: -Werror=missing-methods" >> cabal.project | |
echo "package hackage-root-tool" >> cabal.project | |
echo " ghc-options: -Werror=missing-methods" >> cabal.project | |
echo "package hackage-repo-tool" >> cabal.project | |
echo " ghc-options: -Werror=missing-methods" >> cabal.project | |
echo "package hackage-security-HTTP" >> cabal.project | |
echo " ghc-options: -Werror=missing-methods" >> cabal.project | |
echo "package precompute-fileinfo" >> cabal.project | |
echo " ghc-options: -Werror=missing-methods" >> cabal.project | |
cat >> cabal.project <<EOF | |
constraints: base-compat >= 0.12.2 | |
allow-newer: containers | |
EOF | |
$HCPKG list --simple-output --names-only | perl -ne 'for (split /\s+/) { print "constraints: $_ installed\n" unless /^(example-client|hackage-repo-tool|hackage-root-tool|hackage-security|hackage-security-HTTP|hackage-security-curl|hackage-security-http-client|precompute-fileinfo)$/; }' >> 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: tests | |
run: | | |
$CABAL v2-test $ARG_COMPILER $ARG_TESTS $ARG_BENCH all --test-show-details=direct | |
- name: cabal check | |
run: | | |
cd ${PKGDIR_hackage_security} || false | |
${CABAL} -vnormal check | |
cd ${PKGDIR_hackage_security_http_client} || false | |
${CABAL} -vnormal check | |
cd ${PKGDIR_example_client} || false | |
${CABAL} -vnormal check | |
cd ${PKGDIR_hackage_security_curl} || false | |
${CABAL} -vnormal check | |
cd ${PKGDIR_hackage_root_tool} || false | |
${CABAL} -vnormal check | |
cd ${PKGDIR_hackage_repo_tool} || false | |
${CABAL} -vnormal check | |
cd ${PKGDIR_hackage_security_HTTP} || false | |
${CABAL} -vnormal check | |
cd ${PKGDIR_precompute_fileinfo} || false | |
${CABAL} -vnormal check | |
- name: haddock | |
run: | | |
if [ $((HCNUMVER >= 80600)) -ne 0 ] ; then $CABAL v2-haddock --disable-documentation --haddock-all $ARG_COMPILER --with-haddock $HADDOCK $ARG_TESTS $ARG_BENCH all ; fi | |
- name: unconstrained build | |
run: | | |
rm -f cabal.project.local | |
$CABAL v2-build $ARG_COMPILER --disable-tests --disable-benchmarks all | |
- name: prepare for constraint sets | |
run: | | |
rm -f cabal.project.local | |
- name: constraint set containers-0.7 | |
run: | | |
if [ $((HCNUMVER < 90800)) -ne 0 ] ; then $CABAL v2-build $ARG_COMPILER --enable-tests --disable-benchmarks --constraint='containers >= 0.7' all --dry-run ; fi | |
if [ $((HCNUMVER < 90800)) -ne 0 ] ; then cabal-plan topo | sort ; fi | |
if [ $((HCNUMVER < 90800)) -ne 0 ] ; then $CABAL v2-build $ARG_COMPILER --enable-tests --disable-benchmarks --constraint='containers >= 0.7' --dependencies-only -j2 all ; fi | |
if [ $((HCNUMVER < 90800)) -ne 0 ] ; then $CABAL v2-build $ARG_COMPILER --enable-tests --disable-benchmarks --constraint='containers >= 0.7' all ; fi | |
if [ $((HCNUMVER < 90800)) -ne 0 ] ; then $CABAL v2-test $ARG_COMPILER --enable-tests --disable-benchmarks --constraint='containers >= 0.7' all ; fi | |
- name: constraint set no-lukko | |
run: | | |
$CABAL v2-build $ARG_COMPILER --disable-tests --disable-benchmarks --constraint='hackage-security -lukko' all --dry-run | |
cabal-plan topo | sort | |
$CABAL v2-build $ARG_COMPILER --disable-tests --disable-benchmarks --constraint='hackage-security -lukko' --dependencies-only -j2 all | |
$CABAL v2-build $ARG_COMPILER --disable-tests --disable-benchmarks --constraint='hackage-security -lukko' all | |
- name: save cache | |
uses: actions/cache/save@v4 | |
if: always() | |
with: | |
key: ${{ runner.os }}-${{ matrix.compiler }}-${{ github.sha }} | |
path: ~/.cabal/store |