Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
try to make our travis-sonarqube.sh useful to others too
authorMartin Quinson <martin.quinson@loria.fr>
Sat, 28 May 2016 20:07:24 +0000 (22:07 +0200)
committerMartin Quinson <martin.quinson@loria.fr>
Sat, 28 May 2016 20:07:24 +0000 (22:07 +0200)
.travis.yml
tools/internal/travis-sonarqube.sh

index 80042df..1db3d7b 100644 (file)
@@ -49,7 +49,7 @@ before_install:
    - if [ ${TRAVIS_OS_NAME} = 'linux' ] ; then sudo update-alternatives --install /usr/bin/g++ g++ /usr/bin/g++-4.7 50 ; fi
 script:
    - cmake -Denable_documentation=OFF -Denable_coverage=OFF -Denable_java=ON -Denable_model-checking=OFF -Denable_lua=OFF -Denable_compile_optimizations=OFF -Denable_smpi=ON -Denable_smpi_MPICH3_testsuite=OFF -Denable_compile_warnings=ON . 
-   - if [ ${TRAVIS_OS_NAME} = 'linux' ] ; then ./tools/internal/travis-sonarqube.sh ; else make VERBOSE=1 ; fi # run make in the sonar wrapper
+   - ./tools/internal/travis-sonarqube.sh make VERBOSE=1 # run make in the sonar wrapper
    - ctest --output-on-failure --timeout 100
 notifications:
   recipients:
index fcb2682..d85b171 100755 (executable)
@@ -1,7 +1,18 @@
 #! /bin/sh
 
-# Run SonarQube on travis. First version was given per email by one of the SonarQube engineer.
+# Install and run SonarQube on travis. 
+#
+# Use it as a wrapper to your build command, eg: ./travis-sonarqube.sh make VERBOSE=1
 
+# On Mac OSX, you don't want to run SonarQube but to exec the build command directly.
+if [ ${TRAVIS_OS_NAME} != 'linux' ] 
+then
+  exec "$@"
+fi
+# Passed this point, we are on Linux (exec never returns)
+
+
+# Be verbose and fail fast
 set -ex
 
 # Install required software
@@ -23,9 +34,7 @@ installSonarQubeScanner
 installBuildWrapper
 
 # triggers the compilation through the build wrapper to gather compilation database
-# We need to clean the build that was used for the tests before to ensure that everything gets rebuilt (sonarqube only use what's built throught its wrappers)
-# Plus, we need to activate MC so that it does not get throught the quality net :)
-./build-wrapper-linux-x86/build-wrapper-linux-x86-64 --out-dir bw-outputs make VERBOSE=1
+./build-wrapper-linux-x86/build-wrapper-linux-x86-64 --out-dir bw-outputs "$@"
 
 # and finally execute the actual SonarQube analysis (the SONAR_TOKEN is set from the travis web interface, to not expose it)
 sonar-scanner -Dsonar.host.url=https://nemo.sonarqube.org -Dsonar.login=$SONAR_TOKEN