Reformat of Jenkinsfile and fixing deploy stage.

Using repository that is not job specific to improve build time.
This commit is contained in:
Martin Stockhammer 2018-05-01 13:37:38 +02:00
parent d46cf57c36
commit f827eef832
1 changed files with 65 additions and 61 deletions

126
Jenkinsfile vendored
View File

@ -5,86 +5,90 @@ def deploySettings = 'DefaultMavenSettingsProvider.1331204114925'
node(labels) { node(labels) {
def PWD = pwd(); def PWD = pwd()
echo "Workspace: ${PWD}" def REPO_DIR="${env.JENKINS_HOME}/.repo-${env.JOB_NAME.replace('/','_')}"
echo "Info: Job-Name=${JOB_NAME}, Branch=${BRANCH_NAME}, Workspace=${PWD}, Repo-Dir=${REPO_DIR}"
try { stages {
stage('Checkout') { stage('Checkout') {
checkout scm steps {
checkout scm
script {
currentBuild.displayName = "Archiva master build"
currentBuild.description = "This builds, tests and deploys the current artifact from archiva master branch."
}
}
post {
failure {
notifyBuild("Checkout failure")
}
}
} }
} catch (Exception e) {
notifyBuild("Checkout Failure")
throw e
}
try {
stage('Build') { stage('Build') {
timeout(120) { steps {
withMaven(maven: buildMvn, jdk: buildJdk, timeout(120) {
mavenSettingsConfig: deploySettings, withMaven(maven: buildMvn, jdk: buildJdk,
mavenLocalRepo: ".repository" mavenSettingsConfig: deploySettings,
) mavenLocalRepo: REPO_DIR
{ )
sh "chmod 755 ./src/ci/scripts/prepareWorkspace.sh" {
sh "./src/ci/scripts/prepareWorkspace.sh" sh "chmod 755 ./src/ci/scripts/prepareWorkspace.sh"
// Needs a lot of time to reload the repository files, try without cleanup sh "./src/ci/scripts/prepareWorkspace.sh"
// Not sure, but maybe // Needs a lot of time to reload the repository files, try without cleanup
// sh "rm -rf .repository" // Not sure, but maybe
// sh "rm -rf .repository"
// Run test phase / ignore test failures
// Run test phase / ignore test failures // -B: Batch mode
// -B: Batch mode // -U: Force snapshot update
// -U: Force snapshot update // -e: Produce execution error messages
// -e: Produce execution error messages // -fae: Fail at the end
// -fae: Fail at the end // -Dmaven.compiler.fork=false: Do not compile in a separate forked process
// -Dmaven.compiler.fork=false: Do not compile in a separate forked process // -Dmaven.test.failure.ignore=true: Do not stop, if some tests fail
// -Dmaven.test.failure.ignore=true: Do not stop, if some tests fail // -Pci-build: Profile for CI-Server
// -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"
sh "mvn clean install -B -U -e -fae -Dmaven.test.failure.ignore=true -T2 -Dmaven.compiler.fork=false -Pci-build" }
} }
}
post {
success {
junit testDataPublishers: [[$class: 'StabilityTestDataPublisher']], '**/target/surefire-reports/TEST-*.xml'
archiveArtifacts '**/target/*.war,**/target/*-bin.zip'
}
failure {
notifyBuild("Build / Test failure")
}
} }
} }
} catch (Exception e) {
notifyBuild("Test Failure")
throw e
}
try {
stage('Deploy') { stage('Deploy') {
timeout(120) { steps {
withMaven(maven: buildMvn, jdk: buildJdk, timeout(120) {
mavenSettingsConfig: deploySettings, withMaven(maven: buildMvn, jdk: buildJdk,
mavenLocalRepo: ".repository" mavenSettingsConfig: deploySettings,
) mavenLocalRepo: REPO_DIR
{ )
// Repository cleanup causes a lot of time to reload them. We try without cleanup {
// sh "rm -rf .repository" sh "mvn deploy -B -Dmaven.test.skip=true"
// Run test phase / ignore test failures }
sh "mvn -B deploy" }
} }
post {
failure {
notifyBuild("Deploy failure")
}
} }
} }
} catch (Exception e) {
notifyBuild("Deploy Failure")
throw e
} }
post { post {
always { unstable {
if (isUnstable()) { notifyBuild("Unstable Build")
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"
}
// Send a notification about the build status // Send a notification about the build status
def notifyBuild(String buildStatus) { def notifyBuild(String buildStatus) {