-#!/bin/sh
+#!/usr/bin/env sh
# This script is used by various build projects on Jenkins
echo "XXXX Cleanup previous attempts. Remaining content of /tmp:"
rm -rf /tmp/simgrid-java*
-rm -rf /tmp/jvm-*
+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 ] ;
+if [ -e /usr/lib/jvm/java-7-openjdk-amd64 ] ;
then
export JAVA_HOME=/usr/lib/jvm/java-7-openjdk-amd64
fi
#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."
+#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
;;
esac
-if test "$(uname -o)" = "Msys"; then
- if [ -z "$NUMBER_OF_PROCESSORS" ]; then
- NUMBER_OF_PROCESSORS=1
- fi
- GENERATOR="MSYS Makefiles"
-else
- NUMBER_OF_PROCESSORS="$(nproc)" || NUMBER_OF_PROCESSORS=1
- GENERATOR="Unix Makefiles"
-fi
+NUMBER_OF_PROCESSORS="$(nproc)" || NUMBER_OF_PROCESSORS=1
+GENERATOR="Unix Makefiles"
ulimit -c 0 || true
echo "XX"
if [ -d $WORKSPACE/build ]
then
- rm -rf $WORKSPACE/build
+ # 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
-if test "$(uname -o)" != "Msys"; then
- echo "XX"
- echo "XX Build the archive out of the tree"
- echo "XX pwd: `pwd`"
- echo "XX"
+have_NS3="no"
+if dpkg -l libns3-dev 2>&1|grep -q "ii libns3-dev" ; then
+ have_NS3="yes"
+fi
+echo "XX have_NS3: ${have_NS3}"
- cmake -G"$GENERATOR" -Denable_documentation=OFF $WORKSPACE
- make dist -j$NUMBER_OF_PROCESSORS
+# This is for Windows:
+PATH="$WORKSPACE/build/lib:$PATH"
- echo "XX"
- echo "XX Open the resulting archive"
- echo "XX"
- tar xzf `cat VERSION`.tar.gz
- 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 Build the archive out of the tree"
+echo "XX pwd: "$(pwd)
+echo "XX"
+
+cmake -G"$GENERATOR" -Denable_documentation=OFF $WORKSPACE
+make dist -j$NUMBER_OF_PROCESSORS
+
+echo "XX"
+echo "XX Open the resulting archive"
+echo "XX"
+gunzip $(cat VERSION).tar.gz
+tar xf $(cat VERSION).tar
+cd $(cat VERSION)
+mkdir build
+cd build
+SRCFOLDER=".."
echo "XX"
echo "XX Configure and build SimGrid"
-echo "XX pwd: `pwd`"
+echo "XX pwd: "$(pwd)
echo "XX"
-cmake -G"$GENERATOR"\
+set -x
+if [ "$build_mode" = "ModelChecker" ] ; then
+ INSTALL="-DCMAKE_INSTALL_PREFIX=/builds/mc_simgrid_install"
+elif [ "$build_mode" = "Debug" ] ; then
+ INSTALL="-DCMAKE_INSTALL_PREFIX=/builds/simgrid_install"
+fi
+cmake -G"$GENERATOR" $INSTALL \
-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_smpi_MPICH3_testsuite=$(onoff test "$build_mode" != "DynamicAnalysis") \
+ -Denable_compile_optimizations=$(onoff test "$build_mode" != "DynamicAnalysis") \
+ -Denable_smpi_MPICH3_testsuite=$(onoff test "$build_mode" = "Debug") \
-Denable_mallocators=$(onoff test "$build_mode" != "DynamicAnalysis") \
-Denable_memcheck=$(onoff test "$build_mode" = "DynamicAnalysis") \
-Denable_compile_warnings=$(onoff test "$GENERATOR" != "MSYS Makefiles") -Denable_smpi=ON \
- -Denable_jedule=OFF -Denable_java=ON -Denable_lua=OFF $SRCFOLDER
+ -Denable_ns3=$(onoff test "$have_NS3" = "yes" -a "$build_mode" = "Debug") \
+ -Denable_jedule=OFF -Denable_java=ON -Denable_lua=OFF -DCMAKE_DISABLE_SOURCE_CHANGES=ON \
+ $SRCFOLDER
# -Denable_lua=$(onoff test "$build_mode" != "DynamicAnalysis") \
+set +x
make -j$NUMBER_OF_PROCESSORS VERBOSE=1
-if test "$(uname -o)" != "Msys"; then
- cd $WORKSPACE/build
- cd `cat VERSION`/build
-fi
-
-TRES=0
+cd $WORKSPACE/build/$(cat VERSION)/build
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/tools/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
+if test "$(uname)" != "Msys" && test "${build_mode}" = "Debug" -o "${build_mode}" = "ModelChecker" ; then
+ echo "XX"
+ echo "XX Test done. Install everything since it's a regular build, not on a Windows."
+ echo "XX"
+
+ test "${build_mode}" = "Debug" && rm -rf /builds/simgrid_install
+ test "${build_mode}" = "ModelChecker" && rm -rf /builds/mc_simgrid_install
+
+ make install
+fi
+
echo "XX"
echo "XX Done. Return the results to cmake"
echo "XX"