mirror of
https://github.com/corda/corda.git
synced 2024-12-19 13:08:04 +00:00
101 lines
4.0 KiB
Groovy
101 lines
4.0 KiB
Groovy
@Library('existing-build-control')
|
|
import static com.r3.build.BuildControl.killAllExistingBuildsForJob
|
|
|
|
killAllExistingBuildsForJob(env.JOB_NAME, env.BUILD_NUMBER.toInteger())
|
|
|
|
pipeline {
|
|
agent { label 'gke' }
|
|
options {
|
|
timestamps()
|
|
buildDiscarder(logRotator(daysToKeepStr: '7', artifactDaysToKeepStr: '7'))
|
|
}
|
|
|
|
environment {
|
|
DOCKER_TAG_TO_USE = "${env.GIT_COMMIT.subSequence(0, 8)}"
|
|
EXECUTOR_NUMBER = "${env.EXECUTOR_NUMBER}"
|
|
BUILD_ID = "${env.BUILD_ID}-${env.JOB_NAME}"
|
|
ARTIFACTORY_CREDENTIALS = credentials('artifactory-credentials')
|
|
}
|
|
|
|
stages {
|
|
stage('Corda Pull Request - Generate Build Image') {
|
|
steps {
|
|
withCredentials([string(credentialsId: 'container_reg_passwd', variable: 'DOCKER_PUSH_PWD')]) {
|
|
sh "./gradlew " +
|
|
"-Dkubenetize=true " +
|
|
"-Ddocker.push.password=\"\${DOCKER_PUSH_PWD}\" " +
|
|
"-Ddocker.work.dir=\"/tmp/\${EXECUTOR_NUMBER}\" " +
|
|
"-Ddocker.build.tag=\"\${DOCKER_TAG_TO_USE}\"" +
|
|
" clean pushBuildImage --stacktrace"
|
|
}
|
|
sh "kubectl auth can-i get pods"
|
|
}
|
|
}
|
|
|
|
stage('Regression Test') {
|
|
steps {
|
|
sh "./gradlew " +
|
|
"-DbuildId=\"\${BUILD_ID}\" " +
|
|
"-Dkubenetize=true " +
|
|
"-Ddocker.run.tag=\"\${DOCKER_TAG_TO_USE}\" " +
|
|
"-Dartifactory.username=\"\${ARTIFACTORY_CREDENTIALS_USR}\" " +
|
|
"-Dartifactory.password=\"\${ARTIFACTORY_CREDENTIALS_PSW}\" " +
|
|
"-Dgit.branch=\"\${GIT_BRANCH}\" " +
|
|
"-Dgit.target.branch=\"\${GIT_BRANCH}\" " +
|
|
" parallelRegressionTest --stacktrace"
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
post {
|
|
always {
|
|
archiveArtifacts artifacts: '**/pod-logs/**/*.log', fingerprint: false
|
|
junit '**/build/test-results-xml/**/*.xml'
|
|
|
|
script {
|
|
try {
|
|
/*
|
|
* Copy all JUnit results files into a single top level directory.
|
|
* This is necessary to stop the allure plugin from hitting out
|
|
* of memory errors due to being passed many directories with
|
|
* long paths.
|
|
*
|
|
* File names are pre-pended with the pod number when
|
|
* copied to avoid collisions between files where the same test
|
|
* classes have run on multiple pods.
|
|
*/
|
|
sh label: 'Compact test results',
|
|
script:
|
|
'''#!/bin/bash
|
|
shopt -s globstar
|
|
rm -rf allure-input
|
|
mkdir allure-input
|
|
|
|
for i in **/test-results-xml/**/test-runs/test-reports/**
|
|
do
|
|
[ -f $i ] &&
|
|
cp $i allure-input/$(echo $i | sed -e \\
|
|
\'s/.*test-results-xml\\/.*-\\(.*\\)\\/test-runs\\/.*\\/\\(.*\\)$/\\1\\-\\2/\')
|
|
done
|
|
|
|
echo "Finished compacting JUnit results"
|
|
'''
|
|
allure includeProperties: false,
|
|
jdk: '',
|
|
results: [[path: '**/allure-input']]
|
|
} catch (err) {
|
|
echo("Allure report generation failed: $err")
|
|
|
|
if (currentBuild.resultIsBetterOrEqualTo('SUCCESS')) {
|
|
currentBuild.result = 'UNSTABLE'
|
|
}
|
|
}
|
|
}
|
|
}
|
|
cleanup {
|
|
deleteDir() /* clean up our workspace */
|
|
}
|
|
}
|
|
}
|