X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/314abba0374fcaab73ec8b6b25556474339c2928..196b543c8e909828b40e851eaf4443ee28f76c70:/tools/jenkins/project_description.sh diff --git a/tools/jenkins/project_description.sh b/tools/jenkins/project_description.sh index 04d327c18d..b002915e57 100755 --- a/tools/jenkins/project_description.sh +++ b/tools/jenkins/project_description.sh @@ -1,7 +1,12 @@ -#!/bin/bash +#!/usr/bin/env bash get_boost(){ - grep -m 1 "Boost version:" ./consoleText | sed "s/.*-- Boost version: \([a-zA-Z0-9\.]*\)/\1/g" + BOOST=$(grep -m 1 "Boost version:" ./consoleText | sed "s/.*-- Boost version: \([a-zA-Z0-9\.]*\)/\1/g") + if [ -z "$BOOST" ] + then + BOOST=$(grep -m 1 "Found Boost:" ./consoleText | sed "s/.*-- Found Boost:.*found suitable version \"\([a-zA-Z0-9\.]*\)\",.*/\1/g") + fi + echo "$BOOST" } get_compiler(){ @@ -16,19 +21,18 @@ get_cmake(){ grep -m 1 "Cmake version" ./consoleText| sed "s/.*-- Cmake version \([a-zA-Z0-9\.]*\)/\1/g" } +get_eigen3(){ + sed -n 's/.* Eigen3 library \.\+: \([^ ]*\) in .*/\1/p;T;q' ./consoleText +} + get_ns3(){ - found=$(grep -c "NS-3 found" ./consoleText) - if [ $found != 0 ]; then - echo "✔" - else - echo "" - fi + sed -n 's/.*-- ns-3 found (v\(3[-.0-9a-z]\+\); minor:.*/\1/p;T;q' ./consoleText } get_python(){ found=$(grep -c "Compile Python bindings .....: ON" ./consoleText) - if [ $found != 0 ]; then - echo "✔" + if [ "$found" != 0 ]; then + grep -m 1 "Found Python3" ./consoleText| sed "s/.*-- Found Python3.*found version \"\([a-zA-Z0-9\.]*\)\".*/\1/g" else echo "" fi @@ -39,17 +43,17 @@ if [ -f consoleText ]; then fi -if [ -z $BUILD_URL ]; then +if [ -z "$BUILD_URL" ]; then BUILD_URL="https://ci.inria.fr/simgrid/job/SimGrid/lastBuild" fi #get the list of nodes on jenkins wget --quiet ${BUILD_URL}/consoleText >/dev/null 2>&1 -nodes=($(grep -rR "Triggering SimGrid ? Debug," ./consoleText | sed "s/Triggering SimGrid ? Debug,\(.*\)/\1/g"| sort)) +nodes=($(sed -n 's/^Triggering SimGrid [^ ]* Debug,//p' ./consoleText| sort)) rm consoleText - -echo "
Description of the nodes - Automatically updated by project_description.sh script - Don't edit here

+cat <Description of the nodes - Automatically updated by project_description.sh script - Don't edit here

@@ -71,7 +75,7 @@ function sortTable(n, type) { table = document.getElementById('configuration-matrix'); switching = true; //Set the sorting direction to ascending: - dir = 'asc'; + dir = 'asc'; /*Make a loop that will continue until no switching has been done:*/ while (switching) { @@ -111,7 +115,7 @@ function sortTable(n, type) { rows[i].parentNode.insertBefore(rows[i + 1], rows[i]); switching = true; //Each time a switch is done, increase this count by 1: - switchcount ++; + switchcount ++; } else { /*If no switching has been done AND the direction is 'asc', set the direction to 'desc' and run the while loop again.*/ @@ -121,13 +125,37 @@ function sortTable(n, type) { } } } -} - -" +} + +
Name of the BuilderOSCompilerBoostJavaCmakeNS3Python
+ + + + + + + + + + + + + +EOF + +declare -A icons +icons=( + [success]="img src=https://ci.inria.fr/simgrid/images/24x24/blue.png" + [failure]="img src=https://ci.inria.fr/simgrid/images/24x24/red.png" + [disabled]="img src=https://ci.inria.fr/simgrid/images/24x24/disabled.png" +) for node in "${nodes[@]}" do - wget --quiet ${BUILD_URL}/build_mode=Debug,node=${node}/consoleText >/dev/null 2>&1 + wget --quiet --output-document=consoleText \ + ${BUILD_URL}/build_mode=Debug,node=${node}/consoleText \ + ${BUILD_URL}/build_mode=ModelChecker,node=${node}/consoleText \ + >/dev/null 2>&1 if [ ! -f consoleText ]; then echo "file not existing for node ${node}" exit 1 @@ -136,52 +164,86 @@ do compiler=$(get_compiler) java=$(get_java) cmake=$(get_cmake) + eigen3=$(get_eigen3) ns3=$(get_ns3) py=$(get_python) os=$(grep -m 1 "OS Version" ./consoleText| sed "s/OS Version : \(.*\)/\1/g") - echo "" - rm consoleText -done + color1="" + color2="" + #in case of success, replace blue by green in status balls + wget --quiet https://ci.inria.fr/simgrid/buildStatus/text?job=SimGrid%2Fbuild_mode%3DDebug%2Cnode%3D"${node}" -O status >/dev/null 2>&1 -#Travis - get ID of the last jobs with the API -BUILD_NUM=$(curl -s 'https://api.travis-ci.org/repos/simgrid/simgrid/builds?limit=1' | grep -o '^\[{"id":[0-9]*,' | grep -o '[0-9]' | tr -d '\n') -BUILDS=($(curl -s https://api.travis-ci.org/repos/simgrid/simgrid/builds/${BUILD_NUM} | grep -o '{"id":[0-9]*,' | grep -o '[0-9]*'| tail -n 2)) - -for id in "${!BUILDS[@]}" -do - wget --quiet https://api.travis-ci.org/v3/job/${BUILDS[$id]}/log.txt -O ./consoleText >/dev/null 2>&1 - sed -i -e "s/\r//g" ./consoleText - if [ $id == 0 ]; then - node="travis-linux" - os="Ubuntu 16.04 (Xenial) 64 bits" - else - node="travis-mac" - os="Mac OSX High Sierra (kernel: 17.4.0)" + status=$(cat status) + if [ "$status" == "Success" ]; then + color1="&color=green" fi - boost=$(get_boost) - compiler=$(get_compiler) - java=$(get_java) - cmake=$(get_cmake) - ns3=$(get_ns3) - py=$(get_python) - echo "" + rm status + statusdebug="" + + statusmc="<${icons[disabled]}>" + wget --quiet https://ci.inria.fr/simgrid/buildStatus/text?job=SimGrid%2Fbuild_mode%3DModelChecker%2Cnode%3D"${node}" -O status >/dev/null 2>&1 + status=$(cat status) + if [ "$status" ]; then + if [ "$status" == "Success" ]; then + color2="&color=green" + fi + statusmc="" + fi + rm status + + cat < + + + + + + + + + + + + +EOF rm consoleText done + #Appveyor - get ID of the last job with the API BUILD_ID=$(curl -s "https://ci.appveyor.com/api/projects/mquinson/simgrid" | grep -o '\[{"jobId":"[a-zA-Z0-9]*",' | sed "s/\[{\"jobId\":\"//" | sed "s/\",//") -wget --quiet https://ci.appveyor.com/api/buildjobs/$BUILD_ID/log -O ./consoleText >/dev/null 2>&1 +wget --quiet https://ci.appveyor.com/api/buildjobs/"$BUILD_ID"/log -O ./consoleText >/dev/null 2>&1 sed -i -e "s/\r//g" ./consoleText -node="appveyor" +node="appveyor" os="Windows Server 2012 - VS2015 + mingw64 5.3.0" boost=$(get_boost) compiler=$(get_compiler) java=$(get_java) cmake=$(get_cmake) +eigen3=$(get_eigen3) ns3=$(get_ns3) py=$(get_python) -echo "" +success=$(grep -m 1 "Build success" ./consoleText) +ball="${icons[failure]}" +if [ -n "$success" ]; then + ball="${icons[success]}" +fi +cat < + + + + + + + + + + + + +EOF rm consoleText echo "
Name of the BuilderOSDebugMCCompilerBoostJavaCmakeEigen3ns-3Python
$node$os$compiler$boost$java$cmake$ns3$py
$node$os$compiler$boost$java$cmake$ns3$py
$node$os${statusdebug}${statusmc}$compiler$boost$java$cmake$eigen3$ns3$py
$node$os$compiler$boost$java$cmake$ns3$py
$node$os<${ball}><${icons[disabled]}>$compiler$boost$java$cmake$eigen3$ns3$py
"