2024-05-06 07:26:01 -04:00
@Library('hibernate-jenkins-pipeline-helpers@1.13') _
2022-02-23 07:18:03 -05:00
2022-05-12 06:44:38 -04:00
// Avoid running the pipeline on branch indexing
if (currentBuild.getBuildCauses().toString().contains('BranchIndexingCause')) {
2023-10-06 09:01:00 -04:00
print "INFO: Build skipped due to trigger being Branch Indexing"
currentBuild.result = 'NOT_BUILT'
return
2022-05-12 06:44:38 -04:00
}
2023-10-09 10:05:39 -04:00
def throttleCount
// Don't build the TCK on PRs, unless they use the tck label
if ( env.CHANGE_ID != null ) {
if ( !pullRequest.labels.contains( 'tck' ) ) {
print "INFO: Build skipped because pull request doesn't have 'tck' label"
return
}
throttleCount = 20
}
else {
throttleCount = 1
}
2022-05-12 06:44:38 -04:00
2022-02-23 07:18:03 -05:00
pipeline {
agent {
label 'LongDuration'
}
tools {
2024-04-19 07:48:28 -04:00
jdk 'OpenJDK 17 Latest'
2022-02-23 07:18:03 -05:00
}
2022-04-25 10:06:53 -04:00
options {
2023-10-09 10:05:39 -04:00
rateLimitBuilds(throttle: [count: throttleCount, durationName: 'day', userBoost: true])
2022-04-25 10:06:53 -04:00
buildDiscarder(logRotator(numToKeepStr: '3', artifactNumToKeepStr: '3'))
2022-05-12 06:44:38 -04:00
disableConcurrentBuilds(abortPrevious: true)
2022-04-25 10:06:53 -04:00
}
2022-02-23 07:18:03 -05:00
parameters {
2024-04-29 05:16:39 -04:00
choice(name: 'IMAGE_JDK', choices: ['jdk17', 'jdk21'], description: 'The JDK base image version to use for the TCK image.')
2024-04-19 07:48:28 -04:00
string(name: 'TCK_VERSION', defaultValue: '3.2.0', description: 'The version of the Jakarta JPA TCK i.e. `2.2.0` or `3.0.1`')
string(name: 'TCK_SHA', defaultValue: '', description: 'The SHA256 of the Jakarta JPA TCK that is distributed under https://download.eclipse.org/jakartaee/persistence/3.1/jakarta-persistence-tck-${TCK_VERSION}.zip.sha256')
string(name: 'TCK_URL', defaultValue: 'https://www.eclipse.org/downloads/download.php?file=/ee4j/jakartaee-tck/jakartaee11/staged/eftl/jakarta-persistence-tck-3.2.0.zip&mirror_id=1', description: 'The URL from which to download the TCK ZIP file. Only needed for testing staged builds. Ensure the TCK_VERSION variable matches the ZIP file name suffix.')
2024-04-29 05:16:39 -04:00
choice(name: 'RDBMS', choices: ['derby','mysql','mssql','oracle','postgresql','db2','sybase'], description: 'The JDK base image version to use for the TCK image.')
2022-02-23 07:18:03 -05:00
}
stages {
stage('Build') {
steps {
script {
docker.withRegistry('https://index.docker.io/v1/', 'hibernateci.hub.docker.com') {
2024-04-19 07:48:28 -04:00
docker.image('openjdk:17-jdk').pull()
2022-02-23 07:18:03 -05:00
}
}
dir('hibernate') {
checkout scm
2024-04-19 07:48:28 -04:00
sh './gradlew publishToMavenLocal -PmavenMirror=nexus-load-balancer-c4cf05fd92f43ef8.elb.us-east-1.amazonaws.com'
2022-02-23 07:18:03 -05:00
script {
env.HIBERNATE_VERSION = sh (
script: "grep hibernateVersion gradle/version.properties|cut -d'=' -f2",
returnStdout: true
).trim()
}
}
dir('tck') {
checkout changelog: false, poll: false, scm: [$class: 'GitSCM', branches: [[name: '*/main']], extensions: [], userRemoteConfigs: [[url: 'https://github.com/hibernate/jakarta-tck-runner.git']]]
2024-03-07 05:30:13 -05:00
script {
2024-04-29 05:16:39 -04:00
switch (params.RDBMS) {
case "mysql":
docker.withRegistry('https://index.docker.io/v1/', 'hibernateci.hub.docker.com') {
docker.image('mysql:8.2.0').pull()
}
sh "./docker_db.sh mysql"
break;
case "mssql":
docker.image('mcr.microsoft.com/mssql/server@sha256:5439be9edc3b514cf647bcd3651779fa13f487735a985f40cbdcfecc60fea273').pull()
sh "./docker_db.sh mssql"
break;
case "oracle":
docker.withRegistry('https://index.docker.io/v1/', 'hibernateci.hub.docker.com') {
docker.image('gvenzl/oracle-free:23').pull()
}
sh "./docker_db.sh oracle"
break;
case "postgresql":
docker.withRegistry('https://index.docker.io/v1/', 'hibernateci.hub.docker.com') {
docker.image('postgis/postgis:16-3.4').pull()
}
sh "./docker_db.sh postgresql"
break;
case "db2":
docker.image('icr.io/db2_community/db2:11.5.9.0').pull()
sh "./docker_db.sh db2"
break;
case "sybase":
docker.withRegistry('https://index.docker.io/v1/', 'hibernateci.hub.docker.com') {
docker.image('nguoianphu/docker-sybase').pull()
}
sh "./docker_db.sh sybase"
break;
2024-03-07 05:30:13 -05:00
}
2024-04-29 05:16:39 -04:00
withCredentials([file(credentialsId: 'sybase-jconnect-driver', variable: 'jconnect_driver')]) {
sh 'cp -f $jconnect_driver ./jpa-3.2/jconn42.jar'
if ( params.TCK_URL == null || params.TCK_URL.isEmpty() ) {
sh "cd jpa-3.2; docker build -f Dockerfile.${params.IMAGE_JDK} -t jakarta-tck-runner --build-arg TCK_VERSION=${params.TCK_VERSION} --build-arg TCK_SHA=${params.TCK_SHA} ."
}
else {
2024-04-30 08:27:30 -04:00
sh "cd jpa-3.2; docker build -f Dockerfile.${params.IMAGE_JDK} -t jakarta-tck-runner --build-arg TCK_VERSION=${params.TCK_VERSION} --build-arg TCK_SHA=${params.TCK_SHA} --build-arg 'TCK_URL=${params.TCK_URL}' ."
2024-04-29 05:16:39 -04:00
}
2024-03-07 05:30:13 -05:00
}
}
2022-02-23 07:18:03 -05:00
}
}
}
stage('Run TCK') {
steps {
2024-04-30 07:33:10 -04:00
script {
def containerName
if ( params.RDBMS == 'postgresql' ) {
containerName = 'postgres'
}
else {
containerName = params.RDBMS
}
sh """ \
rm -Rf ./results
docker rm -f tck || true
while IFS= read -r container; do
docker network disconnect tck-net \$container || true
2024-04-30 08:31:06 -04:00
done <<< \$(docker network inspect tck-net --format '{{range \$k, \$v := .Containers}}{{print \$k}}{{end}}' 2>/dev/null || true)
2024-04-30 07:33:10 -04:00
docker network rm -f tck-net
docker network create tck-net
docker network connect tck-net ${containerName}
docker run -v ~/.m2/repository/org/hibernate:/root/.m2/repository/org/hibernate:z --network=tck-net -e DB_HOST=${containerName} -e RDBMS=${params.RDBMS} -e HIBERNATE_VERSION=$HIBERNATE_VERSION --name tck jakarta-tck-runner
docker cp tck:/tck/persistence-tck/bin/target/failsafe-reports ./results
docker cp tck:/tck/persistence-tck/bin/target/test-reports ./results
"""
2024-04-29 05:16:39 -04:00
}
2022-02-23 07:18:03 -05:00
archiveArtifacts artifacts: 'results/**'
script {
failures = sh (
script: """ \
while read line; do
2024-04-29 05:16:39 -04:00
if [[ "\$line" = *"-error\" style=\"display:none;\">" ]]; then
prefix1='<tr class="a" id="'
prefix2='<tr class="b" id="'
suffix='-error" style="display:none;">'
line=\${line#"\$prefix1"}
line=\${line#"\$prefix2"}
test=\${line%"\$suffix"}
echo "\$test"
2022-02-23 07:18:03 -05:00
fi
2024-04-29 05:16:39 -04:00
done <results/test-reports/failsafe-report.html
2022-02-23 07:18:03 -05:00
""",
returnStdout: true
).trim()
if ( !failures.isEmpty() ) {
echo "Some TCK tests failed:"
echo failures
currentBuild.result = 'FAILURE'
}
}
}
}
}
post {
always {
2024-04-29 05:16:39 -04:00
script {
2024-04-30 07:33:10 -04:00
def containerName
2024-04-29 05:16:39 -04:00
if ( params.RDBMS == 'postgresql' ) {
containerName = 'postgres'
}
else {
containerName = params.RDBMS
}
sh "docker rm -f ${containerName}"
}
2022-05-12 06:44:38 -04:00
configFileProvider([configFile(fileId: 'job-configuration.yaml', variable: 'JOB_CONFIGURATION_FILE')]) {
notifyBuildResult maintainers: (String) readYaml(file: env.JOB_CONFIGURATION_FILE).notification?.email?.recipients
}
2022-02-23 07:18:03 -05:00
}
}
}