1
0
Fork 0
llvm-premerge-checks/Jenkins/Phabricator-pipeline/Jenkinsfile

182 lines
7.1 KiB
Text
Raw Normal View History

2019-10-17 17:21:24 +02:00
// Copyright 2019 Google LLC
//
// Licensed under the the Apache License v2.0 with LLVM Exceptions (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// https://llvm.org/LICENSE.txt
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
def success = true
def failure_message = ""
2019-10-17 17:21:24 +02:00
pipeline {
agent { label 'linux' }
2019-10-17 17:43:46 +02:00
parameters {
string(name: 'DIFF_ID')
string(name: 'PHID')
}
2019-10-18 13:59:58 +02:00
environment {
CONDUIT_TOKEN = credentials('phabricator-conduit-token')
2019-10-18 14:57:28 +02:00
PHABRICATOR_HOST = 'https://reviews.llvm.org'
2019-10-24 13:46:45 +02:00
PHAB_LOG = "${WORKSPACE}/build/.phabricator-comment"
SCRIPT_DIR = "${WORKSPACE}/llvm-premerge-checks/scripts"
BUILD_ID = "${JOB_BASE_NAME}-${BUILD_NUMBER}"
TARGET_DIR = "/mnt/nfs/results/${BUILD_ID}"
RESULT_URL = "http://results.llvm-merge-guard.org/${BUILD_ID}"
2019-11-18 17:02:24 +01:00
DIFF_JSON = "${WORKSPACE}/build/diff.json"
2019-10-18 13:59:58 +02:00
}
2019-10-17 17:21:24 +02:00
stages {
2019-10-21 22:37:09 +02:00
stage("build info"){
2019-10-21 22:39:27 +02:00
steps {
2019-10-24 21:35:19 +02:00
echo "Building diff ${DIFF_ID} with PHID ${PHID}"
2019-12-11 13:49:50 +01:00
script {
def revision_phid = sh(script:
'echo \'{"constraints":{"ids":[' + DIFF_ID + ']}}\' | '+
'arc call-conduit --conduit-uri=$PHABRICATOR_HOST --conduit-token $CONDUIT_TOKEN differential.diff.search | ' +
'jq -r ".response.data[0].fields.revisionPHID"', returnStdout: true).trim()
def drev_id = sh(script:
'echo \'{"constraints":{"phids":["' + revision_phid + '"]}}\' | ' +
'arc call-conduit --conduit-uri=$PHABRICATOR_HOST --conduit-token $CONDUIT_TOKEN differential.revision.search | ' +
'jq -r ".response.data[0].id"', returnStdout: true).trim()
currentBuild.displayName += " D${drev_id}"
currentBuild.description = "<a href='https://reviews.llvm.org/D${drev_id}'>D${drev_id}</a>"
2019-12-11 13:49:50 +01:00
}
// Report versions of the installed packages.
sh '''
echo Versions of various tools:
clang --version
clang-tidy --version
ld.lld --version
dpkg -l
'''
2019-10-21 22:39:27 +02:00
}
2019-10-21 22:37:09 +02:00
}
2019-11-18 17:13:19 +01:00
stage("git checkout"){
2019-10-17 17:47:16 +02:00
steps {
git url: 'https://github.com/llvm/llvm-project.git'
2020-02-05 10:13:37 +01:00
sh 'git reset --hard origin/master' // To remove any local commits to master.
2019-10-21 22:47:25 +02:00
sh 'git clean -fdx'
sh 'git show -s'
2019-10-17 17:52:11 +02:00
sh 'mkdir -p llvm-premerge-checks'
dir("llvm-premerge-checks")
{
2019-10-17 18:02:14 +02:00
git url: 'https://github.com/google/llvm-premerge-checks.git'
2019-10-17 17:57:40 +02:00
}
}
2019-10-17 17:43:46 +02:00
}
2019-11-18 17:02:24 +01:00
stage('arc patch'){
steps {
2020-02-07 14:01:46 +01:00
script {
success = false
failure_message = "Failed to apply patch"
}
2020-02-05 10:13:37 +01:00
sh "${SCRIPT_DIR}/phabtalk/apply_patch2.py ${DIFF_ID} --token ${CONDUIT_TOKEN} --url ${PHABRICATOR_HOST} --comment-file ${PHAB_LOG}"
2020-02-07 14:01:46 +01:00
script {
success = true
failure_message = ""
}
2019-11-18 17:02:24 +01:00
}
}
stage('CMake') {
2019-10-17 17:21:24 +02:00
steps {
2020-02-07 14:01:46 +01:00
script {
success = false
failure_message = "Failed to run cmake"
}
sh 'rm -rf build || true'
sh 'mkdir -p build'
sh 'mkdir -p "${TARGET_DIR}"'
2019-10-24 13:46:45 +02:00
sh "${SCRIPT_DIR}/run_cmake.sh"
2020-02-07 14:01:46 +01:00
script {
success = true
failure_message = ""
}
2019-10-17 17:21:24 +02:00
}
}
2019-10-23 21:27:28 +02:00
stage('ninja all') {
steps {
script {
try {
sh(script: "${SCRIPT_DIR}/run_ninja.sh all")
} catch (e) {
success = false;
failure_message = "'ninja all' failed" // append as build might already be broken
echo e.toString()
}
}
2020-01-20 14:53:17 +01:00
}
2019-10-23 21:27:28 +02:00
}
2019-10-17 17:52:11 +02:00
stage('ninja check-all') {
2019-10-17 17:21:24 +02:00
steps {
script {
try {
sh(script: "${SCRIPT_DIR}/run_ninja.sh check-all")
} catch (e) {
success = false;
failure_message += "\n'ninja check-all' failed" // append as build might already be broken
echo e.toString()
}
}
2019-10-17 18:09:59 +02:00
}
2019-10-17 17:21:24 +02:00
}
stage('linters') {
steps {
script {
try {
sh(script: "${SCRIPT_DIR}/lint.sh")
} catch (e) {
success = false;
failure_message += "\nFailed to run linters" // append as build might already be broken
echo e.toString()
}
}
}
}
2019-10-17 17:21:24 +02:00
}
2019-10-23 21:27:28 +02:00
post {
2019-12-11 13:45:25 +01:00
always {
script {
if (success) {
currentBuild.result = "SUCCESS"
} else {
currentBuild.result = "FAILURE"
}
}
2019-10-24 13:46:45 +02:00
echo "Console log is available at ${RESULT_URL}"
dir("${TARGET_DIR}") {
2019-10-23 21:27:28 +02:00
// copy console log to result folder
sh "wget -qO console-log.txt http://jenkins-ui.jenkins.svc.cluster.local:8080/job/${JOB_BASE_NAME}/${BUILD_NUMBER}/consoleText"
// keep a copy of the answer from Phabricator for debugging
2019-11-18 17:30:11 +01:00
// TODO: move all file copy operations here
2019-11-18 17:05:15 +01:00
sh """
set -eu
if [ -f "${DIFF_JSON}" ]; then
cp ${DIFF_JSON} .
fi
"""
2019-10-23 21:27:28 +02:00
}
2019-10-24 21:41:40 +02:00
/// send results to Phabricator
2019-11-21 15:09:38 +01:00
sh """${SCRIPT_DIR}/phabtalk/phabtalk.py "${PHID}" "${DIFF_ID}" \
--workspace "${WORKSPACE}" \
2019-10-24 21:41:40 +02:00
--conduit-token "${CONDUIT_TOKEN}" \
--test-result-file "test-results.xml" \
--host "${PHABRICATOR_HOST}/api/" \
--buildresult ${currentBuild.result} \
--clang-format-patch "clang-format.patch" \
--clang-tidy-result "clang-tidy.txt" \
--clang-tidy-ignore "${SCRIPT_DIR}/clang-tidy-comments.ignore" \
--results-dir "${TARGET_DIR}" \
--results-url "${RESULT_URL}" \
--failures "${failure_message}"
2019-11-21 15:09:38 +01:00
"""
2019-10-23 21:27:28 +02:00
}
}
}