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

170 lines
6.3 KiB
Text
Raw Normal View History

// 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
pipeline {
2020-01-15 17:50:50 +01:00
agent { label 'windows' }
parameters {
string(name: 'DIFF_ID')
string(name: 'PHID')
string(name: 'REV_ID')
}
environment {
2020-01-16 09:13:10 +01:00
CONDUIT_TOKEN = credentials('phabricator-conduit-token')
PHABRICATOR_HOST = 'https://reviews.llvm.org'
PHAB_LOG = "${WORKSPACE}/build/.phabricator-comment"
MY_BUILD_ID = "${JOB_BASE_NAME}-${BUILD_NUMBER}"
2020-02-18 13:41:29 +01:00
RESULT_URL = "https://storage.cloud.google.com/llvm-premerge-checks/results/${MY_BUILD_ID}"
2020-01-16 09:13:10 +01:00
SCRIPT_DIR = "${WORKSPACE}/llvm-premerge-checks/scripts"
2020-01-28 13:08:51 +01:00
// store all build results here, will be uploaded to GCS later
2020-01-16 09:13:10 +01:00
RESULT_DIR = "${WORKSPACE}\\results"
LLVM_DIR = "${WORKSPACE}\\llvm-project"
SCCACHE_DIR = "C:\\ws\\sccache"
}
2020-02-19 09:21:21 +01:00
options {
timeout(time:2, unit:'HOURS')
}
stages {
stage("build info"){
steps {
echo "Building diff ${DIFF_ID} with PHID ${PHID} for Revision ${REV_ID}"
script {
currentBuild.displayName += " D${REV_ID}"
currentBuild.description = "<a href='https://reviews.llvm.org/D${REV_ID}'>D${REV_ID}</a>"
}
2020-02-17 17:22:51 +01:00
script {
success = true
failure_message = ""
}
}
}
stage("git checkout"){
steps {
echo "getting llvm-premerge-checks... "
dir("llvm-premerge-checks")
{
git url: 'https://github.com/google/llvm-premerge-checks.git'
}
echo "getting llvm-project... "
dir("llvm-project")
{
git url: 'https://github.com/llvm-premerge-tests/llvm-project.git', branch: "phab-diff-${DIFF_ID}"
powershell 'git clean -fdx'
powershell 'git show -s'
}
2020-01-28 13:08:51 +01:00
// create ${RESULT_DIR}
powershell """
Remove-Item ${RESULT_DIR} -Recurse -ErrorAction Ignore
New-Item -ItemType Directory -Force -Path ${RESULT_DIR} | Out-Null
"""
}
}
stage('CMake') {
steps {
dir("${LLVM_DIR}"){
2020-04-24 13:51:18 +02:00
powershell "python ${SCRIPT_DIR}/run_cmake.py detect"
}
}
2020-02-17 17:22:51 +01:00
post {
failure {
script {
success = false
failure_message = "Failed to run CMake"
}
}
}
}
stage('ninja all') {
steps {
dir("${LLVM_DIR}"){
2020-04-24 13:51:18 +02:00
powershell "python ${SCRIPT_DIR}/run_ninja.py all"
}
}
2020-02-17 17:22:51 +01:00
post {
failure {
script {
success = false
failure_message = "Failed to run ninja all"
}
}
}
}
stage('ninja check-all') {
steps {
dir("${LLVM_DIR}"){
2020-04-24 13:51:18 +02:00
powershell "python ${SCRIPT_DIR}/run_ninja.py check-all"
}
}
2020-02-17 17:22:51 +01:00
post {
failure {
script {
success = false
failure_message = "Failed to run ninja check-all"
}
}
}
}
}
post {
always {
2020-02-17 17:22:51 +01:00
script {
if (success) {
currentBuild.result = "SUCCESS"
} else {
currentBuild.result = "FAILURE"
}
}
2020-02-11 13:49:42 +01:00
echo "Uploading logs to ${RESULT_URL} ..."
2020-02-17 16:29:35 +01:00
dir("${RESULT_DIR}") {
2020-02-13 15:32:05 +01:00
// gather all result files in a folder
powershell """
2020-02-17 16:29:35 +01:00
\$ErrorActionPreference = 'Continue'
Write-Host "Getting the console log..."
Invoke-WebRequest -OutFile console-log.txt -uri "http://jenkins.local:8080/job/${JOB_BASE_NAME}/${BUILD_NUMBER}/consoleText" -ErrorAction "Continue"
Write-Host "Copying build artefacts..."
2020-02-17 16:29:35 +01:00
Copy-Item "${LLVM_DIR}\\choose_projects.log"
Copy-Item "${LLVM_DIR}\\build\\CMakeCache.txt"
Copy-Item "${LLVM_DIR}\\build\\test-results.xml"
2020-02-13 15:32:05 +01:00
"""
}
2020-02-11 13:49:42 +01:00
/// send results to Phabricator
2020-02-17 16:29:35 +01:00
echo "Sending build feedback to Phabricator..."
bat """
2020-02-17 16:59:13 +01:00
python ${SCRIPT_DIR}/phabtalk/phabtalk.py "${PHID}" "${DIFF_ID}" ^
--workspace "${LLVM_DIR}" ^
--conduit-token "${CONDUIT_TOKEN}" ^
--test-result-file "test-results.xml" ^
--host "${PHABRICATOR_HOST}/api/" ^
--results-dir "${RESULT_DIR}" ^
--results-url "${RESULT_URL}" ^
2020-02-17 17:22:51 +01:00
--failures "${failure_message}" ^
2020-02-19 16:49:39 +01:00
--buildresult ${currentBuild.result} ^
--name "windows"
2020-02-11 13:49:42 +01:00
"""
2020-02-17 16:29:35 +01:00
dir("${RESULT_DIR}") {
2020-02-13 15:32:05 +01:00
// upload results to
// Google Cloud Storage
powershell """
Write-Host "Uploading results to GCS..."
\$ErrorActionPreference = 'Continue'
gsutil cp *.* gs://llvm-premerge-checks/results/${MY_BUILD_ID}/
Write-Host "Done."
"""
}
2020-02-17 16:29:35 +01:00
echo "Done."
2020-02-13 15:32:05 +01:00
}
}
}