diff --git a/Jenkinsfile b/Jenkinsfile index f22d0d82a42cc27b95183ec53d5ff11dbede332b..d7319d154780173280007d72b4afa5017997f5bf 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -474,7 +474,11 @@ def buildImages(architecture, type, boards, debosarguments = "", image = true, s // Mark the whole pipeline as failed in case of failure at any stage if (buildStatus.containsValue(false)) { - currentBuild.result = 'FAILURE' + currentBuild.result = 'FAILURE' + // mark builds where some artifacts have failed to build + dir ("${env.PIPELINE_VERSION}/meta/") { + writeFile (file: "failed-${architecture}-${type}", text: '') + } } // Upload artifacts @@ -551,3 +555,35 @@ buildCandidates.each { name, arch -> parallel first_pass parallel second_pass +node() { + stage("upload meta") { + skipped = architectures - buildCandidates + complete = !skipped && currentBuild.resultIsBetterOrEqualTo('SUCCESS') + + skippednames = [] + for (architecture in skipped) { + for (type in architecture.value.types) { + skippednames << "skipped-${architecture.key}-${type.key}" + } + } + + dir ("${env.PIPELINE_VERSION}/meta/") { + writeFile (file: "build-version", text: env.PIPELINE_VERSION) + writeFile (file: "build-url", text: env.BUILD_URL) + + // report which entries have been skipped + for (String skippedname : skippednames) { + writeFile (file: skippedname, text: '') + } + + // mark builds that have not been killed half way + writeFile (file: "finished", text: '') + // mark successful builds with no skipped artifacts, they're the best candidates for longer term storage + if (complete) { + writeFile (file: "complete", text: '') + } + } + + uploadDirectory (env.PIPELINE_VERSION, "daily/${release}") + } +}