blob: 6cd8bd0d92d9c7ad7d46cdaf9be21082940d579d [file] [log] [blame]
@Library('jenkins-pipeline-shared-libraries')_
helper = null
KIND_VERSION = "v0.20.0"
kindClusterPlatform = 'kind'
openshiftClusterPlatform = 'openshift'
kindLogsFolder = "/tmp/kind-logs"
pipeline {
agent {
docker {
image env.AGENT_DOCKER_BUILDER_IMAGE
args env.AGENT_DOCKER_BUILDER_ARGS
label util.avoidFaultyNodes()
}
}
options {
timeout(time: 3, unit: 'HOURS')
timestamps()
}
stages {
stage('Setup pipeline') {
steps {
script {
helper = load '.ci/jenkins/scripts/helper.groovy'
helper.initPipeline()
}
}
}
stage('Initialize') {
steps {
script {
clean()
helper.updateDisplayName()
helper.checkoutRepo()
assert getTestImage(): 'Please provide a Test image'
container.pullImage(getTestImage()) // Verify image exists
}
}
}
stage('Setup cluster') {
steps {
script {
setupCluster()
}
}
}
stage('Load image into Kind') {
when {
expression {
return getClusterName() == kindClusterPlatform
}
}
steps {
script {
kind.loadImage(getTestImage())
}
}
}
stage('Deploy the operator') {
when {
expression {
return getClusterName() == kindClusterPlatform
}
}
steps {
script {
sh "make deploy IMG=${getTestImage()}"
sh "kubectl wait pod -A -l control-plane=sonataflow-operator --for condition=Ready --timeout=120s"
}
}
}
stage('Prepare for e2e tests') {
when {
expression {
return helper.shouldLaunchTests() && helper.isRelease()
}
}
steps {
script {
// Define specific tests images as those to override defaults
// Because released builder and devmode images are not yet available
String platformCRFilepath = getPlatformCRFilePath()
String[] versionSplit = getOperatorVersion().split("\\.")
String majorMinor = "${versionSplit[0]}.${versionSplit[1]}"
def platformCR = readYaml(file: platformCRFilepath)
platformCR.spec.devMode = platformCR.spec.devMode ?: [:]
platformCR.spec.devMode.baseImage = "docker.io/apache/incubator-kie-sonataflow-devmode:${majorMinor}"
platformCR.spec.build = platformCR.spec.build ?: [:]
platformCR.spec.build.config = platformCR.spec.build.config ?: [:]
platformCR.spec.build.config.baseImage = "docker.io/apache/incubator-kie-sonataflow-builder:${majorMinor}"
writeYaml(file: platformCRFilepath, data: platformCR, overwrite: true)
}
}
}
stage('Run e2e tests') {
steps {
script {
executeInCluster {
try {
sh """
export CLUSTER_PLATFORM=${getClusterName()}
export OPERATOR_IMAGE_NAME=${getTestImage()}
make test-e2e
"""
} catch (err) {
kind.exportLogs(kindLogsFolder)
sh 'make undeploy'
deleteKindCluster()
throw err
}
sh 'kubectl get pods -A'
deleteKindCluster()
}
}
}
}
}
post {
always {
script {
archiveArtifacts(artifacts: "**${kindLogsFolder}/**/*.*,**/e2e-test-report.xml")
junit '**/e2e-test-report.xml'
}
}
cleanup {
script {
clean()
}
}
}
}
void clean() {
helper.cleanGoPath()
util.cleanNode(containerEngine)
}
String getTestImage() {
return params.TEST_IMAGE_FULL_TAG
}
String getClusterName() {
return env.CLUSTER_NAME
}
String getOperatorVersion() {
return sh(script: 'source ./hack/env.sh > /dev/null && echo $(getOperatorVersion)', returnStdout: true).trim()
}
void setupCluster() {
switch (getClusterName()) {
case kindClusterPlatform:
echo 'Creating kind cluster'
createKindCluster()
break
case openshiftClusterPlatform:
echo 'Setting up Openshift'
setupOpenshift()
break
default:
error "Unknown cluster name ${getClusterName()}. Cannot prepare for it ..."
}
}
void createKindCluster() {
sh(script: "make KIND_VERSION=${KIND_VERSION} create-cluster", returnStdout: true)
}
void deleteKindCluster() {
sh(script: "make delete-cluster", returnStdout: true)
}
void setupOpenshift() {
// Login to Openshift
openshift.loginOpenshift()
}
void cleanupCluster() {
switch (getClusterName()) {
case kindClusterPlatform:
echo 'Deleting kind cluster'
deleteKindCluster()
break
case openshiftClusterPlatform:
echo 'Nothing to cleanup on openshift. All good !'
break
default:
error "Unknown cluster name ${getClusterName()}. Cannot cleanup ..."
}
}
void executeInCluster(Closure executeClosure) {
switch (getClusterName()) {
case kindClusterPlatform:
echo "Execute in kind"
executeClosure()
break
case openshiftClusterPlatform:
echo "Execute in openshift"
lock("Sonataflow Operator OpenShift tests ${getOpenshiftApi()}") {
executeClosure()
}
break
default:
error "Unknown cluster name ${getClusterName()}. Cannot execute anything ..."
}
}
void getPlatformCRFilePath() {
switch (getClusterName()) {
case kindClusterPlatform:
return 'test/testdata/sonataflow.org_v1alpha08_sonataflowplatform_withCache_minikube.yaml'
case openshiftClusterPlatform:
return 'test/testdata/sonataflow.org_v1alpha08_sonataflowplatform_openshift.yaml'
default:
error "Unknown cluster name ${getClusterName()}. Cannot execute anything ..."
}
}
// Special method to get the Openshift API in the lock because env is not accessible yet
void getOpenshiftApi() {
withCredentials([string(credentialsId: env.OPENSHIFT_API_KEY, variable: 'OPENSHIFT_API')]) {
return env.OPENSHIFT_API
}
}