DOPS-3309: Add sonar & defectdojo analysis #702
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Iroha2-java pull requests workflow | |
on: | |
pull_request: | |
branches: [ iroha2-dev, iroha2-main ] | |
jobs: | |
build: | |
runs-on: self-hosted | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Set up JDK 17 | |
uses: actions/setup-java@v3 | |
with: | |
java-version: '17' | |
distribution: 'liberica' | |
- name: Cache Gradle packages | |
uses: actions/cache@v3 | |
with: | |
path: | | |
~/.gradle/caches | |
~/.gradle/wrapper | |
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }} | |
restore-keys: | | |
${{ runner.os }}-gradle- | |
- name: Build with Gradle & Sonarqube analysis | |
run: ./gradlew build testCoverage sonar -Dsonar.token=${{ secrets.SONAR_TOKEN }} --info | |
- name: DefectDojo | |
if: always() | |
uses: C4tWithShell/defectdojo-action@1.0.4 | |
with: | |
token: ${{ secrets.DEFECTOJO_TOKEN }} | |
defectdojo_url: ${{ secrets.DEFECTOJO_URL }} | |
product_type: iroha2 | |
engagement: ${{ github.ref_name }} | |
tools: "SonarQube API Import,Github Vulnerability Scan" | |
sonar_projectKey: hyperledger:iroha-java | |
github_token: ${{ secrets.GITHUB_TOKEN }} | |
github_repository: ${{ github.repository }} | |
product: ${{ github.repository }} | |
environment: Test | |
reports: '{"Github Vulnerability Scan": "github.json"}' | |
- name: Upload build reports | |
if: failure() | |
uses: actions/upload-artifact@v3 | |
with: | |
name: build-reports | |
path: /home/runner/work/iroha-java/iroha-java/**/index.html | |
- name: Cleanup Gradle Cache | |
# Remove some files from the Gradle cache, so they aren't cached by GitHub Actions. | |
# Restoring these files from a GitHub Actions cache might cause problems for future builds. | |
run: | | |
rm -f ~/.gradle/caches/modules-2/modules-2.lock | |
rm -f ~/.gradle/caches/modules-2/gc.properties |