1313branches :
1414 only :
1515 - master
16- - release-0.12
1716
1817cache :
1918 directories :
@@ -35,19 +34,19 @@ matrix:
3534 include :
3635 - compiler : " ghc-8.4.3"
3736 # env: TEST=--disable-tests BENCH=--disable-benchmarks
38- addons : {apt: {packages: [ghc-ppa-tools,ghc-8.4.3], sources: [hvr-ghc]}}
37+ addons : {apt: {packages: [ghc-ppa-tools,cabal-install-2.2, ghc-8.4.3], sources: [hvr-ghc]}}
3938 - compiler : " ghc-8.2.2"
4039 # env: TEST=--disable-tests BENCH=--disable-benchmarks
41- addons : {apt: {packages: [ghc-ppa-tools,ghc-8.2.2], sources: [hvr-ghc]}}
40+ addons : {apt: {packages: [ghc-ppa-tools,cabal-install-2.2, ghc-8.2.2], sources: [hvr-ghc]}}
4241 - compiler : " ghc-8.0.2"
4342 # env: TEST=--disable-tests BENCH=--disable-benchmarks
44- addons : {apt: {packages: [ghc-ppa-tools,ghc-8.0.2], sources: [hvr-ghc]}}
43+ addons : {apt: {packages: [ghc-ppa-tools,cabal-install-2.2, ghc-8.0.2], sources: [hvr-ghc]}}
4544 - compiler : " ghc-7.10.3"
4645 # env: TEST=--disable-tests BENCH=--disable-benchmarks
47- addons : {apt: {packages: [ghc-ppa-tools,ghc-7.10.3], sources: [hvr-ghc]}}
46+ addons : {apt: {packages: [ghc-ppa-tools,cabal-install-2.2, ghc-7.10.3], sources: [hvr-ghc]}}
4847 - compiler : " ghc-7.8.4"
4948 # env: TEST=--disable-tests BENCH=--disable-benchmarks
50- addons : {apt: {packages: [ghc-ppa-tools,ghc-7.8.4], sources: [hvr-ghc]}}
49+ addons : {apt: {packages: [ghc-ppa-tools,cabal-install-2.2, ghc-7.8.4], sources: [hvr-ghc]}}
5150
5251before_install :
5352 - HC=${CC}
@@ -59,34 +58,27 @@ before_install:
5958 - HCNUMVER=$(( $(${HC} --numeric-version|sed -E 's/([0-9]+)\.([0-9]+)\.([0-9]+).*/\1 * 10000 + \2 * 100 + \3/') ))
6059 - echo $HCNUMVER
6160
62- # Let's download "better" cabal
63- - " curl -L http://oleg.fi/cabal-grayjay-buildable-fix.xz | xz -d > $HOME/.local/bin/cabal"
64- - |
65- if [ "$(cd $HOME/.local/bin && sha256sum cabal)" != "e281e9466b8eef30ac0d1371e8ea83c9d2e856bda4714a728ac474138b09b20f cabal" ]; then
66- rm -f $HOME/.local/bin/cabal;
67- sha256sum $HOME/.local/bin/cabal;
68- false;
69- else
70- chmod a+x $HOME/.local/bin/cabal;
71- fi
72-
7361install :
7462 - cabal --version
7563 - echo "$(${HC} --version) [$(${HC} --print-project-git-commit-id 2> /dev/null || echo '?')]"
7664 - BENCH=${BENCH---enable-benchmarks}
7765 - TEST=${TEST---enable-tests}
7866 - HADDOCK=${HADDOCK-true}
79- - INSTALLED=${INSTALLED-true}
67+ - UNCONSTRAINED=${UNCONSTRAINED-true}
68+ - NOINSTALLEDCONSTRAINTS=${NOINSTALLEDCONSTRAINTS-false}
8069 - GHCHEAD=${GHCHEAD-false}
8170 - travis_retry cabal update -v
8271 - " sed -i.bak 's/^jobs:/-- jobs:/' ${HOME}/.cabal/config"
8372 - rm -fv cabal.project cabal.project.local
8473 - " if [ $HCNUMVER -ge 70800 ]; then sed -i.bak 's/-- ghc-options:.*/ghc-options: -j2/' ${HOME}/.cabal/config; fi"
8574 - grep -Ev -- '^\s*--' ${HOME}/.cabal/config | grep -Ev '^\s*$'
86- - " printf 'packages: \" servant\" \" servant-client\" \" servant-client-core\" \" servant-docs\" \" servant-foreign\" \" servant-server\" \" doc/tutorial\" \" doc/cookbook/basic-auth\" \" doc/cookbook/db-postgres-pool\" \" doc/cookbook/db-sqlite-simple\" \" doc/cookbook/https\" \" doc/cookbook/pagination\" \" doc/cookbook/structuring-apis\" \" doc/cookbook/using-custom-monad\"\\ n' > cabal.project"
75+ - " printf 'packages: \" servant\" \" servant-client\" \" servant-client-core\" \" servant-docs\" \" servant-foreign\" \" servant-server\" \" doc/tutorial\" \" doc/cookbook/basic-auth\" \" doc/cookbook/db-postgres-pool\" \" doc/cookbook/db-sqlite-simple\" \" doc/cookbook/file-upload \" \" doc/cookbook/ https\" \" doc/cookbook/jwt-and-basic-auth \" \" doc/cookbook/pagination\" \" doc/cookbook/structuring-apis\" \" doc/cookbook/using-custom-monad\"\\ n' > cabal.project"
8776 - " echo 'constraints: foundation >=0.0.14,memory <0.14.12 || >0.14.12' >> cabal.project"
88- - " echo 'allow-newer: servant-auth-server:http-types,servant-auth-server:servant-server, http-media:base' >> cabal.project"
89- - cat cabal.project
77+ - " echo 'allow-newer: servant-auth-server:http-types,servant-auth-server:servant-server, servant-pagination:servant,servant-pagination:servant-server' >> cabal.project"
78+ - touch cabal.project.local
79+ - " if ! $NOINSTALLEDCONSTRAINTS; then for pkg in $($HCPKG list --simple-output); do echo $pkg | sed 's/^/constraints: /' | sed 's/-[^-]*$/ installed/' >> cabal.project.local; done; fi"
80+ - cat cabal.project || true
81+ - cat cabal.project.local || true
9082 - if [ -f "servant/configure.ac" ]; then
9183 (cd "servant" && autoreconf -i);
9284 fi
@@ -117,9 +109,15 @@ install:
117109 - if [ -f "doc/cookbook/db-sqlite-simple/configure.ac" ]; then
118110 (cd "doc/cookbook/db-sqlite-simple" && autoreconf -i);
119111 fi
112+ - if [ -f "doc/cookbook/file-upload/configure.ac" ]; then
113+ (cd "doc/cookbook/file-upload" && autoreconf -i);
114+ fi
120115 - if [ -f "doc/cookbook/https/configure.ac" ]; then
121116 (cd "doc/cookbook/https" && autoreconf -i);
122117 fi
118+ - if [ -f "doc/cookbook/jwt-and-basic-auth/configure.ac" ]; then
119+ (cd "doc/cookbook/jwt-and-basic-auth" && autoreconf -i);
120+ fi
123121 - if [ -f "doc/cookbook/pagination/configure.ac" ]; then
124122 (cd "doc/cookbook/pagination" && autoreconf -i);
125123 fi
@@ -130,7 +128,7 @@ install:
130128 (cd "doc/cookbook/using-custom-monad" && autoreconf -i);
131129 fi
132130 - rm -f cabal.project.freeze
133- - rm -rf .ghc.environment.* "servant"/dist "servant-client"/dist "servant-client-core"/dist "servant-docs"/dist "servant-foreign"/dist "servant-server"/dist "doc/tutorial"/dist "doc/cookbook/basic-auth"/dist "doc/cookbook/db-postgres-pool"/dist "doc/cookbook/db-sqlite-simple"/dist "doc/cookbook/https"/dist "doc/cookbook/pagination"/dist "doc/cookbook/structuring-apis"/dist "doc/cookbook/using-custom-monad"/dist
131+ - rm -rf .ghc.environment.* "servant"/dist "servant-client"/dist "servant-client-core"/dist "servant-docs"/dist "servant-foreign"/dist "servant-server"/dist "doc/tutorial"/dist "doc/cookbook/basic-auth"/dist "doc/cookbook/db-postgres-pool"/dist "doc/cookbook/db-sqlite-simple"/dist "doc/cookbook/file-upload"/dist "doc/cookbook/ https"/dist "doc/cookbook/jwt-and-basic-auth "/dist "doc/cookbook/pagination"/dist "doc/cookbook/structuring-apis"/dist "doc/cookbook/using-custom-monad"/dist
134132 - DISTDIR=$(mktemp -d /tmp/dist-test.XXXX)
135133
136134# Here starts the actual work to be performed for the package under test;
@@ -148,22 +146,26 @@ script:
148146 - (cd "doc/cookbook/basic-auth" && cabal sdist)
149147 - (cd "doc/cookbook/db-postgres-pool" && cabal sdist)
150148 - (cd "doc/cookbook/db-sqlite-simple" && cabal sdist)
149+ - (cd "doc/cookbook/file-upload" && cabal sdist)
151150 - (cd "doc/cookbook/https" && cabal sdist)
151+ - (cd "doc/cookbook/jwt-and-basic-auth" && cabal sdist)
152152 - (cd "doc/cookbook/pagination" && cabal sdist)
153153 - (cd "doc/cookbook/structuring-apis" && cabal sdist)
154154 - (cd "doc/cookbook/using-custom-monad" && cabal sdist)
155155 - echo -en 'travis_fold:end:sdist\\r'
156156 - echo Unpacking... && echo -en 'travis_fold:start:unpack\\r'
157- - mv "servant"/dist/servant-*.tar.gz "servant-client"/dist/servant-client-*.tar.gz "servant-client-core"/dist/servant-client-core-*.tar.gz "servant-docs"/dist/servant-docs-*.tar.gz "servant-foreign"/dist/servant-foreign-*.tar.gz "servant-server"/dist/servant-server-*.tar.gz "doc/tutorial"/dist/tutorial-*.tar.gz "doc/cookbook/basic-auth"/dist/cookbook-basic-auth-*.tar.gz "doc/cookbook/db-postgres-pool"/dist/cookbook-db-postgres-pool-*.tar.gz "doc/cookbook/db-sqlite-simple"/dist/cookbook-db-sqlite-simple-*.tar.gz "doc/cookbook/https"/dist/cookbook-https-*.tar.gz "doc/cookbook/pagination"/dist/cookbook-pagination-*.tar.gz "doc/cookbook/structuring-apis"/dist/cookbook-structuring-apis-*.tar.gz "doc/cookbook/using-custom-monad"/dist/cookbook-using-custom-monad-*.tar.gz ${DISTDIR}/
157+ - mv "servant"/dist/servant-*.tar.gz "servant-client"/dist/servant-client-*.tar.gz "servant-client-core"/dist/servant-client-core-*.tar.gz "servant-docs"/dist/servant-docs-*.tar.gz "servant-foreign"/dist/servant-foreign-*.tar.gz "servant-server"/dist/servant-server-*.tar.gz "doc/tutorial"/dist/tutorial-*.tar.gz "doc/cookbook/basic-auth"/dist/cookbook-basic-auth-*.tar.gz "doc/cookbook/db-postgres-pool"/dist/cookbook-db-postgres-pool-*.tar.gz "doc/cookbook/db-sqlite-simple"/dist/cookbook-db-sqlite-simple-*.tar.gz "doc/cookbook/file-upload"/dist/cookbook-file-upload-*.tar.gz "doc/cookbook/ https"/dist/cookbook-https-*.tar.gz "doc/cookbook/jwt-and-basic-auth"/dist/cookbook-jwt-and-basic-auth -*.tar.gz "doc/cookbook/pagination"/dist/cookbook-pagination-*.tar.gz "doc/cookbook/structuring-apis"/dist/cookbook-structuring-apis-*.tar.gz "doc/cookbook/using-custom-monad"/dist/cookbook-using-custom-monad-*.tar.gz ${DISTDIR}/
158158 - cd ${DISTDIR} || false
159159 - find . -maxdepth 1 -name '*.tar.gz' -exec tar -xvf '{}' \;
160- - " printf 'packages: servant-*/*.cabal servant-client-*/*.cabal servant-client-core-*/*.cabal servant-docs-*/*.cabal servant-foreign-*/*.cabal servant-server-*/*.cabal tutorial-*/*.cabal cookbook-basic-auth-*/*.cabal cookbook-db-postgres-pool-*/*.cabal cookbook-db-sqlite-simple-*/*.cabal cookbook-https-*/*.cabal cookbook-pagination-*/*.cabal cookbook-structuring-apis-*/*.cabal cookbook-using-custom-monad-*/*.cabal\\ n' > cabal.project"
160+ - " printf 'packages: servant-*/*.cabal servant-client-*/*.cabal servant-client-core-*/*.cabal servant-docs-*/*.cabal servant-foreign-*/*.cabal servant-server-*/*.cabal tutorial-*/*.cabal cookbook-basic-auth-*/*.cabal cookbook-db-postgres-pool-*/*.cabal cookbook-db-sqlite-simple-*/*.cabal cookbook-file-upload-*/*.cabal cookbook- https-*/*.cabal cookbook-jwt-and-basic-auth -*/*.cabal cookbook-pagination-*/*.cabal cookbook-structuring-apis-*/*.cabal cookbook-using-custom-monad-*/*.cabal\\ n' > cabal.project"
161161 - " echo 'constraints: foundation >=0.0.14,memory <0.14.12 || >0.14.12' >> cabal.project"
162- - " echo 'allow-newer: servant-auth-server:http-types,servant-auth-server:servant-server, http-media:base' >> cabal.project"
163- - cat cabal.project
162+ - " echo 'allow-newer: servant-auth-server:http-types,servant-auth-server:servant-server, servant-pagination:servant,servant-pagination:servant-server' >> cabal.project"
163+ - touch cabal.project.local
164+ - " if ! $NOINSTALLEDCONSTRAINTS; then for pkg in $($HCPKG list --simple-output); do echo $pkg | sed 's/^/constraints: /' | sed 's/-[^-]*$/ installed/' >> cabal.project.local; done; fi"
165+ - cat cabal.project || true
166+ - cat cabal.project.local || true
164167 - echo -en 'travis_fold:end:unpack\\r'
165168
166-
167169 - echo Building with tests and benchmarks... && echo -en 'travis_fold:start:build-everything\\r'
168170 # build & run tests, build benchmarks
169171 - cabal new-build -w ${HC} ${TEST} ${BENCH} all
@@ -176,5 +178,10 @@ script:
176178 - if $HADDOCK; then cabal new-haddock -w ${HC} ${TEST} ${BENCH} all; else echo "Skipping haddock generation";fi
177179
178180 - echo -en 'travis_fold:end:haddock\\r'
181+ - echo Building without installed constraints for packages in global-db... && echo -en 'travis_fold:start:build-installed\\r'
182+ # Build without installed constraints for packages in global-db
183+ - if $UNCONSTRAINED; then rm -f cabal.project.local; echo cabal new-build -w ${HC} --disable-tests --disable-benchmarks all; else echo "Not building without installed constraints"; fi
184+
185+ - echo -en 'travis_fold:end:build-installed\\r'
179186# REGENDATA ["--config=cabal.make-travis-yml","--output=.travis.yml","cabal.project"]
180187# EOF
0 commit comments