From b5a3444e252fd3e737f31b9067b0d71d1a6111a3 Mon Sep 17 00:00:00 2001 From: Ali Abrar Date: Mon, 26 Aug 2019 07:28:01 -0400 Subject: [PATCH] ci: Add travis. cabal: add version boudns --- .travis.yml | 113 +++++++++++++++++++++++++++++++++++ dependent-monoidal-map.cabal | 17 +++--- 2 files changed, 123 insertions(+), 7 deletions(-) create mode 100644 .travis.yml diff --git a/.travis.yml b/.travis.yml new file mode 100644 index 0000000..aca2fc0 --- /dev/null +++ b/.travis.yml @@ -0,0 +1,113 @@ +# This Travis job script has been generated by a script via +# +# haskell-ci 'dependent-monoidal-map.cabal' '--output' '.travis.yml' +# +# For more information, see https://github.com/haskell-CI/haskell-ci +# +# version: 0.3 +# +language: c +dist: xenial + +git: + submodules: false # whether to recursively clone submodules + +cache: + directories: + - $HOME/.cabal/packages + - $HOME/.cabal/store + +before_cache: + - rm -fv $CABALHOME/packages/hackage.haskell.org/build-reports.log + # remove files that are regenerated by 'cabal update' + - rm -fv $CABALHOME/packages/hackage.haskell.org/00-index.* + - rm -fv $CABALHOME/packages/hackage.haskell.org/*.json + - rm -fv $CABALHOME/packages/hackage.haskell.org/01-index.cache + - rm -fv $CABALHOME/packages/hackage.haskell.org/01-index.tar + - rm -fv $CABALHOME/packages/hackage.haskell.org/01-index.tar.idx + + - rm -rfv $CABALHOME/packages/head.hackage + +matrix: + include: + - compiler: "ghc-8.6.5" + addons: {apt: {packages: [ghc-ppa-tools,cabal-install-2.4,ghc-8.6.5], sources: [hvr-ghc]}} + - compiler: "ghc-8.4.4" + addons: {apt: {packages: [ghc-ppa-tools,cabal-install-2.4,ghc-8.4.4], sources: [hvr-ghc]}} + - compiler: "ghc-8.2.2" + addons: {apt: {packages: [ghc-ppa-tools,cabal-install-2.4,ghc-8.2.2], sources: [hvr-ghc]}} + - compiler: "ghc-8.0.2" + addons: {apt: {packages: [ghc-ppa-tools,cabal-install-2.4,ghc-8.0.2], sources: [hvr-ghc]}} + +before_install: + - HC=/opt/ghc/bin/${CC} + - HCPKG=${HC/ghc/ghc-pkg} + - unset CC + - CABAL=/opt/ghc/bin/cabal + - CABALHOME=$HOME/.cabal + - export PATH="$CABALHOME/bin:$PATH" + - ROOTDIR=$(pwd) + - HCNUMVER=$(( $(${HC} --numeric-version|sed -E 's/([0-9]+)\.([0-9]+)\.([0-9]+).*/\1 * 10000 + \2 * 100 + \3/') )) + - echo $HCNUMVER + +install: + - ${CABAL} --version + - echo "$(${HC} --version) [$(${HC} --print-project-git-commit-id 2> /dev/null || echo '?')]" + - TEST=--enable-tests + - BENCH=--enable-benchmarks + - GHCHEAD=${GHCHEAD-false} + - travis_retry ${CABAL} update -v + - sed -i.bak 's/^jobs:/-- jobs:/' $CABALHOME/config + - rm -fv cabal.project cabal.project.local + - grep -Ev -- '^\s*--' $CABALHOME/config | grep -Ev '^\s*$' + - rm -f cabal.project + - touch cabal.project + - "printf 'packages: \".\"\\n' >> cabal.project" + - "printf 'write-ghc-environment-files: always\\n' >> cabal.project" + - touch cabal.project.local + - "for pkg in $($HCPKG list --simple-output); do echo $pkg | sed 's/-[^-]*$//' | grep -vE -- '^(dependent-monoidal-map)$' | sed 's/^/constraints: /' | sed 's/$/ installed/' >> cabal.project.local; done" + - cat cabal.project || true + - cat cabal.project.local || true + - if [ -f "./configure.ac" ]; then (cd "." && autoreconf -i); fi + - rm -f cabal.project.freeze + - ${CABAL} new-freeze -w ${HC} ${TEST} ${BENCH} --project-file="cabal.project" --dry + - "cat \"cabal.project.freeze\" | sed -E 's/^(constraints: *| *)//' | sed 's/any.//'" + - rm "cabal.project.freeze" + - ${CABAL} new-build -w ${HC} ${TEST} ${BENCH} --project-file="cabal.project" --dep -j2 all + - ${CABAL} new-build -w ${HC} --disable-tests --disable-benchmarks --project-file="cabal.project" --dep -j2 all + - rm -rf .ghc.environment.* "."/dist + - DISTDIR=$(mktemp -d /tmp/dist-test.XXXX) + +# Here starts the actual work to be performed for the package under test; +# any command which exits with a non-zero exit code causes the build to fail. +script: + # test that source-distributions can be generated + - ${CABAL} new-sdist all + - mv dist-newstyle/sdist/*.tar.gz ${DISTDIR}/ + - cd ${DISTDIR} || false + - find . -maxdepth 1 -name '*.tar.gz' -exec tar -xvf '{}' \; + - rm -f cabal.project + - touch cabal.project + - "printf 'packages: \"dependent-monoidal-map-*/*.cabal\"\\n' >> cabal.project" + - "printf 'write-ghc-environment-files: always\\n' >> cabal.project" + - touch cabal.project.local + - "for pkg in $($HCPKG list --simple-output); do echo $pkg | sed 's/-[^-]*$//' | grep -vE -- '^(dependent-monoidal-map)$' | sed 's/^/constraints: /' | sed 's/$/ installed/' >> cabal.project.local; done" + - cat cabal.project || true + - cat cabal.project.local || true + # this builds all libraries and executables (without tests/benchmarks) + - ${CABAL} new-build -w ${HC} --disable-tests --disable-benchmarks all + + # build & run tests, build benchmarks + - ${CABAL} new-build -w ${HC} ${TEST} ${BENCH} all + + # cabal check + - (cd dependent-monoidal-map-* && ${CABAL} check) + + # haddock + - ${CABAL} new-haddock -w ${HC} ${TEST} ${BENCH} all + + # Build without installed constraints for packages in global-db + - rm -f cabal.project.local; ${CABAL} new-build -w ${HC} --disable-tests --disable-benchmarks all + +# REGENDATA ["dependent-monoidal-map.cabal","--output",".travis.yml"] +# EOF diff --git a/dependent-monoidal-map.cabal b/dependent-monoidal-map.cabal index ba48c74..461ce37 100644 --- a/dependent-monoidal-map.cabal +++ b/dependent-monoidal-map.cabal @@ -10,14 +10,17 @@ build-type: Simple extra-source-files: ChangeLog.md cabal-version: >=1.10 +tested-with: + GHC ==8.0.2 || ==8.2.2 || ==8.4.4 || ==8.6.5 + library exposed-modules: Data.Dependent.Map.Monoidal - build-depends: base >=4.9 && <4.13 - , aeson - , constraints - , constraints-extras - , dependent-sum - , dependent-sum-aeson-orphans - , dependent-map + build-depends: base >=4.9 && <4.13, + aeson >= 1.4.4 && < 1.5, + constraints >= 0.10.1 && < 0.11, + constraints-extras >= 0.3.0 && < 0.4, + dependent-map >= 0.3 && < 0.4, + dependent-sum >= 0.6.2 && < 0.7, + dependent-sum-aeson-orphans >= 0.2.1 && < 0.3 hs-source-dirs: src default-language: Haskell2010