From: David ‘Bombe’ Roden Date: Wed, 2 Oct 2024 07:47:44 +0000 (+0200) Subject: 🏗️ Add Jenkinsfile X-Git-Url: https://git.pterodactylus.net/?a=commitdiff_plain;h=refs%2Fheads%2Fnext;p=jSite.git 🏗️ Add Jenkinsfile --- diff --git a/Jenkinsfile b/Jenkinsfile new file mode 100644 index 0000000..cbb182e --- /dev/null +++ b/Jenkinsfile @@ -0,0 +1,64 @@ +pipeline { + agent any + + options { + timestamps() + } + + stages { + stage('Build (Java 8)') { + tools { + jdk 'OpenJDK 8' + } + steps { + sh './gradlew clean classes testClasses' + } + } + stage('Test (Java 8)') { + tools { + jdk 'OpenJDK 8' + } + steps { + sh './gradlew test jacocoTestReport' + } + post { + always { + junit 'build/test-results/*/*.xml' + jacoco classPattern: 'build/classes/*/main', sourcePattern: '**/src/main/' + recordCoverage(tools: [[parser: 'JACOCO', pattern: '**/jacocoTestReport.xml']]) + } + } + } + stage('Binary (Java 8)') { + tools { + jdk 'OpenJDK 8' + } + steps { + sh './gradlew fatJar' + archiveArtifacts artifacts: 'build/libs/jSite*-jar-with-dependencies.jar', fingerprint: true + } + } + stage('Compatibility (Java 17)') { + tools { + jdk 'OpenJDK 17' + } + steps { + catchError(buildResult: 'SUCCESS', stageResult: 'FAILURE') { + sh './gradlew clean test' + } + } + } + stage('Compatibility (Java 21)') { + tools { + jdk 'OpenJDK 21' + } + steps { + catchError(buildResult: 'SUCCESS', stageResult: 'FAILURE') { + sh './gradlew clean test' + } + } + } + } +} + +// vi: ts=4 sw=4 et si diff --git a/build.gradle b/build.gradle index bb21b70..c530c78 100644 --- a/build.gradle +++ b/build.gradle @@ -42,5 +42,9 @@ jacoco { toolVersion = '0.8.10' } -jacocoTestReport.dependsOn test - +jacocoTestReport { + dependsOn test + reports { + xml.enabled = true + } +}