mirror of
https://github.com/corda/corda.git
synced 2025-01-19 03:06:36 +00:00
Merge pull request #6915 from corda/wz/merge-os-46-47-2021-06-07
NOTICK: Merging forward updates from OS 4.6 to OS 4.7 (2021-06-07)
This commit is contained in:
commit
a544ff7fab
@ -23,7 +23,7 @@ boolean isReleaseTag = (env.TAG_NAME =~ /^release.*JDK11$/)
|
|||||||
** calculate the stage for NexusIQ evaluation
|
** calculate the stage for NexusIQ evaluation
|
||||||
** * build for snapshots
|
** * build for snapshots
|
||||||
** * stage-release: for release candidates and for health checks
|
** * stage-release: for release candidates and for health checks
|
||||||
** * operate: for final release
|
** * release: for GA release
|
||||||
*/
|
*/
|
||||||
def nexusDefaultIqStage = "build"
|
def nexusDefaultIqStage = "build"
|
||||||
if (isReleaseTag) {
|
if (isReleaseTag) {
|
||||||
@ -47,175 +47,217 @@ def nexusIqStageChoices = [nexusDefaultIqStage].plus(
|
|||||||
'operate'
|
'operate'
|
||||||
].minus([nexusDefaultIqStage]))
|
].minus([nexusDefaultIqStage]))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Common Gradle arguments for all Gradle executions
|
||||||
|
*/
|
||||||
|
String COMMON_GRADLE_PARAMS = [
|
||||||
|
'--no-daemon',
|
||||||
|
'--stacktrace',
|
||||||
|
'--info',
|
||||||
|
'-Pcompilation.warningsAsErrors=false',
|
||||||
|
'-Ptests.failFast=true',
|
||||||
|
].join(' ')
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The name of subfolders to run tests previously on Another Agent and Same Agent
|
||||||
|
*/
|
||||||
|
String sameAgentFolder = 'sameAgent'
|
||||||
|
String anotherAgentFolder = 'anotherAgent'
|
||||||
|
|
||||||
pipeline {
|
pipeline {
|
||||||
agent { label 'k8s' }
|
agent {
|
||||||
|
dockerfile {
|
||||||
|
label 'standard'
|
||||||
|
additionalBuildArgs '--build-arg USER="${USER}"' // DON'T change quotation - USER variable is substituted by SHELL!!!!
|
||||||
|
filename "${sameAgentFolder}/.ci/dev/compatibility/DockerfileJDK11"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* List options in alphabetical order
|
||||||
|
*/
|
||||||
options {
|
options {
|
||||||
timestamps()
|
|
||||||
timeout(time: 3, unit: 'HOURS')
|
|
||||||
buildDiscarder(logRotator(daysToKeepStr: '14', artifactDaysToKeepStr: '14'))
|
buildDiscarder(logRotator(daysToKeepStr: '14', artifactDaysToKeepStr: '14'))
|
||||||
|
checkoutToSubdirectory "${sameAgentFolder}"
|
||||||
|
parallelsAlwaysFailFast()
|
||||||
|
timeout(time: 6, unit: 'HOURS')
|
||||||
|
timestamps()
|
||||||
}
|
}
|
||||||
|
|
||||||
parameters {
|
parameters {
|
||||||
choice choices: nexusIqStageChoices, description: 'NexusIQ stage for code evaluation', name: 'nexusIqStage'
|
choice choices: nexusIqStageChoices, description: 'NexusIQ stage for code evaluation', name: 'nexusIqStage'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* List environment variables in alphabetical order
|
||||||
|
*/
|
||||||
environment {
|
environment {
|
||||||
DOCKER_TAG_TO_USE = "${env.GIT_COMMIT.subSequence(0, 8)}JDK11"
|
ARTIFACTORY_BUILD_NAME = "Corda :: Publish :: Publish JDK 11 Release to Artifactory :: ${env.BRANCH_NAME}"
|
||||||
EXECUTOR_NUMBER = "${env.EXECUTOR_NUMBER}"
|
|
||||||
BUILD_ID = "${env.BUILD_ID}-${env.JOB_NAME}"
|
|
||||||
ARTIFACTORY_CREDENTIALS = credentials('artifactory-credentials')
|
ARTIFACTORY_CREDENTIALS = credentials('artifactory-credentials')
|
||||||
ARTIFACTORY_BUILD_NAME = "Corda / Publish / Publish JDK 11 Release to Artifactory".replaceAll("/", "::")
|
|
||||||
CORDA_ARTIFACTORY_USERNAME = "${env.ARTIFACTORY_CREDENTIALS_USR}"
|
|
||||||
CORDA_ARTIFACTORY_PASSWORD = "${env.ARTIFACTORY_CREDENTIALS_PSW}"
|
CORDA_ARTIFACTORY_PASSWORD = "${env.ARTIFACTORY_CREDENTIALS_PSW}"
|
||||||
|
CORDA_ARTIFACTORY_USERNAME = "${env.ARTIFACTORY_CREDENTIALS_USR}"
|
||||||
}
|
}
|
||||||
|
|
||||||
stages {
|
stages {
|
||||||
/*
|
stage('Compile') {
|
||||||
* Temporarily disable Sonatype checks for regression builds
|
steps {
|
||||||
*/
|
dir(sameAgentFolder) {
|
||||||
|
sh script: [
|
||||||
|
'./gradlew',
|
||||||
|
COMMON_GRADLE_PARAMS,
|
||||||
|
'clean',
|
||||||
|
'jar'
|
||||||
|
].join(' ')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
stage('Copy') {
|
||||||
|
steps {
|
||||||
|
sh "rm -rf ${anotherAgentFolder} && mkdir -p ${anotherAgentFolder} && cd ${sameAgentFolder} && cp -aR . ../${anotherAgentFolder}"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
stage('Sonatype Check') {
|
stage('Sonatype Check') {
|
||||||
when {
|
|
||||||
expression { isReleaseTag }
|
|
||||||
}
|
|
||||||
steps {
|
steps {
|
||||||
sh "./gradlew --no-daemon clean jar"
|
dir(sameAgentFolder) {
|
||||||
script {
|
script {
|
||||||
sh "./gradlew --no-daemon properties | grep -E '^(version|group):' >version-properties"
|
sh "./gradlew --no-daemon properties | grep -E '^(version|group):' >version-properties"
|
||||||
/* every build related to Corda X.Y (GA, RC, HC, patch or snapshot) uses the same NexusIQ application */
|
/* every build related to Corda X.Y (GA, RC, HC, patch or snapshot) uses the same NexusIQ application */
|
||||||
def version = sh (returnStdout: true, script: "grep ^version: version-properties | sed -e 's/^version: \\([0-9]\\+\\(\\.[0-9]\\+\\)\\+\\).*\$/\\1/'").trim()
|
def version = sh(returnStdout: true, script: "grep ^version: version-properties | sed -e 's/^version: \\([0-9]\\+\\(\\.[0-9]\\+\\)\\+\\).*\$/\\1/'").trim()
|
||||||
def groupId = sh (returnStdout: true, script: "grep ^group: version-properties | sed -e 's/^group: //'").trim()
|
def groupId = sh(returnStdout: true, script: "grep ^group: version-properties | sed -e 's/^group: //'").trim()
|
||||||
def artifactId = 'corda'
|
def artifactId = 'corda'
|
||||||
nexusAppId = "${groupId}-${artifactId}-${version}"
|
nexusAppId = "${groupId}-${artifactId}-${version}"
|
||||||
|
}
|
||||||
|
nexusPolicyEvaluation(
|
||||||
|
failBuildOnNetworkError: false,
|
||||||
|
iqApplication: selectedApplication(nexusAppId), // application *has* to exist before a build starts!
|
||||||
|
iqScanPatterns: [[scanPattern: 'node/capsule/build/libs/corda*.jar']],
|
||||||
|
iqStage: params.nexusIqStage
|
||||||
|
)
|
||||||
}
|
}
|
||||||
nexusPolicyEvaluation (
|
|
||||||
failBuildOnNetworkError: false,
|
|
||||||
iqApplication: selectedApplication(nexusAppId), // application *has* to exist before a build starts!
|
|
||||||
iqScanPatterns: [[scanPattern: 'node/capsule/build/libs/corda*.jar']],
|
|
||||||
iqStage: params.nexusIqStage
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
stage('Generate Build Image') {
|
stage('All Tests') {
|
||||||
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}\" " +
|
|
||||||
"-Ddocker.buildbase.tag=11latest " +
|
|
||||||
"-Ddocker.container.env.parameter.CORDA_ARTIFACTORY_USERNAME=\"\${ARTIFACTORY_CREDENTIALS_USR}\" " +
|
|
||||||
"-Ddocker.container.env.parameter.CORDA_ARTIFACTORY_PASSWORD=\"\${ARTIFACTORY_CREDENTIALS_PSW}\" " +
|
|
||||||
"-Ddocker.dockerfile=DockerfileJDK11Azul" +
|
|
||||||
" clean preAllocateForAllParallelUnitTest preAllocateForAllParallelIntegrationTest " +
|
|
||||||
" preAllocateForAllParallelSlowIntegrationTest preAllocateForAllParallelSmokeTest " +
|
|
||||||
" pushBuildImage --stacktrace"
|
|
||||||
}
|
|
||||||
sh "kubectl auth can-i get pods"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
stage('Testing phase') {
|
|
||||||
parallel {
|
parallel {
|
||||||
stage('Unit Test') {
|
stage('Another agent') {
|
||||||
steps {
|
post {
|
||||||
sh "./gradlew " +
|
always {
|
||||||
"-DbuildId=\"\${BUILD_ID}\" " +
|
dir(anotherAgentFolder) {
|
||||||
"-Dkubenetize=true " +
|
archiveArtifacts artifacts: '**/*.log', fingerprint: false
|
||||||
"-Ddocker.run.tag=\"\${DOCKER_TAG_TO_USE}\" " +
|
junit testResults: '**/build/test-results/**/*.xml', keepLongStdio: true
|
||||||
"-Dartifactory.username=\"\${ARTIFACTORY_CREDENTIALS_USR}\" " +
|
}
|
||||||
"-Dartifactory.password=\"\${ARTIFACTORY_CREDENTIALS_PSW}\" " +
|
}
|
||||||
"-Dgit.branch=\"\${GIT_BRANCH}\" " +
|
}
|
||||||
"-Dgit.target.branch=\"\${GIT_BRANCH}\" " +
|
stages {
|
||||||
" allParallelUnitTest --stacktrace"
|
stage('Unit Test') {
|
||||||
|
steps {
|
||||||
|
dir(anotherAgentFolder) {
|
||||||
|
sh script: [
|
||||||
|
'./gradlew',
|
||||||
|
COMMON_GRADLE_PARAMS,
|
||||||
|
'test'
|
||||||
|
].join(' ')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stage('Smoke Test') {
|
||||||
|
steps {
|
||||||
|
dir(anotherAgentFolder) {
|
||||||
|
sh script: [
|
||||||
|
'./gradlew',
|
||||||
|
COMMON_GRADLE_PARAMS,
|
||||||
|
'smokeTest'
|
||||||
|
].join(' ')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stage('Slow Integration Test') {
|
||||||
|
steps {
|
||||||
|
dir(anotherAgentFolder) {
|
||||||
|
sh script: [
|
||||||
|
'./gradlew',
|
||||||
|
COMMON_GRADLE_PARAMS,
|
||||||
|
'slowIntegrationTest'
|
||||||
|
].join(' ')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
stage('Integration Test') {
|
stage('Same agent') {
|
||||||
steps {
|
post {
|
||||||
sh "./gradlew " +
|
always {
|
||||||
"-DbuildId=\"\${BUILD_ID}\" " +
|
dir(sameAgentFolder) {
|
||||||
"-Dkubenetize=true " +
|
archiveArtifacts artifacts: '**/*.log', fingerprint: false
|
||||||
"-Ddocker.run.tag=\"\${DOCKER_TAG_TO_USE}\" " +
|
junit testResults: '**/build/test-results/**/*.xml', keepLongStdio: true
|
||||||
"-Dartifactory.username=\"\${ARTIFACTORY_CREDENTIALS_USR}\" " +
|
}
|
||||||
"-Dartifactory.password=\"\${ARTIFACTORY_CREDENTIALS_PSW}\" " +
|
}
|
||||||
"-Dgit.branch=\"\${GIT_BRANCH}\" " +
|
|
||||||
"-Dgit.target.branch=\"\${GIT_BRANCH}\" " +
|
|
||||||
" allParallelIntegrationTest --stacktrace"
|
|
||||||
}
|
}
|
||||||
}
|
stages {
|
||||||
stage('Smoke Test') {
|
stage('Integration Test') {
|
||||||
steps {
|
steps {
|
||||||
sh "./gradlew " +
|
dir(sameAgentFolder) {
|
||||||
"-DbuildId=\"\${BUILD_ID}\" " +
|
sh script: [
|
||||||
"-Dkubenetize=true " +
|
'./gradlew',
|
||||||
"-Ddocker.run.tag=\"\${DOCKER_TAG_TO_USE}\" " +
|
COMMON_GRADLE_PARAMS,
|
||||||
"-Dartifactory.username=\"\${ARTIFACTORY_CREDENTIALS_USR}\" " +
|
'integrationTest'
|
||||||
"-Dartifactory.password=\"\${ARTIFACTORY_CREDENTIALS_PSW}\" " +
|
].join(' ')
|
||||||
"-Dgit.branch=\"\${GIT_BRANCH}\" " +
|
}
|
||||||
"-Dgit.target.branch=\"\${GIT_BRANCH}\" " +
|
}
|
||||||
" allParallelSmokeTest --stacktrace"
|
}
|
||||||
}
|
|
||||||
}
|
stage('Deploy Node') {
|
||||||
stage('Slow Integration Test') {
|
steps {
|
||||||
steps {
|
dir(sameAgentFolder) {
|
||||||
sh "./gradlew " +
|
sh script: [
|
||||||
"-DbuildId=\"\${BUILD_ID}\" " +
|
'./gradlew',
|
||||||
"-Dkubenetize=true " +
|
COMMON_GRADLE_PARAMS,
|
||||||
"-Ddocker.run.tag=\"\${DOCKER_TAG_TO_USE}\" " +
|
'deployNode'
|
||||||
"-Dartifactory.username=\"\${ARTIFACTORY_CREDENTIALS_USR}\" " +
|
].join(' ')
|
||||||
"-Dartifactory.password=\"\${ARTIFACTORY_CREDENTIALS_PSW}\" " +
|
}
|
||||||
"-Dgit.branch=\"\${GIT_BRANCH}\" " +
|
}
|
||||||
"-Dgit.target.branch=\"\${GIT_BRANCH}\" " +
|
}
|
||||||
" allParallelSlowIntegrationTest --stacktrace"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
stage('Publish to Artifactory') {
|
stage('Publish to Artifactory') {
|
||||||
agent {
|
|
||||||
dockerfile {
|
|
||||||
reuseNode true
|
|
||||||
additionalBuildArgs "--build-arg USER=stresstester"
|
|
||||||
filename '.ci/dev/compatibility/DockerfileJDK11'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
when {
|
when {
|
||||||
expression { isReleaseTag }
|
expression { isReleaseTag }
|
||||||
}
|
}
|
||||||
steps {
|
steps {
|
||||||
rtServer(
|
dir(sameAgentFolder) {
|
||||||
id: 'R3-Artifactory',
|
rtServer(
|
||||||
url: 'https://software.r3.com/artifactory',
|
id: 'R3-Artifactory',
|
||||||
credentialsId: 'artifactory-credentials'
|
url: 'https://software.r3.com/artifactory',
|
||||||
)
|
credentialsId: 'artifactory-credentials'
|
||||||
rtGradleDeployer(
|
)
|
||||||
id: 'deployer',
|
rtGradleDeployer(
|
||||||
serverId: 'R3-Artifactory',
|
id: 'deployer',
|
||||||
repo: 'corda-releases'
|
serverId: 'R3-Artifactory',
|
||||||
)
|
repo: 'corda-releases'
|
||||||
rtGradleRun(
|
)
|
||||||
usesPlugin: true,
|
rtGradleRun(
|
||||||
useWrapper: true,
|
usesPlugin: true,
|
||||||
switches: '-s --info',
|
useWrapper: true,
|
||||||
tasks: 'artifactoryPublish',
|
switches: '-s --info',
|
||||||
deployerId: 'deployer',
|
tasks: 'artifactoryPublish',
|
||||||
buildName: env.ARTIFACTORY_BUILD_NAME
|
deployerId: 'deployer',
|
||||||
)
|
buildName: env.ARTIFACTORY_BUILD_NAME
|
||||||
rtPublishBuildInfo(
|
)
|
||||||
serverId: 'R3-Artifactory',
|
rtPublishBuildInfo(
|
||||||
buildName: env.ARTIFACTORY_BUILD_NAME
|
serverId: 'R3-Artifactory',
|
||||||
)
|
buildName: env.ARTIFACTORY_BUILD_NAME
|
||||||
|
)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
post {
|
post {
|
||||||
always {
|
|
||||||
archiveArtifacts artifacts: '**/pod-logs/**/*.log', fingerprint: false
|
|
||||||
junit testResults: '**/build/test-results-xml/**/*.xml', keepLongStdio: true
|
|
||||||
}
|
|
||||||
cleanup {
|
cleanup {
|
||||||
deleteDir() /* clean up our workspace */
|
deleteDir() /* clean up our workspace */
|
||||||
}
|
}
|
||||||
|
@ -1,3 +1,8 @@
|
|||||||
|
#!groovy
|
||||||
|
/**
|
||||||
|
* Jenkins pipeline to build Corda Opensource Pull Requests with JDK11.
|
||||||
|
*/
|
||||||
|
|
||||||
@Library('corda-shared-build-pipeline-steps')
|
@Library('corda-shared-build-pipeline-steps')
|
||||||
import static com.r3.build.BuildControl.killAllExistingBuildsForJob
|
import static com.r3.build.BuildControl.killAllExistingBuildsForJob
|
||||||
|
|
||||||
@ -6,8 +11,8 @@ killAllExistingBuildsForJob(env.JOB_NAME, env.BUILD_NUMBER.toInteger())
|
|||||||
pipeline {
|
pipeline {
|
||||||
agent {
|
agent {
|
||||||
dockerfile {
|
dockerfile {
|
||||||
label 'k8s'
|
label 'standard'
|
||||||
additionalBuildArgs "--build-arg USER=stresstester"
|
additionalBuildArgs '--build-arg USER="${USER}"' // DON'T change quotation - USER variable is substituted by SHELL!!!!
|
||||||
filename '.ci/dev/compatibility/DockerfileJDK11'
|
filename '.ci/dev/compatibility/DockerfileJDK11'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
183
.ci/dev/nightly-regression/Jenkinsfile
vendored
183
.ci/dev/nightly-regression/Jenkinsfile
vendored
@ -1,78 +1,167 @@
|
|||||||
|
#!groovy
|
||||||
|
/**
|
||||||
|
* Jenkins pipeline to build Corda Opensource nightly regression for feature branches.
|
||||||
|
*/
|
||||||
|
|
||||||
@Library('corda-shared-build-pipeline-steps')
|
@Library('corda-shared-build-pipeline-steps')
|
||||||
import static com.r3.build.BuildControl.killAllExistingBuildsForJob
|
import static com.r3.build.BuildControl.killAllExistingBuildsForJob
|
||||||
|
|
||||||
killAllExistingBuildsForJob(env.JOB_NAME, env.BUILD_NUMBER.toInteger())
|
killAllExistingBuildsForJob(env.JOB_NAME, env.BUILD_NUMBER.toInteger())
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Common Gradle arguments for all Gradle executions
|
||||||
|
*/
|
||||||
|
String COMMON_GRADLE_PARAMS = [
|
||||||
|
'--no-daemon',
|
||||||
|
'--stacktrace',
|
||||||
|
'--info',
|
||||||
|
'-Pcompilation.warningsAsErrors=false',
|
||||||
|
'-Ptests.failFast=true',
|
||||||
|
].join(' ')
|
||||||
|
|
||||||
pipeline {
|
pipeline {
|
||||||
agent { label 'k8s' }
|
agent { label 'standard' }
|
||||||
|
|
||||||
|
/*
|
||||||
|
* List options in alphabetical order
|
||||||
|
*/
|
||||||
options {
|
options {
|
||||||
timestamps()
|
|
||||||
overrideIndexTriggers(false)
|
|
||||||
timeout(time: 3, unit: 'HOURS')
|
|
||||||
buildDiscarder(logRotator(daysToKeepStr: '14', artifactDaysToKeepStr: '14'))
|
buildDiscarder(logRotator(daysToKeepStr: '14', artifactDaysToKeepStr: '14'))
|
||||||
|
overrideIndexTriggers(false)
|
||||||
|
parallelsAlwaysFailFast()
|
||||||
|
timeout(time: 6, unit: 'HOURS')
|
||||||
|
timestamps()
|
||||||
}
|
}
|
||||||
|
|
||||||
triggers {
|
triggers {
|
||||||
pollSCM ignorePostCommitHooks: true, scmpoll_spec: '@midnight'
|
pollSCM ignorePostCommitHooks: true, scmpoll_spec: '@midnight'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* List environment variables in alphabetical order
|
||||||
|
*/
|
||||||
environment {
|
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')
|
ARTIFACTORY_CREDENTIALS = credentials('artifactory-credentials')
|
||||||
CORDA_ARTIFACTORY_USERNAME = "${env.ARTIFACTORY_CREDENTIALS_USR}"
|
|
||||||
CORDA_ARTIFACTORY_PASSWORD = "${env.ARTIFACTORY_CREDENTIALS_PSW}"
|
CORDA_ARTIFACTORY_PASSWORD = "${env.ARTIFACTORY_CREDENTIALS_PSW}"
|
||||||
|
CORDA_ARTIFACTORY_USERNAME = "${env.ARTIFACTORY_CREDENTIALS_USR}"
|
||||||
}
|
}
|
||||||
|
|
||||||
stages {
|
stages {
|
||||||
stage('Deploy Nodes') {
|
stage('Compile') {
|
||||||
steps {
|
steps {
|
||||||
sh "./gradlew --no-daemon jar deployNodes"
|
sh script: [
|
||||||
|
'./gradlew',
|
||||||
|
COMMON_GRADLE_PARAMS,
|
||||||
|
'clean',
|
||||||
|
'jar'
|
||||||
|
].join(' ')
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
stage('Generate Build Image') {
|
stage('Stash') {
|
||||||
steps {
|
steps {
|
||||||
withCredentials([string(credentialsId: 'container_reg_passwd', variable: 'DOCKER_PUSH_PWD')]) {
|
stash name: 'compiled', useDefaultExcludes: false
|
||||||
sh "./gradlew " +
|
|
||||||
"-Dkubenetize=true " +
|
|
||||||
"-Ddocker.push.password=\"\${DOCKER_PUSH_PWD}\" " +
|
|
||||||
"-Ddocker.work.dir=\"/tmp/\${EXECUTOR_NUMBER}\" " +
|
|
||||||
"-Ddocker.container.env.parameter.CORDA_ARTIFACTORY_USERNAME=\"\${ARTIFACTORY_CREDENTIALS_USR}\" " +
|
|
||||||
"-Ddocker.container.env.parameter.CORDA_ARTIFACTORY_PASSWORD=\"\${ARTIFACTORY_CREDENTIALS_PSW}\" " +
|
|
||||||
"-Ddocker.build.tag=\"\${DOCKER_TAG_TO_USE}\"" +
|
|
||||||
" clean pushBuildImage --stacktrace"
|
|
||||||
}
|
|
||||||
sh "kubectl auth can-i get pods"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
stage('Testing phase') {
|
stage('All Tests') {
|
||||||
parallel {
|
parallel {
|
||||||
stage('Regression Test') {
|
stage('Another agent') {
|
||||||
steps {
|
agent {
|
||||||
sh "./gradlew " +
|
label 'standard'
|
||||||
"-DbuildId=\"\${BUILD_ID}\" " +
|
}
|
||||||
"-Dkubenetize=true " +
|
options {
|
||||||
"-Ddocker.run.tag=\"\${DOCKER_TAG_TO_USE}\" " +
|
skipDefaultCheckout true
|
||||||
"-Dartifactory.username=\"\${ARTIFACTORY_CREDENTIALS_USR}\" " +
|
}
|
||||||
"-Dartifactory.password=\"\${ARTIFACTORY_CREDENTIALS_PSW}\" " +
|
post {
|
||||||
"-Dgit.branch=\"\${GIT_BRANCH}\" " +
|
always {
|
||||||
"-Dgit.target.branch=\"\${GIT_BRANCH}\" " +
|
archiveArtifacts artifacts: '**/*.log', fingerprint: false
|
||||||
" parallelRegressionTest --stacktrace"
|
junit testResults: '**/build/test-results/**/*.xml', keepLongStdio: true
|
||||||
|
}
|
||||||
|
cleanup {
|
||||||
|
deleteDir() /* clean up our workspace */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stages {
|
||||||
|
stage('Unstash') {
|
||||||
|
steps {
|
||||||
|
unstash 'compiled'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stage('Recompile') {
|
||||||
|
steps {
|
||||||
|
sh script: [
|
||||||
|
'./gradlew',
|
||||||
|
COMMON_GRADLE_PARAMS,
|
||||||
|
'jar'
|
||||||
|
].join(' ')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stage('Unit Test') {
|
||||||
|
steps {
|
||||||
|
sh script: [
|
||||||
|
'./gradlew',
|
||||||
|
COMMON_GRADLE_PARAMS,
|
||||||
|
'test'
|
||||||
|
].join(' ')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stage('Proxy Integration Test') {
|
||||||
|
steps {
|
||||||
|
sh script: [
|
||||||
|
'./gradlew',
|
||||||
|
COMMON_GRADLE_PARAMS,
|
||||||
|
'proxyIntegrationTest'
|
||||||
|
].join(' ')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stage('Smoke Test') {
|
||||||
|
steps {
|
||||||
|
sh script: [
|
||||||
|
'./gradlew',
|
||||||
|
COMMON_GRADLE_PARAMS,
|
||||||
|
'smokeTest'
|
||||||
|
].join(' ')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stage('Slow Integration Test') {
|
||||||
|
steps {
|
||||||
|
sh script: [
|
||||||
|
'./gradlew',
|
||||||
|
COMMON_GRADLE_PARAMS,
|
||||||
|
'slowIntegrationTest'
|
||||||
|
].join(' ')
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
stage('Slow Integration Test') {
|
stage('Same agent') {
|
||||||
steps {
|
post {
|
||||||
sh "./gradlew " +
|
always {
|
||||||
"-DbuildId=\"\${BUILD_ID}\" " +
|
archiveArtifacts artifacts: '**/*.log', fingerprint: false
|
||||||
"-Dkubenetize=true " +
|
junit testResults: '**/build/test-results/**/*.xml', keepLongStdio: true
|
||||||
"-Ddocker.run.tag=\"\${DOCKER_TAG_TO_USE}\" " +
|
}
|
||||||
"-Dartifactory.username=\"\${ARTIFACTORY_CREDENTIALS_USR}\" " +
|
}
|
||||||
"-Dartifactory.password=\"\${ARTIFACTORY_CREDENTIALS_PSW}\" " +
|
stages {
|
||||||
"-Dgit.branch=\"\${GIT_BRANCH}\" " +
|
stage('Integration Test') {
|
||||||
"-Dgit.target.branch=\"\${GIT_BRANCH}\" " +
|
steps {
|
||||||
" allParallelSlowIntegrationTest --stacktrace"
|
sh script: [
|
||||||
|
'./gradlew',
|
||||||
|
COMMON_GRADLE_PARAMS,
|
||||||
|
'integrationTest'
|
||||||
|
].join(' ')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
stage('Deploy Node') {
|
||||||
|
steps {
|
||||||
|
sh script: [
|
||||||
|
'./gradlew',
|
||||||
|
COMMON_GRADLE_PARAMS,
|
||||||
|
'deployNode'
|
||||||
|
].join(' ')
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -80,10 +169,6 @@ pipeline {
|
|||||||
}
|
}
|
||||||
|
|
||||||
post {
|
post {
|
||||||
always {
|
|
||||||
archiveArtifacts artifacts: '**/pod-logs/**/*.log', fingerprint: false
|
|
||||||
junit testResults: '**/build/test-results-xml/**/*.xml', keepLongStdio: true
|
|
||||||
}
|
|
||||||
cleanup {
|
cleanup {
|
||||||
deleteDir() /* clean up our workspace */
|
deleteDir() /* clean up our workspace */
|
||||||
}
|
}
|
||||||
|
30
.ci/dev/pr-code-checks/Jenkinsfile
vendored
30
.ci/dev/pr-code-checks/Jenkinsfile
vendored
@ -11,20 +11,9 @@ pipeline {
|
|||||||
buildDiscarder(logRotator(daysToKeepStr: '14', artifactDaysToKeepStr: '14'))
|
buildDiscarder(logRotator(daysToKeepStr: '14', artifactDaysToKeepStr: '14'))
|
||||||
}
|
}
|
||||||
|
|
||||||
environment {
|
|
||||||
PR_CONTEXT_STRING = "PR Code Checks"
|
|
||||||
}
|
|
||||||
|
|
||||||
stages {
|
stages {
|
||||||
stage('Detekt check') {
|
stage('Detekt check') {
|
||||||
steps {
|
steps {
|
||||||
script {
|
|
||||||
pullRequest.createStatus(
|
|
||||||
status: 'pending',
|
|
||||||
context: "${PR_CONTEXT_STRING}",
|
|
||||||
description: "Running code checks",
|
|
||||||
targetUrl: "${env.BUILD_URL}")
|
|
||||||
}
|
|
||||||
sh "./gradlew --no-daemon clean detekt"
|
sh "./gradlew --no-daemon clean detekt"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -50,25 +39,6 @@ pipeline {
|
|||||||
}
|
}
|
||||||
|
|
||||||
post {
|
post {
|
||||||
success {
|
|
||||||
script {
|
|
||||||
pullRequest.createStatus(
|
|
||||||
status: 'success',
|
|
||||||
context: "${PR_CONTEXT_STRING}",
|
|
||||||
description: 'Code checks passed',
|
|
||||||
targetUrl: "${env.BUILD_URL}")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
failure {
|
|
||||||
script {
|
|
||||||
pullRequest.createStatus(
|
|
||||||
status: 'failure',
|
|
||||||
context: "${PR_CONTEXT_STRING}",
|
|
||||||
description: 'Code checks failed',
|
|
||||||
targetUrl: "${env.BUILD_URL}")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
cleanup {
|
cleanup {
|
||||||
deleteDir() /* clean up our workspace */
|
deleteDir() /* clean up our workspace */
|
||||||
}
|
}
|
||||||
|
@ -1,11 +1,15 @@
|
|||||||
#!groovy
|
#!groovy
|
||||||
|
/**
|
||||||
|
* Jenkins pipeline to build Corda Opensource Preview.
|
||||||
|
*/
|
||||||
|
|
||||||
@Library('corda-shared-build-pipeline-steps')
|
@Library('corda-shared-build-pipeline-steps')
|
||||||
import static com.r3.build.BuildControl.killAllExistingBuildsForJob
|
import static com.r3.build.BuildControl.killAllExistingBuildsForJob
|
||||||
|
|
||||||
killAllExistingBuildsForJob(env.JOB_NAME, env.BUILD_NUMBER.toInteger())
|
killAllExistingBuildsForJob(env.JOB_NAME, env.BUILD_NUMBER.toInteger())
|
||||||
|
|
||||||
pipeline {
|
pipeline {
|
||||||
agent { label 'k8s' }
|
agent { label 'standard' }
|
||||||
|
|
||||||
options {
|
options {
|
||||||
timestamps()
|
timestamps()
|
||||||
|
158
Jenkinsfile
vendored
158
Jenkinsfile
vendored
@ -1,73 +1,133 @@
|
|||||||
import static com.r3.build.BuildControl.killAllExistingBuildsForJob
|
#!groovy
|
||||||
|
/**
|
||||||
|
* Jenkins pipeline to build Corda Opensource Pull Requests.
|
||||||
|
*/
|
||||||
|
|
||||||
@Library('corda-shared-build-pipeline-steps')
|
@Library('corda-shared-build-pipeline-steps')
|
||||||
import static com.r3.build.BuildControl.killAllExistingBuildsForJob
|
import static com.r3.build.BuildControl.killAllExistingBuildsForJob
|
||||||
|
|
||||||
killAllExistingBuildsForJob(env.JOB_NAME, env.BUILD_NUMBER.toInteger())
|
killAllExistingBuildsForJob(env.JOB_NAME, env.BUILD_NUMBER.toInteger())
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Common Gradle arguments for all Gradle executions
|
||||||
|
*/
|
||||||
|
String COMMON_GRADLE_PARAMS = [
|
||||||
|
'--no-daemon',
|
||||||
|
'--stacktrace',
|
||||||
|
'--info',
|
||||||
|
/*
|
||||||
|
** revert default behavour for `ignoreFailures` and
|
||||||
|
** do not ignore test failures in PR builds
|
||||||
|
*/
|
||||||
|
'-Ptests.ignoreFailures=false',
|
||||||
|
'-Pcompilation.warningsAsErrors=false',
|
||||||
|
'-Ptests.failFast=true',
|
||||||
|
'-Ddependx.branch.origin="${GIT_COMMIT}"', // DON'T change quotation - GIT_COMMIT variable is substituted by SHELL!!!!
|
||||||
|
'-Ddependx.branch.target="${CHANGE_TARGET}"', // DON'T change quotation - CHANGE_TARGET variable is substituted by SHELL!!!!
|
||||||
|
].join(' ')
|
||||||
|
|
||||||
pipeline {
|
pipeline {
|
||||||
agent { label 'k8s' }
|
agent { label 'standard' }
|
||||||
|
|
||||||
|
/*
|
||||||
|
* List options in alphabetical order
|
||||||
|
*/
|
||||||
options {
|
options {
|
||||||
timestamps()
|
ansiColor('xterm')
|
||||||
timeout(time: 3, unit: 'HOURS')
|
|
||||||
buildDiscarder(logRotator(daysToKeepStr: '14', artifactDaysToKeepStr: '14'))
|
buildDiscarder(logRotator(daysToKeepStr: '14', artifactDaysToKeepStr: '14'))
|
||||||
|
parallelsAlwaysFailFast()
|
||||||
|
timeout(time: 6, unit: 'HOURS')
|
||||||
|
timestamps()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* List environment variables in alphabetical order
|
||||||
|
*/
|
||||||
environment {
|
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')
|
ARTIFACTORY_CREDENTIALS = credentials('artifactory-credentials')
|
||||||
CORDA_ARTIFACTORY_USERNAME = "${env.ARTIFACTORY_CREDENTIALS_USR}"
|
|
||||||
CORDA_ARTIFACTORY_PASSWORD = "${env.ARTIFACTORY_CREDENTIALS_PSW}"
|
CORDA_ARTIFACTORY_PASSWORD = "${env.ARTIFACTORY_CREDENTIALS_PSW}"
|
||||||
|
CORDA_ARTIFACTORY_USERNAME = "${env.ARTIFACTORY_CREDENTIALS_USR}"
|
||||||
}
|
}
|
||||||
|
|
||||||
stages {
|
stages {
|
||||||
stage('Corda Pull Request - Generate Build Image') {
|
stage('Compile') {
|
||||||
steps {
|
steps {
|
||||||
withCredentials([string(credentialsId: 'container_reg_passwd', variable: 'DOCKER_PUSH_PWD')]) {
|
sh script: [
|
||||||
sh "./gradlew --no-daemon " +
|
'./gradlew',
|
||||||
"-Dkubenetize=true " +
|
COMMON_GRADLE_PARAMS,
|
||||||
"-Ddocker.push.password=\"\${DOCKER_PUSH_PWD}\" " +
|
'clean',
|
||||||
"-Ddocker.work.dir=\"/tmp/\${EXECUTOR_NUMBER}\" " +
|
'jar'
|
||||||
"-Ddocker.container.env.parameter.CORDA_ARTIFACTORY_USERNAME=\"\${ARTIFACTORY_CREDENTIALS_USR}\" " +
|
].join(' ')
|
||||||
"-Ddocker.container.env.parameter.CORDA_ARTIFACTORY_PASSWORD=\"\${ARTIFACTORY_CREDENTIALS_PSW}\" " +
|
|
||||||
"-Ddocker.build.tag=\"\${DOCKER_TAG_TO_USE}\"" +
|
|
||||||
" clean preAllocateForAllParallelUnitTest preAllocateForAllParallelIntegrationTest pushBuildImage --stacktrace"
|
|
||||||
}
|
|
||||||
sh "kubectl auth can-i get pods"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
stage('Corda Pull Request - Run Tests') {
|
stage('Stash') {
|
||||||
|
steps {
|
||||||
|
stash name: 'compiled', useDefaultExcludes: false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
stage('All Tests') {
|
||||||
parallel {
|
parallel {
|
||||||
stage('Integration Tests') {
|
stage('Another agent') {
|
||||||
steps {
|
agent {
|
||||||
sh "./gradlew --no-daemon " +
|
label 'standard'
|
||||||
"-DbuildId=\"\${BUILD_ID}\" " +
|
}
|
||||||
"-Dkubenetize=true " +
|
options {
|
||||||
"-Ddocker.run.tag=\"\${DOCKER_TAG_TO_USE}\" " +
|
skipDefaultCheckout true
|
||||||
"-Dartifactory.username=\"\${ARTIFACTORY_CREDENTIALS_USR}\" " +
|
}
|
||||||
"-Dartifactory.password=\"\${ARTIFACTORY_CREDENTIALS_PSW}\" " +
|
post {
|
||||||
"-Dgit.branch=\"\${GIT_BRANCH}\" " +
|
always {
|
||||||
"-Dgit.target.branch=\"\${CHANGE_TARGET}\" " +
|
archiveArtifacts artifacts: '**/*.log', fingerprint: false
|
||||||
"-Ddependx.branch.origin=${env.GIT_COMMIT} " +
|
junit testResults: '**/build/test-results/**/*.xml', keepLongStdio: true
|
||||||
"-Ddependx.branch.target=${CHANGE_TARGET} " +
|
}
|
||||||
" allParallelIntegrationTest --stacktrace"
|
cleanup {
|
||||||
|
deleteDir() /* clean up our workspace */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stages {
|
||||||
|
stage('Unstash') {
|
||||||
|
steps {
|
||||||
|
unstash 'compiled'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stage('Recompile') {
|
||||||
|
steps {
|
||||||
|
sh script: [
|
||||||
|
'./gradlew',
|
||||||
|
COMMON_GRADLE_PARAMS,
|
||||||
|
'jar'
|
||||||
|
].join(' ')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stage('Unit Test') {
|
||||||
|
steps {
|
||||||
|
sh script: [
|
||||||
|
'./gradlew',
|
||||||
|
COMMON_GRADLE_PARAMS,
|
||||||
|
'test'
|
||||||
|
].join(' ')
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
stage('Unit Tests') {
|
stage('Same agent') {
|
||||||
steps {
|
post {
|
||||||
sh "./gradlew --no-daemon " +
|
always {
|
||||||
"-DbuildId=\"\${BUILD_ID}\" " +
|
archiveArtifacts artifacts: '**/*.log', fingerprint: false
|
||||||
"-Dkubenetize=true " +
|
junit testResults: '**/build/test-results/**/*.xml', keepLongStdio: true
|
||||||
"-Ddocker.run.tag=\"\${DOCKER_TAG_TO_USE}\" " +
|
}
|
||||||
"-Dartifactory.username=\"\${ARTIFACTORY_CREDENTIALS_USR}\" " +
|
}
|
||||||
"-Dartifactory.password=\"\${ARTIFACTORY_CREDENTIALS_PSW}\" " +
|
stages {
|
||||||
"-Dgit.branch=\"\${GIT_BRANCH}\" " +
|
stage('Integration Test') {
|
||||||
"-Dgit.target.branch=\"\${CHANGE_TARGET}\" " +
|
steps {
|
||||||
"-Ddependx.branch.origin=${env.GIT_COMMIT} " +
|
sh script: [
|
||||||
"-Ddependx.branch.target=${CHANGE_TARGET} " +
|
'./gradlew',
|
||||||
" allParallelUnitTest --stacktrace"
|
COMMON_GRADLE_PARAMS,
|
||||||
|
'integrationTest'
|
||||||
|
].join(' ')
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -75,10 +135,6 @@ pipeline {
|
|||||||
}
|
}
|
||||||
|
|
||||||
post {
|
post {
|
||||||
always {
|
|
||||||
archiveArtifacts artifacts: '**/pod-logs/**/*.log', fingerprint: false
|
|
||||||
junit testResults: '**/build/test-results-xml/**/*.xml', keepLongStdio: true
|
|
||||||
}
|
|
||||||
cleanup {
|
cleanup {
|
||||||
deleteDir() /* clean up our workspace */
|
deleteDir() /* clean up our workspace */
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user