1
0
Fork 0

draft for new Linux pipeline

This commit is contained in:
Christian Kühnel 2020-03-23 17:08:58 +01:00
parent 003175ed96
commit 89c08fc390

View file

@ -20,35 +20,26 @@ pipeline {
parameters { parameters {
string(name: 'DIFF_ID') string(name: 'DIFF_ID')
string(name: 'PHID') string(name: 'PHID')
string(name: 'REV_ID')
} }
environment { environment {
CONDUIT_TOKEN = credentials('phabricator-conduit-token') CONDUIT_TOKEN = credentials('phabricator-conduit-token')
PHABRICATOR_HOST = 'https://reviews.llvm.org' PHABRICATOR_HOST = 'https://reviews.llvm.org'
PHAB_LOG = "${WORKSPACE}/build/.phabricator-comment" LLVM_DIR = "${WORKSPACE}/llvm-project"
SCRIPT_DIR = "${WORKSPACE}/llvm-premerge-checks/scripts" SCRIPT_DIR = "${WORKSPACE}/llvm-premerge-checks/scripts"
BUILD_ID = "${JOB_BASE_NAME}-${BUILD_NUMBER}" RESULT_DIR = "${WORKSPACE}/results"
// TODO: replace result dir with Google Cloud Storage, PHAB_LOG = "${RESULT_DIR}/.phabricator-comment"
// TODO: create local result folder that is uploaded to GCS later, as on Windows MY_BUILD_ID = "${JOB_BASE_NAME}-${BUILD_NUMBER}"
TARGET_DIR = "/mnt/nfs/results/${BUILD_ID}" TARGET_DIR = "/mnt/nfs/results/${BUILD_ID}"
RESULT_URL = "http://results.llvm-merge-guard.org/${BUILD_ID}" RESULT_URL = "http://results.llvm-merge-guard.org/${BUILD_ID}"
DIFF_JSON = "${WORKSPACE}/build/diff.json"
} }
stages { stages {
stage("build info"){ stage("build info"){
steps { steps {
echo "Building diff ${DIFF_ID} with PHID ${PHID}" echo "Building diff ${DIFF_ID} with PHID ${PHID} for Revision ${REV_ID}"
// TODO: replace this scripting by submitting the Revision from Phabricator as additional Parameter
script { script {
def revision_phid = sh(script: currentBuild.displayName += " D${REV_ID}"
'echo \'{"constraints":{"ids":[' + DIFF_ID + ']}}\' | '+ currentBuild.description = "<a href='https://reviews.llvm.org/D${REV_ID}'>D${REV_ID}</a>"
'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>"
} }
// Report versions of the installed packages. // Report versions of the installed packages.
sh ''' sh '''
@ -58,34 +49,25 @@ pipeline {
ld.lld --version ld.lld --version
dpkg -l dpkg -l
''' '''
} }
} }
stage("git checkout"){ stage("git checkout")
{
steps { steps {
git url: 'https://github.com/llvm/llvm-project.git' dir("${LLVM_DIR}")
sh 'git reset --hard origin/master' // To remove any local commits to master. {
sh 'git clean -fdx' git url: 'https://github.com/llvm/llvm-project.git' branch: "phab-diff-${DIFF_ID}"
sh 'git show -s' sh 'git clean -fdx'
sh 'mkdir -p llvm-premerge-checks' sh 'git show -s'
}
dir("llvm-premerge-checks") dir("llvm-premerge-checks")
{ {
git url: 'https://github.com/google/llvm-premerge-checks.git' git url: 'https://github.com/google/llvm-premerge-checks.git'
} }
} sh """
} rm -rf ${RESULT_DIR}
stage('arc patch'){ mkdir -p ${RESULT_DIR}
steps { """
//TODO: Why are we using pre/post variables and not try/catch as in `ninja all`?
script {
success = false
failure_message = "Failed to apply patch"
}
sh "${SCRIPT_DIR}/phabtalk/apply_patch2.py ${DIFF_ID} --token ${CONDUIT_TOKEN} --url ${PHABRICATOR_HOST} --comment-file ${PHAB_LOG}"
script {
success = true
failure_message = ""
}
} }
} }
stage('CMake') { stage('CMake') {
@ -94,23 +76,18 @@ pipeline {
success = false success = false
failure_message = "Failed to run cmake" failure_message = "Failed to run cmake"
} }
sh 'rm -rf build || true' sh "${SCRIPT_DIR}/run_cmake.py --projects detect"
sh 'mkdir -p build'
sh 'mkdir -p "${TARGET_DIR}"'
// TODO: replace with Pyhton script for CMake that works on Linux and Windows
// TODO: Limit to projects affected by the change
sh "${SCRIPT_DIR}/run_cmake.sh"
script { script {
success = true success = true
failure_message = "" failure_message = ""
} }
} }
} }
/*
stage('ninja all') { stage('ninja all') {
steps { steps {
script { script {
try { try {
// TODO: replace with Python script that works on Linux and Windows
sh(script: "${SCRIPT_DIR}/run_ninja.sh all") sh(script: "${SCRIPT_DIR}/run_ninja.sh all")
} catch (e) { } catch (e) {
success = false; success = false;
@ -121,7 +98,6 @@ pipeline {
} }
} }
stage('ninja check-all') { stage('ninja check-all') {
// TODO: do not trigger `ninja check-all` after `ninja all` has failed!
steps { steps {
script { script {
try { try {
@ -147,6 +123,7 @@ pipeline {
} }
} }
} }
*/
} }
post { post {
always { always {
@ -158,23 +135,25 @@ pipeline {
} }
} }
echo "Console log is available at ${RESULT_URL}" echo "Console log is available at ${RESULT_URL}"
dir("${TARGET_DIR}") { dir("${RESULT_DIR}") {
// copy console log to result folder // 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" 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 // keep a copy of the answer from Phabricator for debugging
// TODO: move all file copy operations here // TODO: move all file copy operations here
sh """ sh """
set -eu set -eu
if [ -f "${DIFF_JSON}" ]; then cp ${LLVM_DIR}/build/CMakeCache.txt . || :
cp ${DIFF_JSON} . cp ${LLVM_DIR}/test-results.xml . || :
fi
mkdir -p ${TARGET_DIR}
cp * ${TARGET_DIR}
""" """
} }
/// send results to Phabricator /// send results to Phabricator
sh """${SCRIPT_DIR}/phabtalk/phabtalk.py "${PHID}" "${DIFF_ID}" \ sh """${SCRIPT_DIR}/phabtalk/phabtalk.py "${PHID}" "${DIFF_ID}" \
--workspace "${WORKSPACE}" \ --workspace "${WORKSPACE}" \
--conduit-token "${CONDUIT_TOKEN}" \ --conduit-token "${CONDUIT_TOKEN}" \
--test-result-file "test-results.xml" \ --test-result-file "${RESULT_DIR}/test-results.xml" \
--host "${PHABRICATOR_HOST}/api/" \ --host "${PHABRICATOR_HOST}/api/" \
--buildresult ${currentBuild.result} \ --buildresult ${currentBuild.result} \
--clang-format-patch "clang-format.patch" \ --clang-format-patch "clang-format.patch" \