You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@jackrabbit.apache.org by kw...@apache.org on 2022/01/05 11:09:56 UTC
[jackrabbit-filevault-jenkins-lib] 01/01: separate IT execution
This is an automated email from the ASF dual-hosted git repository.
kwin pushed a commit to branch feature/JCRVLT-580-parameterize-maven-version
in repository https://gitbox.apache.org/repos/asf/jackrabbit-filevault-jenkins-lib.git
commit e620bf186b1346b0ed5911d6983f1ad68fb4e682
Author: Konrad Windszus <kw...@apache.org>
AuthorDate: Wed Jan 5 12:03:47 2022 +0100
separate IT execution
---
vars/fileVaultMavenStdBuild.groovy | 55 +++++++++++++++++++++++++++++---------
1 file changed, 42 insertions(+), 13 deletions(-)
diff --git a/vars/fileVaultMavenStdBuild.groovy b/vars/fileVaultMavenStdBuild.groovy
index 5185417..c29c8ed 100644
--- a/vars/fileVaultMavenStdBuild.groovy
+++ b/vars/fileVaultMavenStdBuild.groovy
@@ -60,17 +60,14 @@ String getMavenLabel(String mavenVersion) {
return "maven_${versionLabel}"
}
-def buildStage(final int jdkVersion, final String nodeLabel, final String mavenVersion, final boolean isMainBuild, final String sonarProjectKey) {
+def buildStage(final String jdkLabel, final String nodeLabel, final String mavenVersion, final boolean isMainBuild, final String sonarProjectKey) {
return {
- // https://cwiki.apache.org/confluence/display/INFRA/JDK+Installation+Matrix
- def availableJDKs = [ 8: 'jdk_1.8_latest', 9: 'jdk_1.9_latest', 10: 'jdk_10_latest', 11: 'jdk_11_latest', 12: 'jdk_12_latest', 13: 'jdk_13_latest', 14: 'jdk_14_latest', 15: 'jdk_15_latest', 16: 'jdk_16_latest', 17: 'jdk_17_latest', 18: 'jdk_18_latest', 19: 'jdk_19_latest']
- final String jdkLabel = availableJDKs[jdkVersion]
final String wagonPluginGav = "org.codehaus.mojo:wagon-maven-plugin:2.0.2"
final String sonarPluginGav = "org.sonarsource.scanner.maven:sonar-maven-plugin:3.9.1.2184"
node(label: nodeLabel) {
- stage("${isMainBuild ? 'Main ' : ''}Maven Build (JDK ${jdkVersion}, Maven ${mavenVersion}, ${nodeLabel})") {
+ stage("${isMainBuild ? 'Main ' : ''}Maven Build (JDK ${jdkLabel}, Maven ${mavenVersion}, ${nodeLabel})") {
timeout(60) {
- final String mavenLabel = getMavenLabel(mavenVersion)
+ final String mavenLabel = getMavenLabel(mavenVersion) // this requires a node context
echo "Running on node ${env.NODE_NAME}"
checkout scm
try {
@@ -81,17 +78,21 @@ def buildStage(final int jdkVersion, final String nodeLabel, final String mavenV
dir(localRepoPath) {
deleteDir()
}
- mavenArguments = "-U clean site deploy -DaltDeploymentRepository=snapshot-repo::default::file:${localRepoPath} -Pjacoco-report -Dlogback.configurationFile=vault-core/src/test/resources/logback-only-errors.xml"
+ mavenArguments = "-U clean site deploy -DskipITs -DaltDeploymentRepository=snapshot-repo::default::file:${localRepoPath} -Pjacoco-report -Dlogback.configurationFile=vault-core/src/test/resources/logback-only-errors.xml"
} else {
- mavenArguments = '-U clean verify site'
+ mavenArguments = '-U clean package site'
}
executeMaven(jdkLabel, mavenLabel, mavenArguments, 'IMPLICIT')
- if (isMainBuild && isOnMainBranch()) {
- // Stash the build results so we can deploy them on another node
- stash name: 'local-snapshots-dir', includes: 'local-snapshots-dir/**'
+ if (isMainBuild) {
+ // stash the integration test classes for later execution
+ stash name: 'integration-test-classes', includes: '**/target/test-classes/**/*IT*.class'
+ if (isOnMainBranch()) {
+ // Stash the build results so we can deploy them on another node
+ stash name: 'local-snapshots-dir', includes: 'local-snapshots-dir/**'
+ }
}
} finally {
- junit '**/target/surefire-reports/**/*.xml,**/target/failsafe-reports*/**/*.xml'
+ junit '**/target/surefire-reports/**/*.xml'
}
}
}
@@ -124,13 +125,38 @@ def buildStage(final int jdkVersion, final String nodeLabel, final String mavenV
}
}
+def stageIT(final String jdkLabel, final String nodeLabel, final String mavenVersion) {
+ stage("Run Integration Tests") {
+ node(nodeLabel) {
+ timeout(60) {
+ // Nexus deployment needs pom.xml
+ checkout scm
+ // Unstash the previously stashed build results.
+ unstash name: 'integration-test-classes'
+ try {
+ final String mavenLabel = getMavenLabel(mavenVersion) // this requires a node context
+ // populate test source directory
+ String mavenArguments = "failsafe:integration-test failsafe:verify
+ executeMaven(jdkLabel, mavenLabel, mavenArguments, 'EXPLICIT')
+ } finally {
+ junit '**/target/failsafe-reports*/**/*.xml'
+ }
+ }
+ }
+ }
+}
+
def stagesFor(List<Integer> jdkVersions, int mainJdkVersion, List<String> nodeLabels, String mainNodeLabel, List<String> mavenVersions, String mainMavenVersion, String sonarProjectKey) {
def stageMap = [:]
+ // https://cwiki.apache.org/confluence/display/INFRA/JDK+Installation+Matrix
+ def availableJDKs = [ 8: 'jdk_1.8_latest', 9: 'jdk_1.9_latest', 10: 'jdk_10_latest', 11: 'jdk_11_latest', 12: 'jdk_12_latest', 13: 'jdk_13_latest', 14: 'jdk_14_latest', 15: 'jdk_15_latest', 16: 'jdk_16_latest', 17: 'jdk_17_latest', 18: 'jdk_18_latest', 19: 'jdk_19_latest']
+
for (nodeLabel in nodeLabels) {
for (jdkVersion in jdkVersions) {
+ final String jdkLabel = availableJDKs[jdkVersion]
for (mavenVersion in mavenVersions) {
boolean isMainBuild = (jdkVersion == mainJdkVersion && nodeLabel == mainNodeLabel && mainMavenVersion == mavenVersion)
- stageMap["JDK ${jdkVersion}, ${nodeLabel}, Maven ${mavenVersion} ${isMainBuild ? ' (Main)' : ''}"] = buildStage(jdkVersion, nodeLabel, mavenVersion, isMainBuild, sonarProjectKey)
+ stageMap["JDK ${jdkVersion}, ${nodeLabel}, Maven ${mavenVersion} ${isMainBuild ? ' (Main)' : ''}"] = buildStage(jdkLabel, nodeLabel, mavenVersion, isMainBuild, sonarProjectKey)
}
}
}
@@ -155,4 +181,7 @@ def call(List<Integer> jdkVersions, int mainJdkVersion, List<String> nodeLabels,
}
properties(buildProperties)
parallel stagesFor(jdkVersions, mainJdkVersion, nodeLabels, mainNodeLabel, mavenVersions, mainMavenVersion, sonarProjectKey)
+ // TODO: trigger ITs separately
+ stageIT('jdk_1.8_latest', mainNodeLabel, '3.3.9')
+ // finally do deploy
}