182 lines
6.6 KiB
Groovy
182 lines
6.6 KiB
Groovy
#!groovy
|
|
|
|
pipeline {
|
|
agent none
|
|
|
|
environment {
|
|
PROJECT_TEST_CONFIG_DIR = "/.ci/cpp_build_system/test"
|
|
}
|
|
|
|
options {
|
|
disableConcurrentBuilds()
|
|
skipDefaultCheckout()
|
|
timestamps()
|
|
}
|
|
|
|
stages {
|
|
stage('Windows') {
|
|
agent any
|
|
stages {
|
|
stage('Checkout') {
|
|
steps {
|
|
script {
|
|
int maxAttempts = 6
|
|
int baseDelay = 10
|
|
for (int attempt = 1; attempt <= maxAttempts; attempt++) {
|
|
try {
|
|
checkout scm
|
|
break
|
|
} catch (err) {
|
|
if (attempt == maxAttempts) { throw err }
|
|
int waitSec = baseDelay * (1 << (attempt - 1))
|
|
echo "Checkout failed (attempt ${attempt}/${maxAttempts}). Waiting ${waitSec}s before retry..."
|
|
sleep time: waitSec, unit: 'SECONDS'
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
stage('win32_shared') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_win32.sh shared' } } }
|
|
}
|
|
stage('win32_shared_crypto') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_win32.sh shared 1' } } }
|
|
}
|
|
stage('win32_shared_crypto_no_boost') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_win32.sh shared 7' } } }
|
|
}
|
|
stage('win32_shared_dsm') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_win32.sh shared 2' } } }
|
|
}
|
|
stage('win32_shared_sqlite') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_win32.sh shared 3' } } }
|
|
}
|
|
stage('win32_shared_errors_v1') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_win32.sh shared 4' } } }
|
|
}
|
|
stage('win32_shared_fmt') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_win32.sh shared 5' } } }
|
|
}
|
|
stage('win32_shared_libevent') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_win32.sh shared 6' } } }
|
|
}
|
|
|
|
stage('win32_static') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_win32.sh static' } } }
|
|
}
|
|
stage('win32_static_crypto') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_win32.sh static 1' } } }
|
|
}
|
|
stage('win32_static_crypto_no_boost') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_win32.sh static 7' } } }
|
|
}
|
|
stage('win32_static_dsm') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_win32.sh static 2' } } }
|
|
}
|
|
stage('win32_static_sqlite') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_win32.sh static 3' } } }
|
|
}
|
|
stage('win32_static_errors_v1') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_win32.sh static 4' } } }
|
|
}
|
|
stage('win32_static_fmt') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_win32.sh static 5' } } }
|
|
}
|
|
stage('win32_static_libevent') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_win32.sh static 6' } } }
|
|
}
|
|
}
|
|
}
|
|
|
|
stage('Linux') {
|
|
agent any
|
|
stages {
|
|
stage('Checkout') {
|
|
steps {
|
|
script {
|
|
int maxAttempts = 6
|
|
int baseDelay = 10
|
|
for (int attempt = 1; attempt <= maxAttempts; attempt++) {
|
|
try {
|
|
checkout scm
|
|
break
|
|
} catch (err) {
|
|
if (attempt == maxAttempts) { throw err }
|
|
int waitSec = baseDelay * (1 << (attempt - 1))
|
|
echo "Checkout failed (attempt ${attempt}/${maxAttempts}). Waiting ${waitSec}s before retry..."
|
|
sleep time: waitSec, unit: 'SECONDS'
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
stage('linux_shared') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_unix.sh shared' } } }
|
|
}
|
|
stage('linux_shared_crypto') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_unix.sh shared 1' } } }
|
|
}
|
|
stage('linux_shared_crypto_no_boost') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_unix.sh shared 7' } } }
|
|
}
|
|
stage('linux_shared_dsm') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_unix.sh shared 2' } } }
|
|
}
|
|
stage('linux_shared_sqlite') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_unix.sh shared 3' } } }
|
|
}
|
|
stage('linux_shared_errors_v1') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_unix.sh shared 4' } } }
|
|
}
|
|
stage('linux_shared_fmt') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_unix.sh shared 5' } } }
|
|
}
|
|
stage('linux_shared_libevent') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_unix.sh shared 6' } } }
|
|
}
|
|
|
|
stage('linux_static') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_unix.sh static' } } }
|
|
}
|
|
stage('linux_static_crypto') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_unix.sh static 1' } } }
|
|
}
|
|
stage('linux_static_crypto_no_boost') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_unix.sh static 7' } } }
|
|
}
|
|
stage('linux_static_dsm') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_unix.sh static 2' } } }
|
|
}
|
|
stage('linux_static_sqlite') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_unix.sh static 3' } } }
|
|
}
|
|
stage('linux_static_errors_v1') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_unix.sh static 4' } } }
|
|
}
|
|
stage('linux_static_fmt') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_unix.sh static 5' } } }
|
|
}
|
|
stage('linux_static_libevent') {
|
|
steps { script { retryWithBackoff(2, 5) { sh 'scripts/test_unix.sh static 6' } } }
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
def retryWithBackoff(int maxAttempts, int baseDelaySeconds, Closure body) {
|
|
for (int attempt = 1; attempt <= maxAttempts; attempt++) {
|
|
try {
|
|
body()
|
|
return
|
|
} catch (err) {
|
|
if (attempt == maxAttempts) { throw err }
|
|
int waitSec = baseDelaySeconds * (1 << (attempt - 1))
|
|
echo "Step failed (attempt ${attempt}/${maxAttempts}). Waiting ${waitSec}s before retry..."
|
|
sleep time: waitSec, unit: 'SECONDS'
|
|
}
|
|
}
|
|
}
|