update CI timeouts (#3751)

Assign a longer overall timeout that a CI job can spend in queue,
and define short timeouts for the individual stages to avoid stuck jobs.
This commit is contained in:
Etan Kissling 2022-06-14 22:39:54 +02:00 committed by GitHub
parent 1b6651dfc3
commit 6bf7d64680
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 15 additions and 15 deletions

30
Jenkinsfile vendored
View File

@ -13,14 +13,14 @@ def runStages(nodeDir) {
sh "mkdir -p ${nodeDir}" sh "mkdir -p ${nodeDir}"
dir(nodeDir) { dir(nodeDir) {
try { try {
stage("Clone") { stage("Clone") { timeout(10) {
/* source code checkout */ /* source code checkout */
checkout scm checkout scm
/* we need to update the submodules before caching kicks in */ /* we need to update the submodules before caching kicks in */
sh "git submodule update --init --recursive" sh "git submodule update --init --recursive"
} } }
stage("Preparations") { stage("Preparations") { timeout(10) {
sh """#!/bin/bash sh """#!/bin/bash
set -e set -e
# macOS shows scary warnings if there are old libraries and object files laying around # macOS shows scary warnings if there are old libraries and object files laying around
@ -29,29 +29,29 @@ def runStages(nodeDir) {
make -j${env.NPROC} QUICK_AND_DIRTY_COMPILER=1 update make -j${env.NPROC} QUICK_AND_DIRTY_COMPILER=1 update
./scripts/setup_scenarios.sh ./scripts/setup_scenarios.sh
""" """
} } }
stage("Tools") { stage("Tools") { timeout(30) {
sh """#!/bin/bash sh """#!/bin/bash
set -e set -e
make -j${env.NPROC} LOG_LEVEL=TRACE make -j${env.NPROC} LOG_LEVEL=TRACE
""" """
} } }
stage("Test suite") { stage("Test suite") { timeout(60) {
sh "make -j${env.NPROC} DISABLE_TEST_FIXTURES_SCRIPT=1 test" sh "make -j${env.NPROC} DISABLE_TEST_FIXTURES_SCRIPT=1 test"
} } }
stage("REST test suite") { stage("REST test suite") { timeout(5) {
sh """#!/bin/bash sh """#!/bin/bash
set -e set -e
./tests/simulation/restapi.sh --data-dir resttest0_data --base-port \$(( 9100 + EXECUTOR_NUMBER * 100 )) \ ./tests/simulation/restapi.sh --data-dir resttest0_data --base-port \$(( 9100 + EXECUTOR_NUMBER * 100 )) \
--base-rest-port \$(( 7100 + EXECUTOR_NUMBER * 100 )) --base-metrics-port \ --base-rest-port \$(( 7100 + EXECUTOR_NUMBER * 100 )) --base-metrics-port \
\$(( 8108 + EXECUTOR_NUMBER * 100 )) --resttest-delay 30 --kill-old-processes \$(( 8108 + EXECUTOR_NUMBER * 100 )) --resttest-delay 30 --kill-old-processes
""" """
} } }
stage("Testnet finalization") { stage("Testnet finalization") { timeout(75) {
// EXECUTOR_NUMBER will be 0 or 1, since we have 2 executors per Jenkins node // EXECUTOR_NUMBER will be 0 or 1, since we have 2 executors per Jenkins node
sh """#!/bin/bash sh """#!/bin/bash
set -e set -e
@ -66,7 +66,7 @@ def runStages(nodeDir) {
--kill-old-processes \ --kill-old-processes \
-- --verify-finalization --discv5:no -- --verify-finalization --discv5:no
""" """
} } }
} catch(e) { } catch(e) {
// we need to rethrow the exception here // we need to rethrow the exception here
throw e throw e
@ -93,7 +93,7 @@ def runStages(nodeDir) {
parallel( parallel(
"Linux": { "Linux": {
throttle(['nimbus-eth2']) { throttle(['nimbus-eth2']) {
timeout(time: 5, unit: 'HOURS') { timeout(time: 24, unit: 'HOURS') { // includes time in build queue
node("linux") { node("linux") {
withEnv(["NPROC=${sh(returnStdout: true, script: 'nproc').trim()}"]) { withEnv(["NPROC=${sh(returnStdout: true, script: 'nproc').trim()}"]) {
runStages("linux") runStages("linux")
@ -104,7 +104,7 @@ parallel(
}, },
"macOS (AMD64)": { "macOS (AMD64)": {
throttle(['nimbus-eth2']) { throttle(['nimbus-eth2']) {
timeout(time: 5, unit: 'HOURS') { timeout(time: 24, unit: 'HOURS') { // includes time in build queue
node("macos && x86_64") { node("macos && x86_64") {
withEnv(["NPROC=${sh(returnStdout: true, script: 'sysctl -n hw.logicalcpu').trim()}"]) { withEnv(["NPROC=${sh(returnStdout: true, script: 'sysctl -n hw.logicalcpu').trim()}"]) {
runStages("macos_amd64") runStages("macos_amd64")
@ -115,7 +115,7 @@ parallel(
}, },
"macOS (ARM64)": { "macOS (ARM64)": {
throttle(['nimbus-eth2']) { throttle(['nimbus-eth2']) {
timeout(time: 5, unit: 'HOURS') { timeout(time: 24, unit: 'HOURS') { // includes time in build queue
node("macos && arm64") { node("macos && arm64") {
withEnv(["NPROC=${sh(returnStdout: true, script: 'sysctl -n hw.logicalcpu').trim()}"]) { withEnv(["NPROC=${sh(returnStdout: true, script: 'sysctl -n hw.logicalcpu').trim()}"]) {
runStages("macos_arm64") runStages("macos_arm64")