aboutsummaryrefslogtreecommitdiffstats
path: root/travis.sh
blob: 6e7cbdca7fb6999dfb11bbb82bc507c78d144f24 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
#!/usr/bin/env bash
set -euo pipefail

./.travis/setup_ramdisk.sh

#
# Configure Maven settings and install some script utilities
#
configureTravis() {
  mkdir -p ~/.local
  curl -sSL https://github.com/SonarSource/travis-utils/tarball/v55 | tar zx --strip-components 1 -C ~/.local
  source ~/.local/bin/install
}
configureTravis

#
# Travis fails on timeout when build does not print logs
# during 10 minutes. This aims to bypass this
# behavior when building the slow sonar-server sub-project.
#
keep_alive() {
  while true; do
    echo -en "\a"
    sleep 60
  done
}
keep_alive &

# When a pull request is open on the branch, then the job related
# to the branch does not need to be executed and should be canceled.
# It does not book slaves for nothing.
# @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
./gradlew build --no-daemon --console plain

# the '-' at the end is needed when using set -u (the 'nounset' flag)
# see https://stackoverflow.com/a/9824943/641955
if [[ -n "${NEXT_TOKEN-}" ]]; then
  if [[ "${TRAVIS_BRANCH}" == "master" ]]; then 
    ./gradlew jacocoTestReport :server:sonar-web:yarn_validate-ci sonarqube --info --no-daemon --console plain \
      -Dsonar.projectKey=org.sonarsource.sonarqube:sonarqube \
      -Dsonar.host.url=https://next.sonarqube.com/sonarqube \
      -Dsonar.login="$NEXT_TOKEN"
  else
    ./gradlew jacocoTestReport :server:sonar-web:yarn_validate-ci sonarqube --info --no-daemon --console plain \
      -Dsonar.projectKey=org.sonarsource.sonarqube:sonarqube \
      -Dsonar.host.url=https://next.sonarqube.com/sonarqube \
      -Dsonar.login="$NEXT_TOKEN" \
      -Dsonar.branch.name="$TRAVIS_BRANCH"
  fi
  
  # Wait for 5mins, hopefully the report will be processed.
  sleep 5m
  ./.travis/run_iris.sh
fi