X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/9df50f62d16906ea5863e6de9516958bbcc3791a..1e2cc382d6eefdc91a296d134403263f63ccff65:/tools/jenkins/Flags.sh diff --git a/tools/jenkins/Flags.sh b/tools/jenkins/Flags.sh index b5acd374c5..ea84301b4f 100755 --- a/tools/jenkins/Flags.sh +++ b/tools/jenkins/Flags.sh @@ -1,56 +1,96 @@ -#!/bin/sh +#!/usr/bin/env sh set -e +echo "Starting Flags.sh $*" + die() { echo "$@" exit 1 } +# Get an ON/OFF string from a command: +onoff() { + if "$@" > /dev/null ; then + echo ON + else + echo OFF + fi +} + +[ $# -eq 3 ] || die "Needs 3 arguments : MC SMPI DEBUG" + +### Cleanup previous runs + +[ -n "$WORKSPACE" ] || die "No WORKSPACE" +[ -d "$WORKSPACE" ] || die "WORKSPACE ($WORKSPACE) does not exist" + do_cleanup() { - for d in "$WORKSPACE/build" + for d do if [ -d "$d" ] then - rm -rf "$d" || die "Could not remote $d" + rm -rf "$d" || die "Could not remove $d" fi + mkdir "$d" || die "Could not create $d" done } -### Cleanup previous runs +do_cleanup "$WORKSPACE/build" -! [ -z "$WORKSPACE" ] || die "No WORKSPACE" -[ -d "$WORKSPACE" ] || die "WORKSPACE ($WORKSPACE) does not exist" +NUMPROC="$(nproc)" || NUMPROC=1 -do_cleanup +cd "$WORKSPACE"/build -for d in "$WORKSPACE/build" -do - mkdir "$d" || die "Could not create $d" -done +#we can't just receive ON or OFF as values as display is bad in the resulting jenkins matrix -NUMPROC="$(nproc)" || NUMPROC=1 +if [ "$1" = "MC" ] +then + buildmc="ON" +else + buildmc="OFF" +fi -cd $WORKSPACE/build +if [ "$2" = "SMPI" ] +then + buildsmpi="ON" +else + buildsmpi="OFF" +fi -for buildjava in ON OFF -do - for builddebug in ON OFF - do - for buildsmpi in ON OFF - do - for buildmc in ON OFF - do - echo "build with java=${buildjava}, debug=${builddebug}, SMPI=${buildsmpi}, MC=${buildmc}" - cmake -Denable_documentation=OFF -Denable_lua=ON -Denable_java=${buildjava} \ - -Denable_compile_optimizations=OFF -Denable_compile_warnings=ON \ - -Denable_jedule=ON -Denable_mallocators=ON -Denable_debug=${builddebug} \ - -Denable_smpi=${buildsmpi} -Denable_smpi_MPICH3_testsuite=${buildsmpi} -Denable_model-checking=${buildmc} \ - -Denable_memcheck=OFF -Denable_memcheck_xml=OFF -Denable_smpi_ISP_testsuite=OFF -Denable_coverage=OFF $WORKSPACE - make -j$NUMPROC - make clean - done - done - done -done +if [ "$3" = "DEBUG" ] +then + builddebug="ON" +else + builddebug="OFF" +fi + +echo "Step ${STEP}/${NSTEPS} - Building with debug=${builddebug}, SMPI=${buildsmpi}, MC=${buildmc}" + +if [ "${builddebug}/${buildsmpi}/${buildmc}" = "ON/ON/ON" ]; then + # ${buildmc}=ON because "why not", and especially because it doesn't + # compile with -D_GLIBCXX_DEBUG and -Denable_ns3=ON together + export CXXFLAGS=-D_GLIBCXX_DEBUG + runtests="ON" +else + runtests="OFF" +fi + +cmake -Denable_documentation=OFF \ + -Denable_compile_optimizations=OFF -Denable_compile_warnings=ON \ + -Denable_mallocators=ON -Denable_debug=${builddebug} \ + -Denable_smpi=${buildsmpi} -Denable_smpi_MPICH3_testsuite=${buildsmpi} -Denable_model-checking=${buildmc} \ + -Denable_memcheck=OFF -Denable_memcheck_xml=OFF -Denable_smpi_MBI_testsuite=OFF \ + -Denable_ns3=$(onoff test "$buildmc" != "ON") -DNS3_HINT=/builds/ns-3-dev/build/ \ + -Denable_coverage=OFF -DLTO_EXTRA_FLAG="auto" -DCMAKE_CXX_COMPILER_LAUNCHER=ccache \ + "$WORKSPACE" + +make -j$NUMPROC tests + +if [ "$runtests" = "ON" ]; then + # exclude tests known to fail with _GLIBCXX_DEBUG + ctest -j$NUMPROC -E '^[ps]thread-|mc-bugged1-liveness' +fi +cd .. +rm -rf build