nimbus-eth2/Jenkinsfile

65 lines
1.7 KiB
Plaintext
Raw Normal View History

2019-11-11 22:43:40 +01:00
def runStages() {
try {
stage("Clone") {
checkout scm
}
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"]
]) {
stage("Build") {
sh "make -j${env.NPROC} update" /* to allow a newer Nim version to be detected */
sh "make -j${env.NPROC} deps" /* to allow the following parallel stages */
sh "scripts/setup_official_tests.sh jsonTestsCache"
2019-11-11 22:43:40 +01:00
}
2019-12-03 18:57:05 +01:00
}
stage("Test") {
parallel(
"tools": {
stage("Tools") {
sh "make -j${env.NPROC}"
sh "make -j${env.NPROC} LOG_LEVEL=TRACE NIMFLAGS='-d:testnet_servers_image'"
}
},
"test suite": {
stage("Test suite") {
sh "make -j${env.NPROC} DISABLE_TEST_FIXTURES_SCRIPT=1 test"
}
2020-03-10 18:01:04 +01:00
if ("${NODE_NAME}" ==~ /linux.*/) {
stage("testnet finalization") {
sh "./scripts/launch_local_testnet.sh --testnet 0 --nodes 4 --log-level INFO --disable-htop -- --verify-finalization --stop-at-epoch=5"
sh "./scripts/launch_local_testnet.sh --testnet 1 --nodes 4 --log-level INFO --disable-htop -- --verify-finalization --stop-at-epoch=5"
2020-03-10 18:01:04 +01:00
}
}
}
)
}
} catch(e) {
echo "'${env.STAGE_NAME}' stage failed"
2019-12-03 18:57:05 +01:00
// we need to rethrow the exception here
throw e
} finally {
cleanWs()
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()
}
}
}
)