X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/d7bc120608a7dff0e936300bc7fc0367ee26b16d..1d2e87217b087ee4a4566f6eeab19df9713ea4bb:/tools/internal/travis-sonarqube.sh diff --git a/tools/internal/travis-sonarqube.sh b/tools/internal/travis-sonarqube.sh index 3bdf700de6..908ed6e05e 100755 --- a/tools/internal/travis-sonarqube.sh +++ b/tools/internal/travis-sonarqube.sh @@ -1,6 +1,19 @@ #! /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 or with pull requests, you don't want to run SonarQube but to exec the build command directly. +if [ ${TRAVIS_OS_NAME} != 'linux' ] || [ ${TRAVIS_PULL_REQUEST} != 'false' ] +then + exec "$@" +fi +# Passed this point, we are on Linux and not in a PR (exec never returns) + + +# Be verbose and fail fast +set -ex # Install required software installSonarQubeScanner() { @@ -21,11 +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 :) -make clean -cmake -Denable_documentation=OFF -Denable_coverage=OFF -Denable_java=ON -Denable_model-checking=ON -Denable_lua=OFF -Denable_compile_optimizations=OFF -Denable_smpi=ON -Denable_smpi_MPICH3_testsuite=OFF . -./build-wrapper-linux-x86/build-wrapper-linux-x86-64 --out-dir bw-outputs make all +./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