aboutsummaryrefslogtreecommitdiffstats
path: root/travis.sh
diff options
context:
space:
mode:
authorJulien Carsique <julien.carsique@sonarsource.com>2022-03-17 14:19:07 +0100
committersonartech <sonartech@sonarsource.com>2022-03-17 20:03:09 +0000
commitd40f44a82c98a1339d3a104c681073b88a5661cd (patch)
treefe95d592363fe40a9e17b62ee745df86c6adcbde /travis.sh
parentc34fc36ca36273f0b920b7e75a1264cc6261027c (diff)
downloadsonarqube-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-xtravis.sh82
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