diff --git a/Jenkinsfile b/Jenkinsfile index b4f37104b..dc1a094a5 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -1,63 +1,99 @@ - def labels = 'ubuntu' def buildJdk = 'JDK 1.8 (latest)' -def buildMvn = 'Maven 3.5.2' +def buildMvn = 'Maven 3.5.2' def deploySettings = 'DefaultMavenSettingsProvider.1331204114925' -node (labels) { - try - { - stage ('Checkout') { - checkout scm - } - } catch (Exception e) { - //notifyBuild("Checkout Failure") - throw e - } +node(labels) { - try - { - stage ('Build') { - timeout(120) { - withMaven(maven: buildMvn, jdk: buildJdk, - mavenSettingsConfig: deploySettings, - mavenLocalRepo: ".repository" - ) - { - sh "rm -rf .repository" - // Run test phase / ignore test failures - sh "mvn -B clean deploy -Dmaven.test.failure.ignore=true -T2" - } - // Report failures in the jenkins UI - //step([$class: 'JUnitResultArchiver', testResults: '**/target/surefire-reports/TEST-*.xml']) - } - if(isUnstable()) - { - //notifyBuild("Unstable / Test Errors") - } - } - } catch(Exception e) { - notifyBuild("Test Failure") - throw e - } + def PWD = pwd(); + echo "Workspace: ${PWD}" + + try { + stage('Checkout') { + checkout scm + } + } catch (Exception e) { + notifyBuild("Checkout Failure") + throw e + } + + try { + stage('Build') { + timeout(120) { + withMaven(maven: buildMvn, jdk: buildJdk, + mavenSettingsConfig: deploySettings, + mavenLocalRepo: ".repository" + ) + { + sh "chmod 755 ./src/ci/scripts/prepareWorkspace.sh" + sh "./src/ci/scripts/prepareWorkspace.sh" + // Needs a lot of time to reload the repository files, try without cleanup + // Not sure, but maybe + // sh "rm -rf .repository" + + + // Run test phase / ignore test failures + // -B: Batch mode + // -U: Force snapshot update + // -e: Produce execution error messages + // -fae: Fail at the end + // -Dmaven.compiler.fork=false: Do not compile in a separate forked process + // -Dmaven.test.failure.ignore=true: Do not stop, if some tests fail + // -Pci-build: Profile for CI-Server + sh "mvn clean install -B -U -e -fae -Dmaven.test.failure.ignore=true -T2 -Dmaven.compiler.fork=false -Pci-build" + } + } + } + } catch (Exception e) { + notifyBuild("Test Failure") + throw e + } + + try { + stage('Deploy') { + timeout(120) { + withMaven(maven: buildMvn, jdk: buildJdk, + mavenSettingsConfig: deploySettings, + mavenLocalRepo: ".repository" + ) + { + // Repository cleanup causes a lot of time to reload them. We try without cleanup + // sh "rm -rf .repository" + // Run test phase / ignore test failures + sh "mvn -B deploy" + } + } + } + } catch (Exception e) { + notifyBuild("Deploy Failure") + throw e + } + + post { + always { + if (isUnstable()) { + notifyBuild("Unstable Build") + } + junit testDataPublishers: [[$class: 'StabilityTestDataPublisher']], '**/target/surefire-reports/TEST-*.xml' + archiveArtifacts '**/target/*.war,**/target/*-bin.zip' + } + } } // Test if the Jenkins Pipeline or Step has marked the // current build as unstable -def isUnstable() -{ - return currentBuild.result == "UNSTABLE" +def isUnstable() { + return currentBuild.result == "UNSTABLE" } // Send a notification about the build status -def notifyBuild(String buildStatus) -{ - // default the value - buildStatus = buildStatus ?: "UNKNOWN" +def notifyBuild(String buildStatus) { + // default the value + buildStatus = buildStatus ?: "UNKNOWN" - def email = "notifications@archiva.apache.org" - def summary = "${env.JOB_NAME}#${env.BUILD_NUMBER} - ${buildStatus}" - def detail = """
${buildStatus}
Build | ${env.BUILD_URL} |