2020-01-24 10:39:23 +00:00
|
|
|
@Library('corda-shared-build-pipeline-steps')
|
2019-10-08 14:33:24 +00:00
|
|
|
import static com.r3.build.BuildControl.killAllExistingBuildsForJob
|
|
|
|
|
|
|
|
killAllExistingBuildsForJob(env.JOB_NAME, env.BUILD_NUMBER.toInteger())
|
|
|
|
|
|
|
|
pipeline {
|
2020-04-16 06:56:39 +00:00
|
|
|
agent { label 'k8s' }
|
2019-11-09 08:57:19 +00:00
|
|
|
options {
|
|
|
|
timestamps()
|
|
|
|
buildDiscarder(logRotator(daysToKeepStr: '7', artifactDaysToKeepStr: '7'))
|
2020-02-12 14:26:06 +00:00
|
|
|
timeout(time: 3, unit: 'HOURS')
|
2019-11-09 08:57:19 +00:00
|
|
|
}
|
2019-10-08 14:33:24 +00:00
|
|
|
|
|
|
|
environment {
|
2019-11-01 15:52:20 +00:00
|
|
|
DOCKER_TAG_TO_USE = "${env.GIT_COMMIT.subSequence(0, 8)}"
|
2019-10-08 14:33:24 +00:00
|
|
|
EXECUTOR_NUMBER = "${env.EXECUTOR_NUMBER}"
|
|
|
|
BUILD_ID = "${env.BUILD_ID}-${env.JOB_NAME}"
|
2019-11-04 13:05:13 +00:00
|
|
|
ARTIFACTORY_CREDENTIALS = credentials('artifactory-credentials')
|
2019-10-08 14:33:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
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}\" " +
|
2019-11-01 15:52:20 +00:00
|
|
|
"-Ddocker.build.tag=\"\${DOCKER_TAG_TO_USE}\"" +
|
2019-11-19 17:38:38 +00:00
|
|
|
" clean pushBuildImage --stacktrace"
|
2019-10-08 14:33:24 +00:00
|
|
|
}
|
|
|
|
sh "kubectl auth can-i get pods"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-03-03 11:16:38 +00:00
|
|
|
stage('Testing phase') {
|
|
|
|
parallel {
|
|
|
|
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"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
stage('Slow Integration 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}\" " +
|
|
|
|
" allParallelSlowIntegrationTest --stacktrace"
|
|
|
|
}
|
|
|
|
}
|
2020-04-01 10:03:01 +00:00
|
|
|
|
|
|
|
stage('Generate sonarqube report') {
|
|
|
|
steps {
|
2020-04-03 14:14:03 +00:00
|
|
|
script {
|
|
|
|
try {
|
|
|
|
// running this step here is the only way to not majorly affect the distributed test plugin,
|
|
|
|
// as now that neither returns build files nor runs jacoco reports
|
|
|
|
sh "./gradlew --no-daemon build jacocoRootReport --stacktrace"
|
|
|
|
withSonarQubeEnv('sq01') {
|
|
|
|
sh "./gradlew --no-daemon sonarqube -x test --stacktrace"
|
|
|
|
}
|
|
|
|
timeout(time: 3, unit: 'MINUTES') {
|
|
|
|
script {
|
|
|
|
try {
|
|
|
|
def qg = waitForQualityGate();
|
|
|
|
if (qg.status != 'OK') {
|
|
|
|
error "Pipeline aborted due to quality gate failure: ${qg.status}"
|
|
|
|
}
|
|
|
|
} catch (org.jenkinsci.plugins.workflow.steps.FlowInterruptedException e) {
|
|
|
|
println('No sonarqube webhook response within timeout. Please check the webhook configuration in sonarqube.')
|
|
|
|
// continue the pipeline
|
|
|
|
}
|
2020-04-01 10:03:01 +00:00
|
|
|
}
|
|
|
|
}
|
2020-04-03 14:14:03 +00:00
|
|
|
} catch (err) {
|
|
|
|
println('Error while trying to execute sonarqube analysis, will be skipped.')
|
2020-04-01 10:03:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2019-10-08 14:33:24 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-11-01 15:52:20 +00:00
|
|
|
|
2019-10-08 14:33:24 +00:00
|
|
|
post {
|
|
|
|
always {
|
2019-11-01 15:52:20 +00:00
|
|
|
archiveArtifacts artifacts: '**/pod-logs/**/*.log', fingerprint: false
|
2019-10-08 14:33:24 +00:00
|
|
|
junit '**/build/test-results-xml/**/*.xml'
|
2020-01-14 11:52:05 +00:00
|
|
|
|
2020-01-16 11:55:01 +00:00
|
|
|
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.
|
|
|
|
*/
|
|
|
|
fileOperations([fileCopyOperation(
|
|
|
|
includes: '**/test-results-xml/**/test-runs/test-reports/**',
|
|
|
|
targetLocation: 'allure-input',
|
|
|
|
flattenFiles: true,
|
|
|
|
renameFiles: true,
|
|
|
|
sourceCaptureExpression: '.*test-results-xml/.*-([\\d]+)/.*/([^/]+)$',
|
|
|
|
targetNameExpression: '$1-$2')])
|
|
|
|
allure includeProperties: false,
|
|
|
|
jdk: '',
|
|
|
|
results: [[path: '**/allure-input']]
|
|
|
|
} catch (err) {
|
|
|
|
echo("Allure report generation failed: $err")
|
|
|
|
|
|
|
|
if (currentBuild.resultIsBetterOrEqualTo('SUCCESS')) {
|
|
|
|
currentBuild.result = 'UNSTABLE'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-01-14 11:52:05 +00:00
|
|
|
script
|
|
|
|
{
|
|
|
|
// We want to send a summary email, but want to limit to once per day.
|
|
|
|
// Comparing the dates of the previous and current builds achieves this,
|
|
|
|
// i.e. we will only send an email for the first build on a given day.
|
|
|
|
def prevBuildDate = new Date(
|
|
|
|
currentBuild?.previousBuild.timeInMillis ?: 0).clearTime()
|
|
|
|
def currentBuildDate = new Date(
|
|
|
|
currentBuild.timeInMillis).clearTime()
|
|
|
|
|
|
|
|
if (prevBuildDate != currentBuildDate) {
|
|
|
|
def statusSymbol = '\u2753'
|
|
|
|
switch(currentBuild.result) {
|
|
|
|
case 'SUCCESS':
|
|
|
|
statusSymbol = '\u2705'
|
|
|
|
break;
|
|
|
|
case 'UNSTABLE':
|
|
|
|
case 'FAILURE':
|
|
|
|
statusSymbol = '\u274c'
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
echo('First build for this date, sending summary email')
|
|
|
|
emailext to: '$DEFAULT_RECIPIENTS',
|
|
|
|
subject: "$statusSymbol" + '$BRANCH_NAME regression tests - $BUILD_STATUS',
|
|
|
|
mimeType: 'text/html',
|
|
|
|
body: '${SCRIPT, template="groovy-html.template"}'
|
|
|
|
} else {
|
|
|
|
echo('Already sent summary email today, suppressing')
|
2019-12-20 14:44:45 +00:00
|
|
|
}
|
|
|
|
}
|
2019-10-08 14:33:24 +00:00
|
|
|
}
|
|
|
|
cleanup {
|
|
|
|
deleteDir() /* clean up our workspace */
|
|
|
|
}
|
|
|
|
}
|
2019-12-04 14:49:44 +00:00
|
|
|
}
|