2020-08-07 23:51:37 +02:00
|
|
|
// https://stackoverflow.com/questions/40760716/jenkins-abort-running-build-if-new-one-is-started
|
|
|
|
def buildNumber = env.BUILD_NUMBER as int
|
|
|
|
if (buildNumber > 1) {
|
|
|
|
milestone(buildNumber - 1)
|
|
|
|
}
|
|
|
|
milestone(buildNumber)
|
|
|
|
|
2019-11-11 22:43:40 +01:00
|
|
|
def runStages() {
|
2019-12-03 15:02:38 +01:00
|
|
|
try {
|
|
|
|
stage("Clone") {
|
2020-08-07 23:51:37 +02:00
|
|
|
/* source code checkout */
|
2019-12-03 15:02:38 +01:00
|
|
|
checkout scm
|
2020-04-20 16:34:36 +02:00
|
|
|
/* we need to update the submodules before caching kicks in */
|
|
|
|
sh "git submodule update --init --recursive"
|
2019-12-03 15:02:38 +01:00
|
|
|
}
|
|
|
|
|
2019-12-03 18:57:05 +01:00
|
|
|
cache(maxCacheSize: 250, caches: [
|
|
|
|
[$class: "ArbitraryFileCache", excludes: "", includes: "**/*", path: "${WORKSPACE}/vendor/nimbus-build-system/vendor/Nim/bin"],
|
|
|
|
[$class: "ArbitraryFileCache", excludes: "", includes: "**/*", path: "${WORKSPACE}/jsonTestsCache"]
|
|
|
|
]) {
|
2019-12-03 15:02:38 +01:00
|
|
|
stage("Build") {
|
2020-05-21 00:02:05 +02:00
|
|
|
sh """#!/bin/bash
|
|
|
|
set -e
|
|
|
|
make -j${env.NPROC} update # to allow a newer Nim version to be detected
|
|
|
|
make -j${env.NPROC} deps # to allow the following parallel stages
|
|
|
|
V=1 ./scripts/setup_official_tests.sh jsonTestsCache
|
|
|
|
"""
|
2019-11-11 22:43:40 +01:00
|
|
|
}
|
2019-12-03 18:57:05 +01:00
|
|
|
}
|
2019-12-03 15:02:38 +01:00
|
|
|
|
|
|
|
stage("Test") {
|
|
|
|
parallel(
|
|
|
|
"tools": {
|
|
|
|
stage("Tools") {
|
2020-05-21 00:02:05 +02:00
|
|
|
sh """#!/bin/bash
|
|
|
|
set -e
|
|
|
|
make -j${env.NPROC}
|
2020-07-03 12:04:04 +02:00
|
|
|
make -j${env.NPROC} LOG_LEVEL=TRACE NIMFLAGS='-d:testnet_servers_image' beacon_node
|
2020-05-21 00:02:05 +02:00
|
|
|
"""
|
2020-01-13 20:58:12 +01:00
|
|
|
}
|
|
|
|
},
|
2019-12-03 15:02:38 +01:00
|
|
|
"test suite": {
|
|
|
|
stage("Test suite") {
|
|
|
|
sh "make -j${env.NPROC} DISABLE_TEST_FIXTURES_SCRIPT=1 test"
|
|
|
|
}
|
2020-07-29 14:08:27 +02:00
|
|
|
stage("testnet finalization") {
|
|
|
|
// EXECUTOR_NUMBER will be 0 or 1, since we have 2 executors per Jenkins node
|
|
|
|
sh """#!/bin/bash
|
|
|
|
set -e
|
2020-09-01 16:38:34 +03:00
|
|
|
./scripts/launch_local_testnet.sh --testnet 0 --nodes 4 --stop-at-epoch 5 --log-level DEBUG --disable-htop --enable-logtrace --data-dir local_testnet0_data --base-port \$(( 9000 + EXECUTOR_NUMBER * 100 )) --base-rpc-port \$(( 7000 + EXECUTOR_NUMBER * 100 )) --base-metrics-port \$(( 8008 + EXECUTOR_NUMBER * 100 )) -- --verify-finalization --discv5:no
|
|
|
|
./scripts/launch_local_testnet.sh --testnet 1 --nodes 4 --stop-at-epoch 5 --log-level DEBUG --disable-htop --enable-logtrace --data-dir local_testnet1_data --base-port \$(( 9000 + EXECUTOR_NUMBER * 100 )) --base-rpc-port \$(( 7000 + EXECUTOR_NUMBER * 100 )) --base-metrics-port \$(( 8008 + EXECUTOR_NUMBER * 100 )) -- --verify-finalization --discv5:no
|
2020-07-29 14:08:27 +02:00
|
|
|
"""
|
2020-03-10 18:01:04 +01:00
|
|
|
}
|
2020-08-15 19:33:58 +02:00
|
|
|
// stage("testnet finalization - Miracl/Milagro fallback") {
|
|
|
|
// // EXECUTOR_NUMBER will be 0 or 1, since we have 2 executors per Jenkins node
|
|
|
|
// sh """#!/bin/bash
|
|
|
|
// set -e
|
2020-09-01 16:38:34 +03:00
|
|
|
// NIMFLAGS="-d:BLS_FORCE_BACKEND=miracl" ./scripts/launch_local_testnet.sh --testnet 0 --nodes 4 --stop-at-epoch 5 --log-level INFO --disable-htop --data-dir local_testnet0_data --base-port \$(( 9000 + EXECUTOR_NUMBER * 100 )) --base-rpc-port \$(( 7000 + EXECUTOR_NUMBER * 100 )) --base-metrics-port \$(( 8008 + EXECUTOR_NUMBER * 100 )) -- --verify-finalization
|
|
|
|
// NIMFLAGS="-d:BLS_FORCE_BACKEND=miracl" ./scripts/launch_local_testnet.sh --testnet 1 --nodes 4 --stop-at-epoch 5 --log-level INFO --disable-htop --data-dir local_testnet1_data --base-port \$(( 9000 + EXECUTOR_NUMBER * 100 )) --base-rpc-port \$(( 7000 + EXECUTOR_NUMBER * 100 )) --base-metrics-port \$(( 8008 + EXECUTOR_NUMBER * 100 )) -- --verify-finalization
|
2020-08-15 19:33:58 +02:00
|
|
|
// """
|
|
|
|
// }
|
2019-12-03 15:02:38 +01:00
|
|
|
}
|
|
|
|
)
|
|
|
|
}
|
|
|
|
} catch(e) {
|
2019-12-03 18:57:05 +01:00
|
|
|
// we need to rethrow the exception here
|
2019-12-03 15:02:38 +01:00
|
|
|
throw e
|
|
|
|
} finally {
|
2020-06-11 00:13:25 +02:00
|
|
|
// archive testnet logs
|
2020-07-29 14:08:27 +02:00
|
|
|
sh """#!/bin/bash
|
|
|
|
for D in local_testnet0_data local_testnet1_data; do
|
|
|
|
[[ -d "\$D" ]] && tar cjf "\${D}-\${NODE_NAME}.tar.bz2" "\${D}"/*.txt || true
|
|
|
|
done
|
|
|
|
"""
|
2020-08-07 23:51:37 +02:00
|
|
|
try {
|
|
|
|
archiveArtifacts("*.tar.bz2")
|
|
|
|
} catch(e) {
|
|
|
|
println("Couldn't archive artefacts.")
|
|
|
|
println(e.toString());
|
|
|
|
// we don't need to re-raise it here; it might be a PR build being cancelled by a newer one
|
|
|
|
}
|
2020-06-11 00:13:25 +02:00
|
|
|
// clean the workspace
|
2020-04-19 13:17:02 +02:00
|
|
|
cleanWs(disableDeferredWipeout: true, deleteDirs: true)
|
2019-11-11 22:16:17 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-11-11 22:43:40 +01:00
|
|
|
parallel(
|
|
|
|
"Linux": {
|
|
|
|
node("linux") {
|
|
|
|
withEnv(["NPROC=${sh(returnStdout: true, script: 'nproc').trim()}"]) {
|
|
|
|
runStages()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"macOS": {
|
|
|
|
node("macos") {
|
|
|
|
withEnv(["NPROC=${sh(returnStdout: true, script: 'sysctl -n hw.logicalcpu').trim()}"]) {
|
|
|
|
runStages()
|
|
|
|
}
|
|
|
|
}
|
2020-08-26 17:31:46 +02:00
|
|
|
},
|
2019-11-11 22:43:40 +01:00
|
|
|
)
|
2020-08-26 17:31:46 +02:00
|
|
|
|