Skip to content

Commit 360eafc

Browse files
committed
Test with GHC 8.6.5 instead of 8.6.3. Add GHC 8.8.1.
1 parent 75c64b4 commit 360eafc

File tree

2 files changed

+134
-118
lines changed

2 files changed

+134
-118
lines changed

.travis.yml

Lines changed: 132 additions & 116 deletions
Original file line numberDiff line numberDiff line change
@@ -1,154 +1,170 @@
11
# This Travis job script has been generated by a script via
22
#
3-
# runghc make_travis_yml_2.hs '--ghc-head' '-o' '.travis.yml' 'GLUT.cabal'
3+
# haskell-ci 'GLUT.cabal' '--output' '.travis.yml'
44
#
55
# For more information, see https://github.com/haskell-CI/haskell-ci
66
#
7+
# version: 0.3.20190429
8+
#
79
language: c
8-
sudo: false
9-
10+
dist: xenial
1011
git:
11-
submodules: false # whether to recursively clone submodules
12-
12+
# whether to recursively clone submodules
13+
submodules: false
1314
cache:
1415
directories:
1516
- $HOME/.cabal/packages
1617
- $HOME/.cabal/store
17-
1818
before_cache:
19-
- rm -fv $HOME/.cabal/packages/hackage.haskell.org/build-reports.log
19+
- rm -fv $CABALHOME/packages/hackage.haskell.org/build-reports.log
2020
# remove files that are regenerated by 'cabal update'
21-
- rm -fv $HOME/.cabal/packages/hackage.haskell.org/00-index.*
22-
- rm -fv $HOME/.cabal/packages/hackage.haskell.org/*.json
23-
- rm -fv $HOME/.cabal/packages/hackage.haskell.org/01-index.cache
24-
- rm -fv $HOME/.cabal/packages/hackage.haskell.org/01-index.tar
25-
- rm -fv $HOME/.cabal/packages/hackage.haskell.org/01-index.tar.idx
26-
27-
- rm -rfv $HOME/.cabal/packages/head.hackage
28-
21+
- rm -fv $CABALHOME/packages/hackage.haskell.org/00-index.*
22+
- rm -fv $CABALHOME/packages/hackage.haskell.org/*.json
23+
- rm -fv $CABALHOME/packages/hackage.haskell.org/01-index.cache
24+
- rm -fv $CABALHOME/packages/hackage.haskell.org/01-index.tar
25+
- rm -fv $CABALHOME/packages/hackage.haskell.org/01-index.tar.idx
26+
- rm -rfv $CABALHOME/packages/head.hackage
2927
matrix:
3028
include:
31-
- compiler: "ghc-8.6.3"
32-
# env: TEST=--disable-tests BENCH=--disable-benchmarks
33-
addons: {apt: {packages: [ghc-ppa-tools,cabal-install-2.4,ghc-8.6.3], sources: [hvr-ghc]}}
34-
- compiler: "ghc-8.4.3"
35-
# env: TEST=--disable-tests BENCH=--disable-benchmarks
36-
addons: {apt: {packages: [ghc-ppa-tools,cabal-install-2.4,ghc-8.4.3], sources: [hvr-ghc]}}
37-
- compiler: "ghc-8.2.2"
38-
# env: TEST=--disable-tests BENCH=--disable-benchmarks
39-
addons: {apt: {packages: [ghc-ppa-tools,cabal-install-2.4,ghc-8.2.2], sources: [hvr-ghc]}}
40-
- compiler: "ghc-8.0.2"
41-
# env: TEST=--disable-tests BENCH=--disable-benchmarks
42-
addons: {apt: {packages: [ghc-ppa-tools,cabal-install-2.4,ghc-8.0.2], sources: [hvr-ghc]}}
43-
- compiler: "ghc-7.10.3"
44-
# env: TEST=--disable-tests BENCH=--disable-benchmarks
45-
addons: {apt: {packages: [ghc-ppa-tools,cabal-install-2.4,ghc-7.10.3], sources: [hvr-ghc]}}
46-
- compiler: "ghc-7.8.4"
47-
# env: TEST=--disable-tests BENCH=--disable-benchmarks
48-
addons: {apt: {packages: [ghc-ppa-tools,cabal-install-2.4,ghc-7.8.4], sources: [hvr-ghc]}}
49-
- compiler: "ghc-7.6.3"
50-
# env: TEST=--disable-tests BENCH=--disable-benchmarks
51-
addons: {apt: {packages: [ghc-ppa-tools,cabal-install-2.4,ghc-7.6.3], sources: [hvr-ghc]}}
52-
- compiler: "ghc-7.4.2"
53-
# env: TEST=--disable-tests BENCH=--disable-benchmarks
54-
addons: {apt: {packages: [ghc-ppa-tools,cabal-install-2.4,ghc-7.4.2], sources: [hvr-ghc]}}
55-
- compiler: "ghc-7.2.2"
56-
# env: TEST=--disable-tests BENCH=--disable-benchmarks
57-
addons: {apt: {packages: [ghc-ppa-tools,cabal-install-2.4,ghc-7.2.2], sources: [hvr-ghc]}}
58-
- compiler: "ghc-7.0.4"
59-
# env: TEST=--disable-tests BENCH=--disable-benchmarks
60-
addons: {apt: {packages: [ghc-ppa-tools,cabal-install-2.4,ghc-7.0.4], sources: [hvr-ghc]}}
61-
- compiler: "ghc-head"
29+
- compiler: ghc-8.8.1
30+
addons: {"apt":{"sources":["hvr-ghc"],"packages":["ghc-8.8.1","cabal-install-3.0"]}}
6231
env: GHCHEAD=true
63-
addons: {apt: {packages: [ghc-ppa-tools,cabal-install-head,ghc-head], sources: [hvr-ghc]}}
64-
32+
- compiler: ghc-8.6.5
33+
addons: {"apt":{"sources":["hvr-ghc"],"packages":["ghc-8.6.5","cabal-install-2.4"]}}
34+
- compiler: ghc-8.4.3
35+
addons: {"apt":{"sources":["hvr-ghc"],"packages":["ghc-8.4.3","cabal-install-2.4"]}}
36+
- compiler: ghc-8.2.2
37+
addons: {"apt":{"sources":["hvr-ghc"],"packages":["ghc-8.2.2","cabal-install-2.4"]}}
38+
- compiler: ghc-8.0.2
39+
addons: {"apt":{"sources":["hvr-ghc"],"packages":["ghc-8.0.2","cabal-install-2.4"]}}
40+
- compiler: ghc-7.10.3
41+
addons: {"apt":{"sources":["hvr-ghc"],"packages":["ghc-7.10.3","cabal-install-2.4"]}}
42+
- compiler: ghc-7.8.4
43+
addons: {"apt":{"sources":["hvr-ghc"],"packages":["ghc-7.8.4","cabal-install-2.4"]}}
44+
- compiler: ghc-7.6.3
45+
addons: {"apt":{"sources":["hvr-ghc"],"packages":["ghc-7.6.3","cabal-install-2.4"]}}
46+
- compiler: ghc-7.4.2
47+
addons: {"apt":{"sources":["hvr-ghc"],"packages":["ghc-7.4.2","cabal-install-2.4"]}}
48+
- compiler: ghc-7.2.2
49+
addons: {"apt":{"sources":["hvr-ghc"],"packages":["ghc-7.2.2","cabal-install-2.4"]}}
50+
- compiler: ghc-7.0.4
51+
addons: {"apt":{"sources":["hvr-ghc"],"packages":["ghc-7.0.4","cabal-install-2.4"]}}
6552
allow_failures:
66-
- compiler: "ghc-head"
67-
53+
- compiler: ghc-8.8.1
6854
before_install:
69-
- HC=${CC}
70-
- HCPKG=${HC/ghc/ghc-pkg}
55+
- HC=$(echo "/opt/$CC/bin/ghc" | sed 's/-/\//')
56+
- HCPKG="$HC-pkg"
7157
- unset CC
72-
- ROOTDIR=$(pwd)
73-
- mkdir -p $HOME/.local/bin
74-
- "PATH=/opt/ghc/bin:/opt/ghc-ppa-tools/bin:$HOME/local/bin:$PATH"
58+
- CABAL=/opt/ghc/bin/cabal
59+
- CABALHOME=$HOME/.cabal
60+
- export PATH="$CABALHOME/bin:$PATH"
61+
- TOP=$(pwd)
7562
- HCNUMVER=$(( $(${HC} --numeric-version|sed -E 's/([0-9]+)\.([0-9]+)\.([0-9]+).*/\1 * 10000 + \2 * 100 + \3/') ))
7663
- echo $HCNUMVER
77-
64+
- CABAL="$CABAL -vnormal+nowrap+markoutput"
65+
- set -o pipefail
66+
- |
67+
echo 'function blue(s) { printf "\033[0;34m" s "\033[0m " }' >> .colorful.awk
68+
echo 'BEGIN { state = "output"; }' >> .colorful.awk
69+
echo '/^-----BEGIN CABAL OUTPUT-----$/ { state = "cabal" }' >> .colorful.awk
70+
echo '/^-----END CABAL OUTPUT-----$/ { state = "output" }' >> .colorful.awk
71+
echo '!/^(-----BEGIN CABAL OUTPUT-----|-----END CABAL OUTPUT-----)/ {' >> .colorful.awk
72+
echo ' if (state == "cabal") {' >> .colorful.awk
73+
echo ' print blue($0)' >> .colorful.awk
74+
echo ' } else {' >> .colorful.awk
75+
echo ' print $0' >> .colorful.awk
76+
echo ' }' >> .colorful.awk
77+
echo '}' >> .colorful.awk
78+
- cat .colorful.awk
79+
- |
80+
color_cabal_output () {
81+
awk -f $TOP/.colorful.awk
82+
}
83+
- echo text | color_cabal_output
7884
install:
79-
- cabal --version
85+
- ${CABAL} --version
8086
- echo "$(${HC} --version) [$(${HC} --print-project-git-commit-id 2> /dev/null || echo '?')]"
81-
- BENCH=${BENCH---enable-benchmarks}
82-
- TEST=${TEST---enable-tests}
83-
- HADDOCK=${HADDOCK-true}
84-
- UNCONSTRAINED=${UNCONSTRAINED-true}
85-
- NOINSTALLEDCONSTRAINTS=${NOINSTALLEDCONSTRAINTS-false}
87+
- TEST=--enable-tests
88+
- BENCH=--enable-benchmarks
8689
- GHCHEAD=${GHCHEAD-false}
87-
- travis_retry cabal update -v
88-
- "sed -i.bak 's/^jobs:/-- jobs:/' ${HOME}/.cabal/config"
89-
- rm -fv cabal.project cabal.project.local
90-
# Overlay Hackage Package Index for GHC HEAD: https://github.com/hvr/head.hackage
90+
- rm -f $CABALHOME/config
91+
- |
92+
echo "verbose: normal +nowrap +markoutput" >> $CABALHOME/config
93+
echo "remote-build-reporting: anonymous" >> $CABALHOME/config
94+
echo "remote-repo-cache: $CABALHOME/packages" >> $CABALHOME/config
95+
echo "logs-dir: $CABALHOME/logs" >> $CABALHOME/config
96+
echo "world-file: $CABALHOME/world" >> $CABALHOME/config
97+
echo "extra-prog-path: $CABALHOME/bin" >> $CABALHOME/config
98+
echo "symlink-bindir: $CABALHOME/bin" >> $CABALHOME/config
99+
echo "installdir: $CABALHOME/bin" >> $CABALHOME/config
100+
echo "build-summary: $CABALHOME/logs/build.log" >> $CABALHOME/config
101+
echo "store-dir: $CABALHOME/store" >> $CABALHOME/config
102+
echo "install-dirs user" >> $CABALHOME/config
103+
echo " prefix: $CABALHOME" >> $CABALHOME/config
104+
echo "repository hackage.haskell.org" >> $CABALHOME/config
105+
echo " url: http://hackage.haskell.org/" >> $CABALHOME/config
91106
- |
92107
if $GHCHEAD; then
93-
sed -i 's/-- allow-newer: .*/allow-newer: *:base/' ${HOME}/.cabal/config
94-
for pkg in $($HCPKG list --simple-output); do pkg=$(echo $pkg | sed 's/-[^-]*$//'); sed -i "s/allow-newer: /allow-newer: *:$pkg, /" ${HOME}/.cabal/config; done
95-
96-
echo 'repository head.hackage' >> ${HOME}/.cabal/config
97-
echo ' url: http://head.hackage.haskell.org/' >> ${HOME}/.cabal/config
98-
echo ' secure: True' >> ${HOME}/.cabal/config
99-
echo ' root-keys: 07c59cb65787dedfaef5bd5f987ceb5f7e5ebf88b904bbd4c5cbdeb2ff71b740' >> ${HOME}/.cabal/config
100-
echo ' 2e8555dde16ebd8df076f1a8ef13b8f14c66bad8eafefd7d9e37d0ed711821fb' >> ${HOME}/.cabal/config
101-
echo ' 8f79fd2389ab2967354407ec852cbe73f2e8635793ac446d09461ffb99527f6e' >> ${HOME}/.cabal/config
102-
echo ' key-threshold: 3' >> ${HOME}/.cabal.config
103-
104-
grep -Ev -- '^\s*--' ${HOME}/.cabal/config | grep -Ev '^\s*$'
105-
106-
cabal new-update head.hackage -v
108+
echo "allow-newer: $($HCPKG list --simple-output | sed -E 's/([a-zA-Z-]+)-[0-9.]+/*:\1/g')" >> $CABALHOME/config
109+
110+
echo "repository head.hackage" >> $CABALHOME/config
111+
echo " url: http://head.hackage.haskell.org/" >> $CABALHOME/config
112+
echo " secure: True" >> $CABALHOME/config
113+
echo " root-keys: 07c59cb65787dedfaef5bd5f987ceb5f7e5ebf88b904bbd4c5cbdeb2ff71b740" >> $CABALHOME/config
114+
echo " 2e8555dde16ebd8df076f1a8ef13b8f14c66bad8eafefd7d9e37d0ed711821fb" >> $CABALHOME/config
115+
echo " 8f79fd2389ab2967354407ec852cbe73f2e8635793ac446d09461ffb99527f6e" >> $CABALHOME/config
116+
echo " key-threshold: 3" >> $CABALHOME/config
107117
fi
108-
- grep -Ev -- '^\s*--' ${HOME}/.cabal/config | grep -Ev '^\s*$'
109-
- "printf 'packages: \".\"\\n' > cabal.project"
110-
- "printf 'write-ghc-environment-files: always\\n' >> cabal.project"
111-
- touch cabal.project.local
112-
- "if ! $NOINSTALLEDCONSTRAINTS; then for pkg in $($HCPKG list --simple-output); do echo $pkg | grep -vw -- GLUT | sed 's/^/constraints: /' | sed 's/-[^-]*$/ installed/' >> cabal.project.local; done; fi"
118+
- cat $CABALHOME/config
119+
- rm -fv cabal.project cabal.project.local cabal.project.freeze
120+
- travis_retry ${CABAL} v2-update -v
121+
# Generate cabal.project
122+
- rm -rf cabal.project cabal.project.local cabal.project.freeze
123+
- touch cabal.project
124+
- |
125+
echo 'packages: "."' >> cabal.project
126+
- |
127+
echo "write-ghc-environment-files: always" >> cabal.project
128+
- "for pkg in $($HCPKG list --simple-output); do echo $pkg | sed 's/-[^-]*$//' | (grep -vE -- '^(GLUT)$' || true) | sed 's/^/constraints: /' | sed 's/$/ installed/' >> cabal.project.local; done"
113129
- cat cabal.project || true
114130
- cat cabal.project.local || true
115-
- if [ -f "./configure.ac" ]; then
116-
(cd "." && autoreconf -i);
117-
fi
118-
- rm -f cabal.project.freeze
119-
- cabal new-build -w ${HC} ${TEST} ${BENCH} --project-file="cabal.project" --dep -j2 all
120-
- cabal new-build -w ${HC} --disable-tests --disable-benchmarks --project-file="cabal.project" --dep -j2 all
121-
- rm -rf .ghc.environment.* "."/dist
122-
- DISTDIR=$(mktemp -d /tmp/dist-test.XXXX)
123-
124-
# Here starts the actual work to be performed for the package under test;
125-
# any command which exits with a non-zero exit code causes the build to fail.
131+
- if [ -f "./configure.ac" ]; then (cd "." && autoreconf -i); fi
132+
- ${CABAL} v2-freeze -w ${HC} ${TEST} ${BENCH} | color_cabal_output
133+
- "cat cabal.project.freeze | sed -E 's/^(constraints: *| *)//' | sed 's/any.//'"
134+
- rm cabal.project.freeze
135+
- ${CABAL} v2-build -w ${HC} ${TEST} ${BENCH} --dep -j2 all | color_cabal_output
136+
- ${CABAL} v2-build -w ${HC} --disable-tests --disable-benchmarks --dep -j2 all | color_cabal_output
126137
script:
127-
# test that source-distributions can be generated
128-
- cabal new-sdist all
138+
- DISTDIR=$(mktemp -d /tmp/dist-test.XXXX)
139+
# Packaging...
140+
- ${CABAL} v2-sdist all | color_cabal_output
141+
# Unpacking...
129142
- mv dist-newstyle/sdist/*.tar.gz ${DISTDIR}/
130143
- cd ${DISTDIR} || false
131144
- find . -maxdepth 1 -name '*.tar.gz' -exec tar -xvf '{}' \;
132-
- "printf 'packages: GLUT-*/*.cabal\\n' > cabal.project"
133-
- "printf 'write-ghc-environment-files: always\\n' >> cabal.project"
134-
- touch cabal.project.local
135-
- "if ! $NOINSTALLEDCONSTRAINTS; then for pkg in $($HCPKG list --simple-output); do echo $pkg | grep -vw -- GLUT | sed 's/^/constraints: /' | sed 's/-[^-]*$/ installed/' >> cabal.project.local; done; fi"
145+
# Generate cabal.project
146+
- rm -rf cabal.project cabal.project.local cabal.project.freeze
147+
- touch cabal.project
148+
- |
149+
echo 'packages: "GLUT-*/*.cabal"' >> cabal.project
150+
- |
151+
echo "write-ghc-environment-files: always" >> cabal.project
152+
- "for pkg in $($HCPKG list --simple-output); do echo $pkg | sed 's/-[^-]*$//' | (grep -vE -- '^(GLUT)$' || true) | sed 's/^/constraints: /' | sed 's/$/ installed/' >> cabal.project.local; done"
136153
- cat cabal.project || true
137154
- cat cabal.project.local || true
155+
# Building...
138156
# this builds all libraries and executables (without tests/benchmarks)
139-
- cabal new-build -w ${HC} --disable-tests --disable-benchmarks all
140-
157+
- ${CABAL} v2-build -w ${HC} --disable-tests --disable-benchmarks all | color_cabal_output
158+
# Building with tests and benchmarks...
141159
# build & run tests, build benchmarks
142-
- cabal new-build -w ${HC} ${TEST} ${BENCH} all
143-
144-
# cabal check
145-
- (cd GLUT-* && cabal check)
146-
147-
# haddock
148-
- if $HADDOCK; then cabal new-haddock -w ${HC} ${TEST} ${BENCH} all; else echo "Skipping haddock generation";fi
149-
150-
# Build without installed constraints for packages in global-db
151-
- 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
152-
153-
# REGENDATA ["--ghc-head","-o",".travis.yml","GLUT.cabal"]
160+
- ${CABAL} v2-build -w ${HC} ${TEST} ${BENCH} all | color_cabal_output
161+
# cabal check...
162+
- (cd GLUT-* && ${CABAL} -vnormal check)
163+
# haddock...
164+
- ${CABAL} v2-haddock -w ${HC} ${TEST} ${BENCH} all | color_cabal_output
165+
# Building without installed constraints for packages in global-db...
166+
- rm -f cabal.project.local
167+
- ${CABAL} v2-build -w ${HC} --disable-tests --disable-benchmarks all | color_cabal_output
168+
169+
# REGENDATA ["GLUT.cabal","--output",".travis.yml"]
154170
# EOF

GLUT.cabal

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -25,8 +25,8 @@ tested-with:
2525
GHC == 8.0.2
2626
GHC == 8.2.2
2727
GHC == 8.4.3
28-
GHC == 8.6.3
29-
GHC == 8.7.*
28+
GHC == 8.6.5
29+
GHC == 8.8.1
3030
cabal-version: >= 1.10
3131
extra-source-files:
3232
CHANGELOG.md

0 commit comments

Comments
 (0)