name: Build on: push: branches: - '**' - '!gh-pages' pull_request: types: [opened, synchronize, reopened] jobs: build: name: Build runs-on: ubuntu-latest steps: - name: Check for Sonar secret id: check-secret env: SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} run: | echo "::set-output name=is_SONAR_TOKEN_set::${{ env.SONAR_TOKEN != '' }}" - name: Checkout code uses: actions/checkout@v2 with: fetch-depth: ${{ !steps.check-secret.is_SONAR_TOKEN_set && 1 || 0 }} # Shallow clones should be disabled for a better relevancy of SonarCloud analysis - name: Set up JDK 17 uses: actions/setup-java@v1 with: java-version: 17 - name: Cache Gradle packages uses: actions/cache@v2 with: path: | ~/.gradle/caches key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle', 'gradle.properties', 'gradle/libs.versions.toml', 'gradle/wrapper/gradle-wrapper.properties') }} restore-keys: ${{ runner.os }}-gradle - name: Cache Sonar packages uses: actions/cache@v2 if: ${{ steps.check-secret.is_SONAR_TOKEN_set }} with: path: | ~/.sonar/cache key: ${{ runner.os }}-sonar restore-keys: ${{ runner.os }}-sonar - name: Cache node distribution uses: actions/cache@v2 with: path: | **/.node key: ${{ runner.os }}-node-${{ hashFiles('gradle.properties') }} restore-keys: ${{ runner.os }}-node - name: Cache yarn packages uses: actions/cache@v2 with: path: | **/.yarn/cache key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }} restore-keys: ${{ runner.os }}-yarn - name: Gradle build if: ${{ !steps.check-secret.is_SONAR_TOKEN_set }} run: | ./gradlew build -Pci --info - name: Gradle build and Sonar analyze if: ${{ steps.check-secret.is_SONAR_TOKEN_set }} env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # Needed by Sonar to get PR information, if any SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} run: | ./gradlew build sonarqube -Pci --info