draft for new Linux pipeline
This commit is contained in:
parent
003175ed96
commit
89c08fc390
1 changed files with 30 additions and 51 deletions
|
@ -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" \
|
Loading…
Reference in a new issue