X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=validate;h=8f70811e411b93029afdd168af23599eb240e2f8;hp=73bef5292dd7c4222525bb3868c4b6791f5a11f7;hb=0b9530245a33b8206ca38b9de6dfb01e056fd8dc;hpb=8ce457c49024a92dc0e13c0d36cc6753edec8087 diff --git a/validate b/validate index 73bef52..8f70811 100644 --- a/validate +++ b/validate @@ -1,4 +1,6 @@ -#!/bin/sh -e +#!/bin/sh + +set -e if [ -f mk/config.mk ]; then make distclean @@ -7,18 +9,42 @@ fi if [ -f mk/build.mk ]; then mv mk/build.mk mk/build.mk.bak fi -echo BuildFlavour=quick >mk/build.mk -cat mk/build.mk.sample >>mk/build.mk + +# The default is a "quick" build +echo BuildFlavour=quick > mk/build.mk +echo HADDOCK_DOCS=YES >> mk/build.mk +cat mk/build.mk.sample >> mk/build.mk + +# You can override the default validate settings using mk/validate.mk +# e.g. you could add GhcLibWays=p to test profiling. +echo '-include $(TOP)/mk/validate.mk' >>mk/build.mk + +case $OSTYPE in + cygwin|msys) config_args=--build=i386-unknown-mingw32 + if [ -f c:/mingw/bin/gcc.exe ]; then + config_args="$config_args --with-gcc=c:/mingw/bin/gcc" + fi + ;; +esac + +if [ "$CPUS" = "" ]; then + threads=2 +else + threads=`expr $CPUS + 1` +fi sh boot -./configure -# ToDo: configure args +./configure $config_args -make -j2 +make -j$threads -make -C testsuite/tests/ghc-regress fast stage=2 2>&1 | tee testlog +# ToDo: use THREADS=$threads, see #1558 +make -C testsuite/tests/ghc-regress fast stage=2 CLEANUP=1 2>&1 | tee testlog -if grep '0 unexpected failures' testlog >/dev/null 2>/dev/null; then +if + grep '\<0 caused framework failures' testlog >/dev/null 2>/dev/null && + grep '\<0 unexpected passes' testlog >/dev/null 2>/dev/null && + grep '\<0 unexpected failures' testlog >/dev/null 2>/dev/null ; then echo "-------------------------------------------------------------------" echo "Congratulations! This tree is has passed minimal testing." echo @@ -31,7 +57,8 @@ if grep '0 unexpected failures' testlog >/dev/null 2>/dev/null; then echo "-------------------------------------------------------------------" else echo "-------------------------------------------------------------------" - echo "Oops! Looks like you have some test failures." + echo "Oops! Looks like you have some unexpected test results or" + echo "framework failures." echo "Please fix them before pushing/sending patches." echo "-------------------------------------------------------------------" fi