archiva/Jenkinsfile

120 lines
4.1 KiB
Plaintext
Raw Normal View History

LABEL = 'ubuntu'
buildJdk = 'JDK 1.8 (latest)'
buildMvn = 'Maven 3.5.2'
deploySettings = 'DefaultMavenSettingsProvider.1331204114925'
2018-04-18 00:11:53 -04:00
pipeline {
2018-05-01 08:08:14 -04:00
agent {
label "${LABEL}"
}
2018-05-01 04:29:17 -04:00
2018-05-01 08:08:14 -04:00
stages {
stage('Checkout') {
steps {
script {
2018-05-01 14:19:58 -04:00
echo "Info: Job-Name=${JOB_NAME}, Branch=${BRANCH_NAME}, Workspace=${PWD}"
}
checkout scm
}
post {
failure {
notifyBuild("Checkout failure")
}
}
2018-05-01 04:29:17 -04:00
}
stage('Build') {
steps {
timeout(120) {
withMaven(maven: buildMvn, jdk: buildJdk,
mavenSettingsConfig: deploySettings,
2018-05-01 14:19:58 -04:00
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"
2018-05-01 04:29:17 -04:00
// 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"
}
}
}
post {
success {
2018-05-01 08:08:14 -04:00
junit testDataPublishers: [[$class: 'StabilityTestDataPublisher']], testResults: '**/target/surefire-reports/TEST-*.xml'
archiveArtifacts '**/target/*.war,**/target/*-bin.zip'
}
failure {
notifyBuild("Build / Test failure")
}
2018-05-01 04:29:17 -04:00
}
}
stage('Deploy') {
steps {
timeout(120) {
withMaven(maven: buildMvn, jdk: buildJdk,
mavenSettingsConfig: deploySettings,
2018-05-01 14:19:58 -04:00
mavenLocalRepo: ".repository"
)
{
sh "mvn deploy -B -Dmaven.test.skip=true"
}
}
}
post {
failure {
notifyBuild("Deploy failure")
}
2018-05-01 04:29:17 -04:00
}
}
2018-05-01 08:09:36 -04:00
}
post {
unstable {
notifyBuild("Unstable Build")
2018-05-01 04:29:17 -04:00
}
2018-05-01 14:19:58 -04:00
always {
cleanWs deleteDirs: true, notFailBuild: true, patterns: [[pattern: '.repository', type: 'EXCLUDE']]
}
2018-05-01 04:29:17 -04:00
}
}
// Send a notification about the build status
2018-05-01 04:29:17 -04:00
def notifyBuild(String buildStatus) {
// default the value
buildStatus = buildStatus ?: "UNKNOWN"
2018-05-01 04:29:17 -04:00
def email = "notifications@archiva.apache.org"
def summary = "${env.JOB_NAME}#${env.BUILD_NUMBER} - ${buildStatus}"
def detail = """<h4>Job: <a href='${env.JOB_URL}'>${env.JOB_NAME}</a> [#${env.BUILD_NUMBER}]</h4>
<p><b>${buildStatus}</b></p>
<table>
<tr><td>Build</td><td><a href='${env.BUILD_URL}'>${env.BUILD_URL}</a></td><tr>
<tr><td>Console</td><td><a href='${env.BUILD_URL}console'>${env.BUILD_URL}console</a></td><tr>
<tr><td>Test Report</td><td><a href='${env.BUILD_URL}testReport/'>${env.BUILD_URL}testReport/</a></td><tr>
</table>
"""
2018-05-01 04:29:17 -04:00
emailext(
to: email,
subject: summary,
body: detail,
mimeType: 'text/html'
)
}
// vim: et:ts=2:sw=2:ft=groovy