Skip to content

Java CI with Maven

Java CI with Maven #66

Workflow file for this run

# This workflow will build a Java project with Maven, and cache/restore any dependencies to improve the workflow execution time
# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-java-with-maven
# This workflow uses actions that are not certified by GitHub.
# They are provided by a third-party and are governed by
# separate terms of service, privacy policy, and support
# documentation.
name: Java CI with Maven
on:
push:
branches: [ "master", "feature/*" ]
pull_request:
branches: [ "master" ]
workflow_dispatch:
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0 # Shallow clones should be disabled for a better relevancy of analysis
- name: Set up JDK 17
uses: actions/setup-java@v4
with:
java-version: '17'
distribution: 'temurin'
cache: maven
- name: Build with Maven
run: mvn -B package --file pom.xml
# Below we need to temporarily disable
- name: Generate the Jacoco report
run: mvn jacoco:report
- name: Generate JaCoCo Badge
id: jacoco
uses: cicirello/jacoco-badge-generator@v2.11.0
- name: Log coverage percentage
run: |
echo "coverage = ${{ steps.jacoco.outputs.coverage }}"
echo "branch coverage = ${{ steps.jacoco.outputs.branches }}"
- name: Upload JaCoCo coverage report
uses: actions/upload-artifact@v4
with:
name: jacoco-report
path: target/site/jacoco/
- name: Upload test results
uses: actions/upload-artifact@v4
with:
name: test-results
path: target/surefire-reports
- name: Publish test report
uses: dorny/test-reporter@v1
if: always()
with:
name: Unit Test Report
path: target/surefire-reports/TEST-*.xml
reporter: java-junit
fail-on-error: false
- name: Cache SonarCloud packages
uses: actions/cache@v4
with:
path: ~/.sonar/cache
key: ${{ runner.os }}-sonar
restore-keys: ${{ runner.os }}-sonar
- name: Cache Maven packages
uses: actions/cache@v4
with:
path: ~/.m2
key: ${{ runner.os }}-m2-${{ hashFiles('**/pom.xml') }}
restore-keys: ${{ runner.os }}-m2
- name: Build and analyze
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # Needed to get PR information, if any
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} ## This needs to be configured
run: mvn -B verify org.sonarsource.scanner.maven:sonar-maven-plugin:sonar -Dsonar.projectKey=swisspost_mobile-access-gateway -Pcoverage
# Optional: Uploads the full dependency graph to GitHub to improve the quality of Dependabot alerts this repository can receive
# Also needs to be disable due to failures in the current repository
- name: Update dependency graph
uses: advanced-security/maven-dependency-submission-action@v3
- name: Upload mag artifact snapshot jar
uses: actions/upload-artifact@v4
with:
name: mag-jar-simple--${{ github.sha }}
path: target/mobile-access-gateway-1.0-SNAPSHOT.jar
- name: Upload mag artifact snapshot spring-boot jar
uses: actions/upload-artifact@v4
with:
name: mag-jar-Springboot--${{ github.sha }}
path: target/mobile-access-gateway-1.0-SNAPSHOT-spring-boot.jar