Skip to content

Commit

Permalink
Time different blocks of travis script
Browse files Browse the repository at this point in the history
  • Loading branch information
phadej committed May 30, 2016
1 parent 8e2ee74 commit e581f75
Showing 1 changed file with 123 additions and 82 deletions.
205 changes: 123 additions & 82 deletions travis-script.sh
Original file line number Diff line number Diff line change
Expand Up @@ -48,96 +48,86 @@ case $GHCVER in
;;
esac

# ---------------------------------------------------------------------
# Timing
# ---------------------------------------------------------------------

timed() {
echo "$1"
start_time=`date +%s`
$2
end_time=`date +%s`
echo "$1" took $(expr $end_time - $start_time) seconds.
echo "----"
}

# ---------------------------------------------------------------------
# Bootstrap cabal, to verify bootstrap.sh script works.
# ---------------------------------------------------------------------

OLD_CWD=$PWD
bootstrap() {
OLD_CWD=$PWD

# Bootstrap
cd cabal-install
env EXTRA_CONFIGURE_OPTS="" ./bootstrap.sh $bootstrap_jobs --no-doc
~/.cabal/bin/cabal --version
# Bootstrap
cd cabal-install
env EXTRA_CONFIGURE_OPTS="" ./bootstrap.sh $bootstrap_jobs --no-doc
~/.cabal/bin/cabal --version

# Move cabal for local use.
mkdir ~/fresh-cabal
mv -i ~/.cabal/bin/cabal ~/fresh-cabal/
# Move cabal for local use.
mkdir ~/fresh-cabal
mv -i ~/.cabal/bin/cabal ~/fresh-cabal/

# Clean up after ourselves.
rm -r ~/.ghc ~/.cabal
# Clean up after ourselves.
rm -r ~/.ghc ~/.cabal

# From here on we use the freshly built cabal executable.
export PATH="$HOME/fresh-cabal/:$PATH"
# From here on we use the freshly built cabal executable.
export PATH="$HOME/fresh-cabal/:$PATH"

cd "$OLD_CWD"
cd "$OLD_CWD"
}

install_parsec() {
# Initial working directory: base directory of Git repository

# Initial working directory: base directory of Git repository
cabal update

cabal update
# We depend on parsec nowadays, which isn't distributed with GHC <8.0
if [ "$PARSEC_BUNDLED" != "YES" ]; then
cabal install $jobs parsec
fi
}

# We depend on parsec nowadays, which isn't distributed with GHC <8.0
if [ "$PARSEC_BUNDLED" != "YES" ]; then
cabal install $jobs parsec
fi
timed "bootstrap.sh script" bootstrap
timed "Installing parsec" install_parsec

# ---------------------------------------------------------------------
# Check that auto-generated files/fields are up to date.
# ---------------------------------------------------------------------

# Regenerate the CONTRIBUTORS file.
# Currently doesn't work because Travis uses --depth=50 when cloning.
#./Cabal/misc/gen-authors.sh > AUTHORS
generated_files() {
# Regenerate the CONTRIBUTORS file.
# Currently doesn't work because Travis uses --depth=50 when cloning.
#./Cabal/misc/gen-authors.sh > AUTHORS

# Regenerate the 'extra-source-files' field in Cabal.cabal.
cd Cabal
./misc/gen-extra-source-files.sh Cabal.cabal

# Regenerate the 'extra-source-files' field in Cabal.cabal.
cd Cabal
./misc/gen-extra-source-files.sh Cabal.cabal
# Regenerate the 'extra-source-files' field in cabal-install.cabal.
cd ../cabal-install
../Cabal/misc/gen-extra-source-files.sh cabal-install.cabal
cd ..

# Regenerate the 'extra-source-files' field in cabal-install.cabal.
cd ../cabal-install
../Cabal/misc/gen-extra-source-files.sh cabal-install.cabal
cd ..
# Fail if the diff is not empty.
./Cabal/misc/travis-diff-files.sh
}

# Fail if the diff is not empty.
./Cabal/misc/travis-diff-files.sh
timed "Generated files check" generated_files

# ---------------------------------------------------------------------
# Cabal
# ---------------------------------------------------------------------

cd Cabal

# Build the setup script in the same way that cabal-install would:
mkdir -p ./dist/setup
cp Setup.hs ./dist/setup/setup.hs
ghc --make \
$jobs \
-odir ./dist/setup -hidir ./dist/setup -i -i. \
./dist/setup/setup.hs -o ./dist/setup/setup \
-Wall -Werror -threaded

# Install test dependencies only after setup is built
cabal install $jobs --only-dependencies --enable-tests --enable-benchmarks
./dist/setup/setup configure \
--user --ghc-option=-Werror --enable-tests --enable-benchmarks \
-v2 # -v2 provides useful information for debugging

# Build all libraries and executables (including tests/benchmarks)
./dist/setup/setup build $jobs
./dist/setup/setup haddock # see https://github.com/haskell/cabal/issues/2198
./dist/setup/setup test --show-details=streaming --test-option=--hide-successes

# Redo the package tests with different versions of GHC
if [ "x$TEST_OLDER" = "xYES" ]; then
CABAL_PACKAGETESTS_WITH_GHC=/opt/ghc/7.0.4/bin/ghc \
./dist/setup/setup test package-tests --show-details=streaming
CABAL_PACKAGETESTS_WITH_GHC=/opt/ghc/7.2.2/bin/ghc \
./dist/setup/setup test package-tests --show-details=streaming
fi

cabal check
cabal sdist # tests that a source-distribution can be generated

# The following scriptlet checks that the resulting source distribution can be
# built & installed.
install_from_tarball() {
Expand All @@ -151,29 +141,80 @@ install_from_tarball() {
fi
}

install_from_tarball
cabal_dependencies() {
cd Cabal

# Build the setup script in the same way that cabal-install would:
mkdir -p ./dist/setup
cp Setup.hs ./dist/setup/setup.hs
ghc --make \
$jobs \
-odir ./dist/setup -hidir ./dist/setup -i -i. \
./dist/setup/setup.hs -o ./dist/setup/setup \
-Wall -Werror -threaded

# Install test dependencies only after setup is built
cabal install $jobs --only-dependencies --enable-tests --enable-benchmarks
}

cabal_build() {
./dist/setup/setup configure \
--user --ghc-option=-Werror --enable-tests --enable-benchmarks \
-v2 # -v2 provides useful information for debugging

# Build all libraries and executables (including tests/benchmarks)
./dist/setup/setup build $jobs
./dist/setup/setup haddock # see https://github.com/haskell/cabal/issues/2198
./dist/setup/setup test --show-details=streaming --test-option=--hide-successes

# Redo the package tests with different versions of GHC
if [ "x$TEST_OLDER" = "xYES" ]; then
CABAL_PACKAGETESTS_WITH_GHC=/opt/ghc/7.0.4/bin/ghc \
./dist/setup/setup test package-tests --show-details=streaming
CABAL_PACKAGETESTS_WITH_GHC=/opt/ghc/7.2.2/bin/ghc \
./dist/setup/setup test package-tests --show-details=streaming
fi

cabal check
cabal sdist # tests that a source-distribution can be generated
install_from_tarball

cd ..
}

timed "Cabal dependencies" cabal_dependencies
timed "Cabal build" cabal_build

# ---------------------------------------------------------------------
# cabal-install
# ---------------------------------------------------------------------

cd ../cabal-install

cabal install $jobs happy
cabal install $jobs --only-dependencies --enable-tests --enable-benchmarks
cabal configure \
--user --ghc-option=-Werror --enable-tests --enable-benchmarks \
-v2 # -v2 provides useful information for debugging
cabal build $jobs
cabal haddock # see https://github.com/haskell/cabal/issues/2198
cabal test unit-tests --show-details=streaming --test-option=--hide-successes
cabal test integration-tests --show-details=streaming --test-option=--hide-successes
cabal test integration-tests2 --show-details=streaming --test-option=--hide-successes
cabal test solver-quickcheck --show-details=streaming --test-option=--hide-successes \
--test-option=--quickcheck-tests=1000
cabal check
./dist/setup/setup sdist
install_from_tarball
cabalinstall_dependencies() {
cd cabal-install

cabal install $jobs happy
cabal install $jobs --only-dependencies --enable-tests --enable-benchmarks
}

cabalinstall_build() {
cabal configure \
--user --ghc-option=-Werror --enable-tests --enable-benchmarks \
-v2 # -v2 provides useful information for debugging
cabal build $jobs
cabal haddock # see https://github.com/haskell/cabal/issues/2198
cabal test unit-tests --show-details=streaming --test-option=--hide-successes
cabal test integration-tests --show-details=streaming --test-option=--hide-successes
cabal test integration-tests2 --show-details=streaming --test-option=--hide-successes
cabal test solver-quickcheck --show-details=streaming --test-option=--hide-successes \
--test-option=--quickcheck-tests=1000
cabal check
./dist/setup/setup sdist
install_from_tarball

}

timed "cabal-install dependencies" cabalinstall_dependencies
timed "cabal-install build" cabalinstall_build

# Check what we got
~/.cabal/bin/cabal --version

0 comments on commit e581f75

Please sign in to comment.