X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=validate;h=8f70811e411b93029afdd168af23599eb240e2f8;hp=3f074033413cbf7852451a14583cfb991fdb52cd;hb=0b9530245a33b8206ca38b9de6dfb01e056fd8dc;hpb=8a2809c29de9f23eba7ca682b48390033a9d40f6 diff --git a/validate b/validate index 3f07403..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 @@ -9,22 +11,40 @@ if [ -f mk/build.mk ]; then fi # The default is a "quick" build -echo BuildFlavour=quick >mk/build.mk -cat mk/build.mk.sample >>mk/build.mk +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 @@ -37,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