1 # NB: don't set `language: haskell` here
2 # We specify language: c, so it doesn't default to e.g. ruby
9 # Remember to add release branches
10 # we whitelist branches, as we don't really need to build dev-branches.
20 # The following enables several GHC versions to be tested; often it's enough to
21 # test only against the last release in a major GHC version. Feel free to omit
22 # lines listings versions you don't need/want testing for.
24 # NB: If you test the same GHC version/OS combo multiple times with
25 # SCRIPT=script (e.g., see PARSEC=YES below), you MUST supply a
26 # TAGSUFFIX to help travis/upload.sh disambiguate the matrix entry.
29 - env: GHCVER=8.0.2 SCRIPT=meta BUILDER=none
32 # These don't have -dyn/-prof whitelisted yet, so we have to
33 # do the old-style installation
34 - env: GHCVER=7.4.2 SCRIPT=script CABAL_LIB_ONLY=YES TEST_OTHER_VERSIONS=YES
37 - env: GHCVER=7.6.3 SCRIPT=script
40 - env: GHCVER=7.8.4 SCRIPT=script USE_GOLD=YES
43 # Ugh, we'd like to drop 'sudo: required' and use the
44 # apt plugin for the next two
45 # but the GCE instance we get has more memory, which makes
47 - env: GHCVER=7.10.3 SCRIPT=script USE_GOLD=YES
50 - env: GHCVER=8.0.2 SCRIPT=script DEPLOY_DOCS=YES USE_GOLD=YES TEST_SOLVER_BENCHMARKS=YES
54 - env: GHCVER=8.0.2 SCRIPT=solver-debug-flags USE_GOLD=YES
57 - env: GHCVER=8.0.2 SCRIPT=script DEBUG_EXPENSIVE_ASSERTIONS=YES TAGSUFFIX="-fdebug-expensive-assertions" USE_GOLD=YES
60 - env: GHCVER=8.0.2 SCRIPT=bootstrap USE_GOLD=YES
63 - env: GHCVER=8.2.1 SCRIPT=script
67 # We axed GHC 7.6 and earlier because it's not worth the trouble to
68 # make older GHC work with clang's cpp. See
69 # https://ghc.haskell.org/trac/ghc/ticket/8493
70 - env: GHCVER=7.8.4 SCRIPT=script
72 # Keep this synced with travis/upload.sh
73 osx_image: xcode6.4 # We need 10.10
75 # TODO: We might want to specify OSX version
76 # https://docs.travis-ci.com/user/osx-ci-environment/#OS-X-Version
77 - env: GHCVER=7.10.3 SCRIPT=script
79 - env: GHCVER=8.0.2 SCRIPT=script
81 - env: GHCVER=8.0.2 SCRIPT=bootstrap
84 - env: GHCVER=via-stack SCRIPT=stack STACKAGE_RESOLVER=lts
92 - env: GHCVER=via-stack SCRIPT=stack STACKAGE_RESOLVER=lts
94 # TODO add PARSEC_BUNDLED=YES when it's so
95 # It seems pointless to run head if we're going to ignore the results.
98 # Note: the distinction between `before_install` and `install` is not important.
100 - export PATH=/opt/ghc/$GHCVER/bin:$PATH
101 - export PATH=$HOME/.ghc-install/$GHCVER/bin:$PATH
102 - export PATH=$HOME/bin:$PATH
103 - export PATH=$HOME/.cabal/bin:$PATH
104 - export PATH=$HOME/.local/bin:$PATH
105 - export PATH=/opt/cabal/2.0/bin:$PATH
106 - export PATH=/opt/happy/1.19.5/bin:$PATH
107 - export PATH=/opt/alex/3.1.7/bin:$PATH
108 - if [ "$USE_GOLD" = "YES" ]; then sudo update-alternatives --install "/usr/bin/ld" "ld" "/usr/bin/ld.gold" 20; fi
109 - if [ "$USE_GOLD" = "YES" ]; then sudo update-alternatives --install "/usr/bin/ld" "ld" "/usr/bin/ld.bfd" 10; fi
111 - ./travis-install.sh
114 # We intentionally do not install anything before trying to build Cabal because
115 # it should build with each supported GHC version out-of-the-box.
117 # Here starts the actual work to be performed for the package under test; any
118 # command which exits with a non-zero exit code causes the build to fail. Using
119 # ./dist/setup/setup here instead of cabal-install to avoid breakage when the
120 # build config format changed.
122 - rm -rf dist-newstyle
123 - ./travis-${SCRIPT}.sh -j2
127 - $HOME/.cabal/packages
132 - $HOME/.stack/precompiled
133 - $HOME/.stack/programs
134 - $HOME/.stack/setup-exe-cache
135 - $HOME/.stack/snapshots
137 # We remove the index because it churns quite a bit and we don't want
138 # to pay the cost of repeatedly caching it even though we don't care
139 # about most changing packages.
141 - rm -fv $HOME/.cabal/packages/hackage.haskell.org/build-reports.log
142 - rm -fv $HOME/.cabal/packages/hackage.haskell.org/00-index*
143 - rm -fv $HOME/.cabal/packages/hackage.haskell.org/01-index*
144 - rm -fv $HOME/.cabal/packages/hackage.haskell.org/*.json
146 # Deploy Haddocks to the haskell/cabal-website repo.
148 # Set up deployment to the haskell/cabal-website repo.
149 # NB: these commands MUST be in .travis.yml, otherwise the secret key can be
150 # leaked! See https://github.com/travis-ci/travis.rb/issues/423.
151 # umask to get the permissions to be 600.
152 - if [ "x$TRAVIS_REPO_SLUG" = "xhaskell/cabal" -a "x$TRAVIS_PULL_REQUEST" = "xfalse" -a "x$TRAVIS_BRANCH" = "xmaster" -a "x$DEPLOY_DOCS" = "xYES" ]; then (umask 177 && openssl aes-256-cbc -K $encrypted_edaf6551664d_key -iv $encrypted_edaf6551664d_iv -in id_rsa_cabal_website.aes256.enc -out ~/.ssh/id_rsa -d); fi
158 - "chat.freenode.net##haskell-cabal"
159 slack: haskell-cabal:sCq6GLfy9N8MJrInosg871n4