Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
[project-description] Fix extraction of the ns-3 version.
[simgrid.git] / tools / jenkins / project_description.sh
index 529ed19..b002915 100755 (executable)
@@ -21,14 +21,12 @@ 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(){
-  grep -m 1 "ns-3 found (v3.[0-9]*; incl:" ./consoleText | sed "s/.*-- ns-3 found .v\(3.[0-9]*\); incl:.*/\1/g"
-#  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(){
@@ -54,8 +52,8 @@ wget --quiet ${BUILD_URL}/consoleText >/dev/null 2>&1
 nodes=($(sed -n 's/^Triggering SimGrid [^ ]* Debug,//p' ./consoleText| sort))
 rm consoleText
 
-
-echo "<br>Description of the nodes - Automatically updated by project_description.sh script - Don't edit here<br><br>
+cat <<EOF
+<br>Description of the nodes - Automatically updated by project_description.sh script - Don't edit here<br><br>
 <script>
 function compareVersion(v1, v2) {
     if (typeof v1 !== 'string') return false;
@@ -77,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) {
@@ -117,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.*/
@@ -127,9 +125,30 @@ function sortTable(n, type) {
       }
     }
   }
-}</script>
-<table id=configuration-matrix> 
-<tr class=matrix-row>  <td class=matrix-header style=min-width:75px onclick='sortTable(0);'>Name of the Builder</td><td class=matrix-header style=min-width:75px onclick='sortTable(1);'>OS</td><td class=matrix-header style=min-width:75px onclick='sortTable(2);'>Compiler</td><td class=matrix-header style=min-width:75px onclick=\"sortTable(3, 'version');\">Boost</td><td class=matrix-header style=min-width:75px onclick=\"sortTable(4,'version');\">Java</td><td class=matrix-header style=min-width:75px onclick=\"sortTable(5,'version');\">Cmake</td><td class=matrix-header style=min-width:50px onclick='sortTable(6);'>ns-3</td><td class=matrix-header style=min-width:50px onclick='sortTable(7);'>Python</td><td class=matrix-header style=min-width:50px onclick='sortTable(1);'>Debug</td><td class=matrix-header style=min-width:50px onclick='sortTable(1);'>MC</td></tr>"
+}
+</script>
+<table id=configuration-matrix>
+  <tr class=matrix-row>
+    <td class=matrix-header style=min-width:75px onclick='sortTable($((col=0)));'>Name of the Builder</td>
+    <td class=matrix-header style=min-width:75px onclick='sortTable($((++col)));'>OS</td>
+    <td class=matrix-header style=min-width:50px onclick='sortTable($((++col,0)));'>Debug</td>
+    <td class=matrix-header style=min-width:50px onclick='sortTable($((++col,0)));'>MC</td>
+    <td class=matrix-header style=min-width:75px onclick='sortTable($((++col)));'>Compiler</td>
+    <td class=matrix-header style=min-width:75px onclick="sortTable($((++col)),'version');">Boost</td>
+    <td class=matrix-header style=min-width:75px onclick="sortTable($((++col)),'version');">Java</td>
+    <td class=matrix-header style=min-width:75px onclick="sortTable($((++col)),'version');">Cmake</td>
+    <td class=matrix-header style=min-width:50px onclick="sortTable($((++col)),'version');">Eigen3</td>
+    <td class=matrix-header style=min-width:50px onclick="sortTable($((++col)),'version');">ns-3</td>
+    <td class=matrix-header style=min-width:50px onclick="sortTable($((++col)),'version');">Python</td>
+  </tr>
+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
@@ -145,20 +164,24 @@ 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")
-    
+
     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
+
     status=$(cat status)
     if [ "$status" == "Success" ]; then
       color1="&color=green"
     fi
     rm status
-    statusmc="<img src=https://ci.inria.fr/simgrid/images/24x24/grey.png>"
+    statusdebug="<a href=\"build_mode=Debug,node=${node}/\"><img src=\"https://ci.inria.fr/simgrid/job/SimGrid/build_mode=Debug,node=${node}/badge/icon?style=ball-24x24${color1}\"/>"
+
+    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
@@ -168,46 +191,26 @@ do
       statusmc="<a href=\"build_mode=ModelChecker,node=${node}/\"><img src=\"https://ci.inria.fr/simgrid/job/SimGrid/build_mode=ModelChecker,node=${node}/badge/icon?style=ball-24x24${color2}\"/>"
     fi
     rm status
-    echo "<tr> <td class=\"matrix-leftcolumn\">$node</td><td class=\"matrix-cell\" style=\"text-align:left\">$os</td><td class=\"matrix-cell\" style=\"text-align:left\">$compiler</td><td class=\"matrix-cell\" style=\"text-align:left\">$boost</td><td class=\"matrix-cell\" style=\"text-align:left\">$java</td><td class=\"matrix-cell\" style=\"text-align:left\">$cmake</td><td class=\"matrix-cell\" style=\"text-align:center\">$ns3</td><td class=\"matrix-cell\" style=\"text-align:center\">$py</td><td class=\"matrix-cell\" style=\"text-align:center\"><a href=\"build_mode=Debug,node=${node}/\"><img src=\"https://ci.inria.fr/simgrid/job/SimGrid/build_mode=Debug,node=${node}/badge/icon?style=ball-24x24${color1}\"/></td><td class=\"matrix-cell\" style=\"text-align:center\">${statusmc}</td></tr>"
-    rm consoleText
-done
-
 
-#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 3))
-OS=($(curl -s https://api.travis-ci.org/repos/simgrid/simgrid/builds/"${BUILD_NUM}" | grep -o '"os":"[a-z]*",' | sed  's/"os":"\([a-z]*\)",/\1/g'| tail -n 3))
-
-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 [ "${OS[$id]}" == "linux" ]; then
-      node="travis-linux (<a href=\"https://travis-ci.org/simgrid/simgrid/jobs/${BUILDS[$id]}\">log</a>)"
-      os="Ubuntu  <a href=\"https://docs.travis-ci.com/user/reference/bionic/\">18.04 bionic</a>"
-    elif [ "${OS[$id]}" == "osx" ]; then
-      node="travis-mac (<a href=\"https://travis-ci.org/simgrid/simgrid/jobs/${BUILDS[$id]}\">log</a>)"
-      os="Mac OS X <a href=\"https://docs.travis-ci.com/user/reference/osx/\">Catalina (10.15)</a> "
-    elif [ "${OS[$id]}" == "windows" ]; then
-      node="travis-windows (<a href=\"https://travis-ci.org/simgrid/simgrid/jobs/${BUILDS[$id]}\">log</a>)"
-      os="Windows <a href=\"https://docs.travis-ci.com/user/reference/windows/\">Server 1809</a>"
-    fi
-    boost=$(get_boost)
-    compiler=$(get_compiler)
-    java=$(get_java)
-    cmake=$(get_cmake)
-    ns3=$(get_ns3)
-    py=$(get_python)
-    success=$(grep -m 1 "Your build exited with 0" ./consoleText)
-    ball="red.png"
-    if [ -n "$success" ]; then
-      ball="blue.png"
-    fi
-    echo "<tr> <td class=\"matrix-leftcolumn\">$node</td><td class=\"matrix-cell\" style=\"text-align:left\">$os</td><td class=\"matrix-cell\" style=\"text-align:left\">$compiler</td><td class=\"matrix-cell\" style=\"text-align:left\">$boost</td><td class=\"matrix-cell\" style=\"text-align:left\">$java</td><td class=\"matrix-cell\" style=\"text-align:left\">$cmake</td><td class=\"matrix-cell\" style=\"text-align:center\">$ns3</td><td class=\"matrix-cell\" style=\"text-align:center\">$py</td><td class=\"matrix-cell\" style=\"text-align:center\"><img src=https://ci.inria.fr/simgrid/images/24x24/${ball}></td><td class=\"matrix-cell\" style=\"text-align:center\"><img src=https://ci.inria.fr/simgrid/images/24x24/grey.png></td></tr>"
+    cat <<EOF
+  <tr>
+    <td class="matrix-leftcolumn">$node</td>
+    <td class="matrix-cell" style="text-align:left">$os</td>
+    <td class="matrix-cell" style="text-align:center">${statusdebug}</td>
+    <td class="matrix-cell" style="text-align:center">${statusmc}</td>
+    <td class="matrix-cell" style="text-align:left">$compiler</td>
+    <td class="matrix-cell" style="text-align:left">$boost</td>
+    <td class="matrix-cell" style="text-align:left">$java</td>
+    <td class="matrix-cell" style="text-align:left">$cmake</td>
+    <td class="matrix-cell" style="text-align:center">$eigen3</td>
+    <td class="matrix-cell" style="text-align:left">$ns3</td>
+    <td class="matrix-cell" style="text-align:left">$py</td>
+  </tr>
+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
@@ -218,14 +221,29 @@ boost=$(get_boost)
 compiler=$(get_compiler)
 java=$(get_java)
 cmake=$(get_cmake)
+eigen3=$(get_eigen3)
 ns3=$(get_ns3)
 py=$(get_python)
 success=$(grep -m 1 "Build success" ./consoleText)
-ball="red.png"
+ball="${icons[failure]}"
 if [ -n "$success" ]; then
-  ball="blue.png"
+  ball="${icons[success]}"
 fi
-echo "<tr> <td class=\"matrix-leftcolumn\">$node</td><td class=\"matrix-cell\" style=\"text-align:left\">$os</td><td class=\"matrix-cell\" style=\"text-align:left\">$compiler</td><td class=\"matrix-cell\" style=\"text-align:left\">$boost</td><td class=\"matrix-cell\" style=\"text-align:left\">$java</td><td class=\"matrix-cell\" style=\"text-align:left\">$cmake</td><td class=\"matrix-cell\" style=\"text-align:center\">$ns3</td><td class=\"matrix-cell\" style=\"text-align:center\">$py</td><td class=\"matrix-cell\" style=\"text-align:center\"><img src=https://ci.inria.fr/simgrid/images/24x24/${ball}></td><td class=\"matrix-cell\" style=\"text-align:center\"><img src=https://ci.inria.fr/simgrid/images/24x24/grey.png></td></tr>"
+cat <<EOF
+  <tr>
+    <td class="matrix-leftcolumn">$node</td>
+    <td class="matrix-cell" style="text-align:left">$os</td>
+    <td class="matrix-cell" style="text-align:center"><${ball}></td>
+    <td class="matrix-cell" style="text-align:center"><${icons[disabled]}></td>
+    <td class="matrix-cell" style="text-align:left">$compiler</td>
+    <td class="matrix-cell" style="text-align:left">$boost</td>
+    <td class="matrix-cell" style="text-align:left">$java</td>
+    <td class="matrix-cell" style="text-align:left">$cmake</td>
+    <td class="matrix-cell" style="text-align:center">$eigen3</td>
+    <td class="matrix-cell" style="text-align:left">$ns3</td>
+    <td class="matrix-cell" style="text-align:left">$py</td>
+  </tr>
+EOF
 rm consoleText
 
 echo "</table>"