diff options
author | Julien Carsique <julien.carsique@sonarsource.com> | 2022-03-17 14:19:07 +0100 |
---|---|---|
committer | sonartech <sonartech@sonarsource.com> | 2022-03-17 20:03:09 +0000 |
commit | d40f44a82c98a1339d3a104c681073b88a5661cd (patch) | |
tree | fe95d592363fe40a9e17b62ee745df86c6adcbde /travis.sh | |
parent | c34fc36ca36273f0b920b7e75a1264cc6261027c (diff) | |
download | sonarqube-d40f44a82c98a1339d3a104c681073b88a5661cd.tar.gz sonarqube-d40f44a82c98a1339d3a104c681073b88a5661cd.zip |
BUILD-1414 Push QAGate and build statuses to Burgr for SonarQube built on Travis (#5593)
* BUILD-1414 push QAGate status
* BUILD-1414 push build status
* chore: update travis-utils to v61
Diffstat (limited to 'travis.sh')
-rwxr-xr-x | travis.sh | 82 |
1 files changed, 68 insertions, 14 deletions
diff --git a/travis.sh b/travis.sh index 753d656180f..d1ca74e576a 100755 --- a/travis.sh +++ b/travis.sh @@ -8,7 +8,8 @@ set -euo pipefail # configureTravis() { mkdir -p ~/.local - curl -sSL https://github.com/SonarSource/travis-utils/tarball/v55 | tar zx --strip-components 1 -C ~/.local + curl -sSL https://github.com/SonarSource/travis-utils/tarball/v61 | tar zx --strip-components 1 -C ~/.local + # shellcheck disable=SC1090 source ~/.local/bin/install } configureTravis @@ -32,26 +33,79 @@ keep_alive & # @TravisCI please provide the feature natively, like at AppVeyor or CircleCI ;-) cancel_branch_build_with_pr || if [[ $? -eq 1 ]]; then exit 0; fi -git fetch --unshallow +# Used by Next +INITIAL_VERSION=$(grep version gradle.properties | awk -F= '{print $2}') +export INITIAL_VERSION + +# use generic environments to remove coupling with Travis ; see setup_promote_environment +export GITHUB_REPO=${TRAVIS_REPO_SLUG} +export BUILD_NUMBER=$TRAVIS_BUILD_NUMBER +export PIPELINE_ID=${BUILD_NUMBER} +if [ "$TRAVIS_PULL_REQUEST" == "false" ]; then + export GIT_SHA1=${TRAVIS_COMMIT} # $CIRRUS_CHANGE_IN_REPO + export GIT_BRANCH=$TRAVIS_BRANCH + export STAGE_TYPE="branch" + export STAGE_ID=${GIT_BRANCH} +else + export GIT_SHA1=${TRAVIS_PULL_REQUEST_SHA} + export GIT_BRANCH=$TRAVIS_PULL_REQUEST_BRANCH + export PULL_REQUEST_BASE_BRANCH=$TRAVIS_BRANCH + export PULL_REQUEST_NUMBER=$TRAVIS_PULL_REQUEST + export STAGE_TYPE="pr_number" + export STAGE_ID=${PULL_REQUEST_NUMBER} +fi +echo "======= SHA1 is ${GIT_SHA1} on branch '${GIT_BRANCH}'. Burgr stage '${STAGE_TYPE} with stage ID '${STAGE_ID} =======" + +# Analyse SonarQube on NEXT +export SONAR_HOST_URL=https://next.sonarqube.com/sonarqube + +# Fetch all commit history so that SonarQube has exact blame information +# for issue auto-assignment +# This command can fail with "fatal: --unshallow on a complete repository does not make sense" +# if there are not enough commits in the Git repository (even if Travis executed git clone --depth 50). +# For this reason errors are ignored with "|| true" +git fetch --unshallow || true + +BUILD_START_DATETIME=$(date --utc +%FT%TZ) ./gradlew build --no-daemon --console plain +BUILD_END_DATETIME=$(date --utc +%FT%TZ) -# the '-' at the end is needed when using set -u (the 'nounset' flag) -# see https://stackoverflow.com/a/9824943/641955 +# exclude external pull requests if [[ -n "${NEXT_TOKEN-}" ]]; then - if [[ "${TRAVIS_BRANCH}" == "master" ]]; then + notify_burgr "build" "build" "$TRAVIS_JOB_WEB_URL" "$BUILD_START_DATETIME" "$BUILD_END_DATETIME" + + sonar_params=(-Dsonar.projectKey=sonarqube + -Dsonar.host.url="$SONAR_HOST_URL" + -Dsonar.login="$NEXT_TOKEN" + -Dsonar.analysis.buildNumber="$BUILD_NUMBER" + -Dsonar.analysis.pipeline="$BUILD_NUMBER" + -Dsonar.analysis.sha1="$GIT_SHA1" + -Dsonar.analysis.repository="$TRAVIS_REPO_SLUG") + + if [ "$TRAVIS_PULL_REQUEST" != "false" ]; then + echo '======= Analyze pull request' ./gradlew jacocoTestReport :server:sonar-web:yarn_validate-ci sonarqube --info --no-daemon --console plain \ - -Dsonar.projectKey=sonarqube \ - -Dsonar.host.url=https://next.sonarqube.com/sonarqube \ - -Dsonar.login="$NEXT_TOKEN" + "${sonar_params[@]}" \ + -Dsonar.analysis.prNumber="$PULL_REQUEST_NUMBER" \ + -Dsonar.pullrequest.branch="$GIT_BRANCH" \ + -Dsonar.pullrequest.base="$PULL_REQUEST_BASE_BRANCH" \ + -Dsonar.pullrequest.key="$PULL_REQUEST_NUMBER" \ + -Dsonar.pullrequest.provider=github \ + -Dsonar.pullrequest.github.repository="$TRAVIS_REPO_SLUG" + elif [ "${TRAVIS_BRANCH}" == "master" ]; then + echo '======= Analyze master' + ./gradlew jacocoTestReport :server:sonar-web:yarn_validate-ci sonarqube --info --no-daemon --console plain \ + "${sonar_params[@]}" \ + -Dsonar.projectVersion="$INITIAL_VERSION" else + echo '======= Analyze branch' ./gradlew jacocoTestReport :server:sonar-web:yarn_validate-ci sonarqube --info --no-daemon --console plain \ - -Dsonar.projectKey=sonarqube \ - -Dsonar.host.url=https://next.sonarqube.com/sonarqube \ - -Dsonar.login="$NEXT_TOKEN" \ - -Dsonar.branch.name="$TRAVIS_BRANCH" + "${sonar_params[@]}" \ + -Dsonar.branch.name="$GIT_BRANCH" \ + -Dsonar.projectVersion="$INITIAL_VERSION" fi - + # Wait for 5mins, hopefully the report will be processed. sleep 5m ./.travis/run_iris.sh -fi
\ No newline at end of file +fi |