mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-17 14:26:49 +00:00

In this patch I'm using a new lit option so that the pipeline writes many results files, one for each time lit is run: ``` --use-unique-output-file-name When enabled, lit will add a unique element to the output file name, before the extension. For example "results.xml" will become "results.<something>.xml". The "<something>" is not ordered in any way and is chosen so that existing files are not overwritten. [Default: Off] ``` (I added this to lit recently) Alternatives were considered: * mkfifo - does not work on bash for Windows. * tail -f - does not print full content on file truncation * lit wrapper script - more complication than using an option to lit itself * ninja/mv file/ninja/mv file etc - lots of changes needed to make the scripts build each target separately And after feedback I decided that using an option to lit itself is the cleanest way to go. It can be removed when we no longer need it. If I run the Linux build after this change: ``` $ bash ./.ci/monolithic-linux.sh "clang;lldb;lld" "check-lldb-shell check-lld" "libcxx;libcxxabi" "check-libcxx check-libcxxabi" ``` I get multiple test result files. In my case some tests fail so runtimes aren't checked, but all projects are so there is 1 file for lldb and one for lld: ``` $ ls build/*.xml build/test-results.klc82utf.xml build/test-results.majylh73.xml ``` This change just collects the XML files as artifacts. Once I know that's working, I can set up test reporting to make a summary of them.
316 lines
8.1 KiB
Bash
Executable File
316 lines
8.1 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
#===----------------------------------------------------------------------===##
|
|
#
|
|
# Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
# See https://llvm.org/LICENSE.txt for license information.
|
|
# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
#
|
|
#===----------------------------------------------------------------------===##
|
|
|
|
#
|
|
# This file generates a Buildkite pipeline that triggers the various CI jobs for
|
|
# the LLVM project during pre-commit CI.
|
|
#
|
|
# See https://buildkite.com/docs/agent/v3/cli-pipeline#pipeline-format.
|
|
#
|
|
# As this outputs a yaml file, it's possible to log messages to stderr or
|
|
# prefix with "#".
|
|
|
|
|
|
set -eu
|
|
set -o pipefail
|
|
|
|
# Environment variables script works with:
|
|
|
|
# Set by buildkite
|
|
: ${BUILDKITE_PULL_REQUEST_BASE_BRANCH:=}
|
|
: ${BUILDKITE_COMMIT:=}
|
|
: ${BUILDKITE_BRANCH:=}
|
|
# Fetch origin to have an up to date merge base for the diff.
|
|
git fetch origin
|
|
# List of files affected by this commit
|
|
: ${MODIFIED_FILES:=$(git diff --name-only origin/${BUILDKITE_PULL_REQUEST_BASE_BRANCH}...HEAD)}
|
|
# Filter rules for generic windows tests
|
|
: ${WINDOWS_AGENTS:='{"queue": "windows"}'}
|
|
# Filter rules for generic linux tests
|
|
: ${LINUX_AGENTS:='{"queue": "linux"}'}
|
|
|
|
reviewID="$(git log --format=%B -n 1 | sed -nE 's/^Review-ID:[[:space:]]*(.+)$/\1/p')"
|
|
if [[ "${reviewID}" != "" ]]; then
|
|
buildMessage="https://llvm.org/${reviewID}"
|
|
else
|
|
buildMessage="Push to branch ${BUILDKITE_BRANCH}"
|
|
fi
|
|
|
|
cat <<EOF
|
|
steps:
|
|
EOF
|
|
|
|
echo "Files modified:" >&2
|
|
echo "$MODIFIED_FILES" >&2
|
|
modified_dirs=$(echo "$MODIFIED_FILES" | cut -d'/' -f1 | sort -u)
|
|
echo "Directories modified:" >&2
|
|
echo "$modified_dirs" >&2
|
|
|
|
function compute-projects-to-test() {
|
|
isForWindows=$1
|
|
shift
|
|
projects=${@}
|
|
for project in ${projects}; do
|
|
echo "${project}"
|
|
case ${project} in
|
|
lld)
|
|
for p in bolt cross-project-tests; do
|
|
echo $p
|
|
done
|
|
;;
|
|
llvm)
|
|
for p in bolt clang clang-tools-extra lld lldb mlir polly; do
|
|
echo $p
|
|
done
|
|
# Flang is not stable in Windows CI at the moment
|
|
if [[ $isForWindows == 0 ]]; then
|
|
echo flang
|
|
fi
|
|
;;
|
|
clang)
|
|
# lldb is temporarily removed to alleviate Linux pre-commit CI waiting times
|
|
for p in clang-tools-extra compiler-rt cross-project-tests; do
|
|
echo $p
|
|
done
|
|
;;
|
|
clang-tools-extra)
|
|
echo libc
|
|
;;
|
|
mlir)
|
|
# Flang is not stable in Windows CI at the moment
|
|
if [[ $isForWindows == 0 ]]; then
|
|
echo flang
|
|
fi
|
|
;;
|
|
*)
|
|
# Nothing to do
|
|
;;
|
|
esac
|
|
done
|
|
}
|
|
|
|
function compute-runtimes-to-test() {
|
|
projects=${@}
|
|
for project in ${projects}; do
|
|
case ${project} in
|
|
clang)
|
|
for p in libcxx libcxxabi libunwind; do
|
|
echo $p
|
|
done
|
|
;;
|
|
*)
|
|
# Nothing to do
|
|
;;
|
|
esac
|
|
done
|
|
}
|
|
|
|
function add-dependencies() {
|
|
projects=${@}
|
|
for project in ${projects}; do
|
|
echo "${project}"
|
|
case ${project} in
|
|
bolt)
|
|
for p in clang lld llvm; do
|
|
echo $p
|
|
done
|
|
;;
|
|
cross-project-tests)
|
|
for p in lld clang; do
|
|
echo $p
|
|
done
|
|
;;
|
|
clang-tools-extra)
|
|
for p in llvm clang; do
|
|
echo $p
|
|
done
|
|
;;
|
|
compiler-rt|libc|openmp)
|
|
echo clang lld
|
|
;;
|
|
flang|lldb|libclc)
|
|
for p in llvm clang; do
|
|
echo $p
|
|
done
|
|
;;
|
|
lld|mlir|polly)
|
|
echo llvm
|
|
;;
|
|
*)
|
|
# Nothing to do
|
|
;;
|
|
esac
|
|
done
|
|
}
|
|
|
|
function exclude-linux() {
|
|
projects=${@}
|
|
for project in ${projects}; do
|
|
case ${project} in
|
|
cross-project-tests) ;; # tests failing
|
|
openmp) ;; # https://github.com/google/llvm-premerge-checks/issues/410
|
|
*)
|
|
echo "${project}"
|
|
;;
|
|
esac
|
|
done
|
|
}
|
|
|
|
function exclude-windows() {
|
|
projects=${@}
|
|
for project in ${projects}; do
|
|
case ${project} in
|
|
cross-project-tests) ;; # tests failing
|
|
compiler-rt) ;; # tests taking too long
|
|
openmp) ;; # TODO: having trouble with the Perl installation
|
|
libc) ;; # no Windows support
|
|
lldb) ;; # custom environment requirements (https://github.com/llvm/llvm-project/pull/94208#issuecomment-2146256857)
|
|
bolt) ;; # tests are not supported yet
|
|
*)
|
|
echo "${project}"
|
|
;;
|
|
esac
|
|
done
|
|
}
|
|
|
|
# Prints only projects that are both present in $modified_dirs and the passed
|
|
# list.
|
|
function keep-modified-projects() {
|
|
projects=${@}
|
|
for project in ${projects}; do
|
|
if echo "$modified_dirs" | grep -q -E "^${project}$"; then
|
|
echo "${project}"
|
|
fi
|
|
done
|
|
}
|
|
|
|
function check-targets() {
|
|
# Do not use "check-all" here because if there is "check-all" plus a
|
|
# project specific target like "check-clang", that project's tests
|
|
# will be run twice.
|
|
projects=${@}
|
|
for project in ${projects}; do
|
|
case ${project} in
|
|
clang-tools-extra)
|
|
echo "check-clang-tools"
|
|
;;
|
|
compiler-rt)
|
|
echo "check-compiler-rt"
|
|
;;
|
|
cross-project-tests)
|
|
echo "check-cross-project"
|
|
;;
|
|
libcxx)
|
|
echo "check-cxx"
|
|
;;
|
|
libcxxabi)
|
|
echo "check-cxxabi"
|
|
;;
|
|
libunwind)
|
|
echo "check-unwind"
|
|
;;
|
|
lldb)
|
|
echo "check-lldb"
|
|
;;
|
|
pstl)
|
|
# Currently we do not run pstl tests in CI.
|
|
;;
|
|
libclc)
|
|
# Currently there is no testing for libclc.
|
|
;;
|
|
*)
|
|
echo "check-${project}"
|
|
;;
|
|
esac
|
|
done
|
|
}
|
|
|
|
# Project specific pipelines.
|
|
|
|
# If libc++ or one of the runtimes directories changed.
|
|
if echo "$modified_dirs" | grep -q -E "^(libcxx|libcxxabi|libunwind|runtimes|cmake)$"; then
|
|
cat <<EOF
|
|
- trigger: "libcxx-ci"
|
|
build:
|
|
message: "${buildMessage}"
|
|
commit: "${BUILDKITE_COMMIT}"
|
|
branch: "${BUILDKITE_BRANCH}"
|
|
EOF
|
|
fi
|
|
|
|
# Generic pipeline for projects that have not defined custom steps.
|
|
#
|
|
# Individual projects should instead define the pre-commit CI tests that suits their
|
|
# needs while letting them run on the infrastructure provided by LLVM.
|
|
|
|
# Figure out which projects need to be built on each platform
|
|
all_projects="bolt clang clang-tools-extra compiler-rt cross-project-tests flang libc libclc lld lldb llvm mlir openmp polly pstl"
|
|
modified_projects="$(keep-modified-projects ${all_projects})"
|
|
|
|
linux_projects_to_test=$(exclude-linux $(compute-projects-to-test 0 ${modified_projects}))
|
|
linux_check_targets=$(check-targets ${linux_projects_to_test} | sort | uniq)
|
|
linux_projects=$(add-dependencies ${linux_projects_to_test} | sort | uniq)
|
|
|
|
linux_runtimes_to_test=$(compute-runtimes-to-test ${linux_projects_to_test})
|
|
linux_runtime_check_targets=$(check-targets ${linux_runtimes_to_test} | sort | uniq)
|
|
linux_runtimes=$(echo ${linux_runtimes_to_test} | sort | uniq)
|
|
|
|
windows_projects_to_test=$(exclude-windows $(compute-projects-to-test 1 ${modified_projects}))
|
|
windows_check_targets=$(check-targets ${windows_projects_to_test} | sort | uniq)
|
|
windows_projects=$(add-dependencies ${windows_projects_to_test} | sort | uniq)
|
|
|
|
# Generate the appropriate pipeline
|
|
if [[ "${linux_projects}" != "" ]]; then
|
|
cat <<EOF
|
|
- label: ':linux: Linux x64'
|
|
artifact_paths:
|
|
- 'artifacts/**/*'
|
|
- '*_result.json'
|
|
- 'build/test-results.*.xml'
|
|
agents: ${LINUX_AGENTS}
|
|
retry:
|
|
automatic:
|
|
- exit_status: -1 # Agent was lost
|
|
limit: 2
|
|
- exit_status: 255 # Forced agent shutdown
|
|
limit: 2
|
|
timeout_in_minutes: 120
|
|
env:
|
|
CC: 'clang'
|
|
CXX: 'clang++'
|
|
commands:
|
|
- './.ci/monolithic-linux.sh "$(echo ${linux_projects} | tr ' ' ';')" "$(echo ${linux_check_targets})" "$(echo ${linux_runtimes} | tr ' ' ';')" "$(echo ${linux_runtime_check_targets})"'
|
|
EOF
|
|
fi
|
|
|
|
if [[ "${windows_projects}" != "" ]]; then
|
|
cat <<EOF
|
|
- label: ':windows: Windows x64'
|
|
artifact_paths:
|
|
- 'artifacts/**/*'
|
|
- '*_result.json'
|
|
- 'build/test-results.*.xml'
|
|
agents: ${WINDOWS_AGENTS}
|
|
retry:
|
|
automatic:
|
|
- exit_status: -1 # Agent was lost
|
|
limit: 2
|
|
- exit_status: 255 # Forced agent shutdown
|
|
limit: 2
|
|
timeout_in_minutes: 150
|
|
env:
|
|
CC: 'cl'
|
|
CXX: 'cl'
|
|
LD: 'link'
|
|
commands:
|
|
- 'C:\\BuildTools\\Common7\\Tools\\VsDevCmd.bat -arch=amd64 -host_arch=amd64'
|
|
- 'bash .ci/monolithic-windows.sh "$(echo ${windows_projects} | tr ' ' ';')" "$(echo ${windows_check_targets})"'
|
|
EOF
|
|
fi
|