X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/1de2cea69ed077bfc9b387814f95dc35db3083dc..8dbe2058fb2e5717d3077dbaf890d3919405697e:/tools/jenkins/build.sh diff --git a/tools/jenkins/build.sh b/tools/jenkins/build.sh index 9379aef4b8..f5b07f2928 100755 --- a/tools/jenkins/build.sh +++ b/tools/jenkins/build.sh @@ -1,4 +1,4 @@ -#!/bin/sh +#!/usr/bin/env sh # This script is used by various build projects on Jenkins @@ -7,9 +7,22 @@ set -e -# Cleanup previous attempts -rm -rf /tmp/simgrid*tmp -rm -rf /tmp/surf-java*tmp +# ensure that the locales are set, so that perl keeps its nerves +export LC_ALL=C + +echo "XXXX Cleanup previous attempts. Remaining content of /tmp:" +rm -rf /tmp/simgrid-java* +rm -rf /tmp/jvm-* +find /builds/workspace/SimGrid-Multi/ -name "hs_err_pid*.log" | xargs rm -f +ls /tmp +df -h +echo "XXXX Let's go" + +# Help older cmakes +if [ -e /usr/lib/jvm/java-7-openjdk-amd64 ] ; +then + export JAVA_HOME=/usr/lib/jvm/java-7-openjdk-amd64 +fi # usage: die status message... die () { @@ -29,6 +42,13 @@ onoff() { fi } +# Check that we have what we need, or die quickly. +# The paths are not the same on all platforms, unfortunately. +#test -e /bin/tar || die 1 "I need tar to compile. Please fix your slave." +#test -e /bin/gzip || die 1 "I need gzip to compile. Please fix your slave." +#test -e /usr/include/libunwind.h || die 1 "I need libunwind to compile. Please fix your slave." +#test -e /usr/include/valgrind/valgrind.h || die 1 "I need valgrind to compile. Please fix your slave." + build_mode="$1" echo "Build mode $build_mode on $(uname -np)" >&2 case "$build_mode" in @@ -58,20 +78,24 @@ fi ulimit -c 0 || true -if test "$(uname -o)" != "Msys"; then - echo "XX" - echo "XX Get out of the tree" - echo "XX" - if [ -d $WORKSPACE/build ] - then - rm -rf $WORKSPACE/build - fi - mkdir $WORKSPACE/build - cd $WORKSPACE/build +echo "XX" +echo "XX Get out of the tree" +echo "XX" +if [ -d $WORKSPACE/build ] +then + # Windows cannot remove the directory if it's still used by the previous build + rm -rf $WORKSPACE/build || sleep 10 && rm -rf $WORKSPACE/build || sleep 10 && rm -rf $WORKSPACE/build +fi +mkdir $WORKSPACE/build +cd $WORKSPACE/build + +# This is for Windows: +PATH="$WORKSPACE/build/lib:$PATH" +if test "$(uname -o)" != "Msys"; then echo "XX" echo "XX Build the archive out of the tree" - echo "XX pwd: `pwd`" + echo "XX pwd: "$(pwd) echo "XX" cmake -G"$GENERATOR" -Denable_documentation=OFF $WORKSPACE @@ -80,63 +104,51 @@ if test "$(uname -o)" != "Msys"; then echo "XX" echo "XX Open the resulting archive" echo "XX" - tar xzf `cat VERSION`.tar.gz - cd `cat VERSION` + gunzip $(cat VERSION).tar.gz + tar xf $(cat VERSION).tar + cd $(cat VERSION) + mkdir build + cd build + SRCFOLDER=".." +else +#for windows we don't make dist, but we still want to build out of source + SRCFOLDER=$WORKSPACE fi echo "XX" echo "XX Configure and build SimGrid" -echo "XX pwd: `pwd`" +echo "XX pwd: "$(pwd) echo "XX" cmake -G"$GENERATOR"\ -Denable_debug=ON -Denable_documentation=OFF -Denable_coverage=OFF \ -Denable_model-checking=$(onoff test "$build_mode" = "ModelChecker") \ -Denable_smpi_ISP_testsuite=$(onoff test "$build_mode" = "ModelChecker") \ - -Denable_compile_optimizations=$(onoff test "$build_mode" = "Debug") \ + -Denable_compile_optimizations=$(onoff test "$build_mode" != "DynamicAnalysis") \ -Denable_smpi_MPICH3_testsuite=$(onoff test "$build_mode" != "DynamicAnalysis") \ - -Denable_lua=$(onoff test "$build_mode" != "DynamicAnalysis") \ -Denable_mallocators=$(onoff test "$build_mode" != "DynamicAnalysis") \ -Denable_memcheck=$(onoff test "$build_mode" = "DynamicAnalysis") \ - -Denable_compile_warnings=ON -Denable_smpi=ON -Denable_lib_static=OFF \ - -Denable_latency_bound_tracking=OFF -Denable_jedule=OFF \ - -Denable_tracing=ON -Denable_java=ON + -Denable_compile_warnings=$(onoff test "$GENERATOR" != "MSYS Makefiles") -Denable_smpi=ON \ + -Denable_jedule=OFF -Denable_java=ON -Denable_lua=OFF $SRCFOLDER +# -Denable_lua=$(onoff test "$build_mode" != "DynamicAnalysis") \ + make -j$NUMBER_OF_PROCESSORS VERBOSE=1 if test "$(uname -o)" != "Msys"; then cd $WORKSPACE/build - cd `cat VERSION` + cd $(cat VERSION)/build fi -TRES=0 - echo "XX" echo "XX Run the tests" -echo "XX pwd: `pwd`" +echo "XX pwd: "$(pwd) echo "XX" ctest -T test --output-on-failure --no-compress-output || true if [ -f Testing/TAG ] ; then - xsltproc $WORKSPACE/buildtools/jenkins/ctest2junit.xsl Testing/`head -n 1 < Testing/TAG`/Test.xml > CTestResults.xml + xsltproc $WORKSPACE/tools/jenkins/ctest2junit.xsl Testing/$( head -n 1 < Testing/TAG )/Test.xml > CTestResults.xml mv CTestResults.xml $WORKSPACE fi echo "XX" echo "XX Done. Return the results to cmake" echo "XX" - -if [ "$build_mode" = "DynamicAnalysis" ] -then - ctest -D ContinuousStart - ctest -D ContinuousConfigure - ctest -D ContinuousBuild - ctest -D ContinuousMemCheck - ctest -D ContinuousSubmit -fi - -ctest -D ContinuousStart -ctest -D ContinuousConfigure -ctest -D ContinuousBuild -ctest -D ContinuousTest -ctest -D ContinuousSubmit - -rm -rf `cat VERSION`