mirror of
https://github.com/valitydev/salt.git
synced 2024-11-09 01:36:48 +00:00
27c7ac94b7
The centos7-py2 tests have been consistently failing to finish before the timeout. I am increasing the timeout for these tests to 8 hours in order to see if we can finish a few of them. They should get much closer to finishing as the branch tests have been finishing at around the 6:30 or 7:00 mark sometimes.
86 lines
4.8 KiB
Plaintext
86 lines
4.8 KiB
Plaintext
timeout(time: 8, unit: 'HOURS') {
|
|
node('kitchen-slave') {
|
|
timestamps {
|
|
ansiColor('xterm') {
|
|
withEnv([
|
|
'SALT_KITCHEN_PLATFORMS=/var/jenkins/workspace/platforms.yml',
|
|
'SALT_KITCHEN_DRIVER=/var/jenkins/workspace/driver.yml',
|
|
'PATH=/usr/local/rbenv/shims/:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin:/root/bin',
|
|
'RBENV_VERSION=2.4.2',
|
|
'TEST_SUITE=py2',
|
|
'TEST_PLATFORM=centos-7',
|
|
'PY_COLORS=1',
|
|
]) {
|
|
stage('checkout-scm') {
|
|
cleanWs notFailBuild: true
|
|
checkout scm
|
|
}
|
|
try {
|
|
stage('github-pending') {
|
|
githubNotify credentialsId: 'test-jenkins-credentials',
|
|
description: "running ${TEST_SUITE}-${TEST_PLATFORM}...",
|
|
status: 'PENDING',
|
|
context: "jenkins/pr/${TEST_SUITE}-${TEST_PLATFORM}"
|
|
}
|
|
stage('setup-bundle') {
|
|
sh 'bundle install --with ec2 windows --without opennebula docker'
|
|
}
|
|
try {
|
|
stage('run kitchen') {
|
|
withCredentials([
|
|
[$class: 'AmazonWebServicesCredentialsBinding', accessKeyVariable: 'AWS_ACCESS_KEY_ID', credentialsId: 'AWS_ACCESS_KEY_ID', secretKeyVariable: 'AWS_SECRET_ACCESS_KEY']
|
|
]) {
|
|
sshagent(credentials: ['jenkins-testing-ssh-key']) {
|
|
sh 'ssh-add ~/.ssh/jenkins-testing.pem'
|
|
sh 'bundle exec kitchen converge $TEST_SUITE-$TEST_PLATFORM || bundle exec kitchen converge $TEST_SUITE-$TEST_PLATFORM'
|
|
sh 'bundle exec kitchen verify $TEST_SUITE-$TEST_PLATFORM'
|
|
}
|
|
}
|
|
}
|
|
} finally {
|
|
stage('cleanup kitchen') {
|
|
script {
|
|
withCredentials([
|
|
[$class: 'AmazonWebServicesCredentialsBinding', accessKeyVariable: 'AWS_ACCESS_KEY_ID', credentialsId: 'AWS_ACCESS_KEY_ID', secretKeyVariable: 'AWS_SECRET_ACCESS_KEY']
|
|
]) {
|
|
sshagent(credentials: ['jenkins-testing-ssh-key']) {
|
|
sh 'ssh-add ~/.ssh/jenkins-testing.pem'
|
|
sh 'bundle exec kitchen destroy $TEST_SUITE-$TEST_PLATFORM'
|
|
}
|
|
}
|
|
}
|
|
archiveArtifacts artifacts: 'artifacts/xml-unittests-output/*.xml'
|
|
archiveArtifacts artifacts: 'artifacts/logs/minion'
|
|
archiveArtifacts artifacts: 'artifacts/logs/salt-runtests.log'
|
|
}
|
|
}
|
|
} catch (Exception e) {
|
|
currentBuild.result = 'FAILURE'
|
|
} finally {
|
|
try {
|
|
junit 'artifacts/xml-unittests-output/*.xml'
|
|
} finally {
|
|
cleanWs notFailBuild: true
|
|
def currentResult = currentBuild.result ?: 'SUCCESS'
|
|
if (currentResult == 'SUCCESS') {
|
|
githubNotify credentialsId: 'test-jenkins-credentials',
|
|
description: "The ${TEST_SUITE}-${TEST_PLATFORM} job has passed",
|
|
status: 'SUCCESS',
|
|
context: "jenkins/pr/${TEST_SUITE}-${TEST_PLATFORM}"
|
|
} else {
|
|
githubNotify credentialsId: 'test-jenkins-credentials',
|
|
description: "The ${TEST_SUITE}-${TEST_PLATFORM} job has failed",
|
|
status: 'FAILURE',
|
|
context: "jenkins/pr/${TEST_SUITE}-${TEST_PLATFORM}"
|
|
slackSend channel: "#jenkins-prod-pr",
|
|
color: '#FF0000',
|
|
message: "FAILED: PR-Job: '${env.JOB_NAME} [${env.BUILD_NUMBER}]' (${env.BUILD_URL})"
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|