blob: bbce7c966a1a36851b3e7111ff5ac203aba422f2 [file] [log] [blame]
@Library('tcp-qa')_
import groovy.xml.XmlUtil
common = new com.mirantis.mk.Common()
shared = new com.mirantis.system_qa.SharedPipeline()
NODE_LABEL = env.NODE_LABEL ?: "sre-team-infra"
MAINTENANCE_TEAM_SSH_ID = env.MAINTENANCE_TEAM_SSH_ID ?: 'maintenance-team-ssh'
//IPMI_CREDS = 'lab_engineer' // base bm lab
seed_ext_ip = env.SEED_EXT_IP ?: '172.16.180.2'
ssh_params = "-o ConnectTimeout=20 -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null"
kubectl_openstack_cmd = "ssh ${ssh_params} root@${seed_ext_ip} /root/kaas-bootstrap/bin/kubectl --kubeconfig /root/child.kubeconfig -n openstack "
timeout(time: 6, unit: 'HOURS') {
timestamps {
node ("${NODE_LABEL}") {
checkout scm
shared.update_working_dir()
sshagent(credentials: ['maintenance-team-ssh']) {
withCredentials(
[[$class: 'SSHUserPrivateKeyBinding',
keyFileVariable: "MAINTENANCE_TEAM_SSH_KEY",
credentialsId: MAINTENANCE_TEAM_SSH_ID,
usernameVariable: "MAINTENANCE_TEAM_SSH_USERNAME"]]) {
stage("Delete old tempest pod") {
cmd_get_service_list_wo_tempest = "${kubectl_openstack_cmd} get osdpl osh-dev -o jsonpath='{.spec.features.services}' | jq 'del(.[index(\\\"tempest\\\")])' "
try {
service_list_wo_tempest = sh(returnStdout: true, script: "${cmd_get_service_list_wo_tempest}").trim()
sh "${kubectl_openstack_cmd} patch osdpl osh-dev --type merge -p '{\\\"spec\\\":{\\\"features\\\":{\\\"services\\\":${service_list_wo_tempest}}}}'"
sleep 60
}
catch(Exception e) {
println("Tempest not included in services (Exception: ${e}")}
}
stage("Tempest configuration and run") {
sh "${kubectl_openstack_cmd} patch osdpl osh-dev --type merge -p '{\\\"spec\\\":{\\\"features\\\":{\\\"services\\\":[\\\"tempest\\\"]}}}'"
tempest_pod_name_cmd = "ssh ${ssh_params} root@${seed_ext_ip} '/root/kaas-bootstrap/bin/kubectl --kubeconfig /root/child.kubeconfig -n openstack get pods -o custom-columns=POD:.metadata.name --no-headers | grep openstack-tempest-run-tests'"
tempest_pod_name = ''
while(tempest_pod_name==''){
try{
tempest_pod_name = sh(returnStdout: true, script: "${tempest_pod_name_cmd}").trim()
} catch(Exception e) {
println("Wait tempest pod start (Exception: ${e}")}
sleep 30
}
tempest_check_cmd = "ssh ${ssh_params} root@${seed_ext_ip} '/root/kaas-bootstrap/bin/kubectl --kubeconfig /root/child.kubeconfig -n openstack get -o jsonpath=\'{.status.phase}\' pod/${tempest_pod_name}'"
status = ""
while (status != "Succeeded"){ //Completed
status = sh(returnStdout: true, script: "${tempest_check_cmd}").trim()
println("Tempest pod status is ${status}")
sleep 60
}
} //stage tempest
stage("Run archive artifacts job") {
def deploy = build job: 'mosk-archive-artifacts',
parameters: [
string(name: 'NODE_LABEL', value: NODE_LABEL),
string(name: 'MAINTENANCE_TEAM_SSH_ID', value: MAINTENANCE_TEAM_SSH_ID),
string(name: 'TCP_QA_REFS', value: env.TCP_QA_REFS),
string(name: 'SEED_EXT_IP', value: seed_ext_ip)
],
wait: false,
propagate: false
}
} //withCredentials
} //sshagent
} //node
} //timestamps
} //timeout