[CI] Cleanup buildkite test report script
This patch removes the generate_test_report_buildkite script entrypoint as we no longer need it now that buildkite has been sunsetted. Also remove the calls in the monolithic-* scripts given they are adding complexity for no value. Also remove the generate-buildkite-pipeline-premerge script as it is no longer needed. Reviewers: tstellar, DavidSpickett, lnihlen, cmtice Reviewed By: DavidSpickett Pull Request: https://github.com/llvm/llvm-project/pull/143480
This commit is contained in:
parent
214ca3161b
commit
99cdc26c94
@ -1,131 +0,0 @@
|
|||||||
#!/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
|
|
||||||
|
|
||||||
# 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
|
|
||||||
source <(git diff --name-only origin/${BUILDKITE_PULL_REQUEST_BASE_BRANCH}...HEAD | python3 .ci/compute_projects.py Linux)
|
|
||||||
linux_projects=${projects_to_build}
|
|
||||||
linux_check_targets=${project_check_targets}
|
|
||||||
linux_runtimes=${runtimes_to_build}
|
|
||||||
linux_runtime_check_targets=${runtimes_check_targets}
|
|
||||||
|
|
||||||
source <(git diff --name-only origin/${BUILDKITE_PULL_REQUEST_BASE_BRANCH}...HEAD | python3 .ci/compute_projects.py Windows)
|
|
||||||
windows_projects=${projects_to_build}
|
|
||||||
windows_check_targets=${project_check_targets}
|
|
||||||
|
|
||||||
|
|
||||||
# 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:
|
|
||||||
MAX_PARALLEL_COMPILE_JOBS: '16'
|
|
||||||
MAX_PARALLEL_LINK_JOBS: '4'
|
|
||||||
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
|
|
@ -1,57 +0,0 @@
|
|||||||
# 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
|
|
||||||
"""Script to generate a build report for buildkite."""
|
|
||||||
|
|
||||||
import argparse
|
|
||||||
import os
|
|
||||||
import subprocess
|
|
||||||
|
|
||||||
import generate_test_report_lib
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
|
||||||
parser = argparse.ArgumentParser()
|
|
||||||
parser.add_argument(
|
|
||||||
"title", help="Title of the test report, without Markdown formatting."
|
|
||||||
)
|
|
||||||
parser.add_argument("context", help="Annotation context to write to.")
|
|
||||||
parser.add_argument("return_code", help="The build's return code.", type=int)
|
|
||||||
parser.add_argument("junit_files", help="Paths to JUnit report files.", nargs="*")
|
|
||||||
args = parser.parse_args()
|
|
||||||
|
|
||||||
# All of these are required to build a link to download the log file.
|
|
||||||
env_var_names = [
|
|
||||||
"BUILDKITE_ORGANIZATION_SLUG",
|
|
||||||
"BUILDKITE_PIPELINE_SLUG",
|
|
||||||
"BUILDKITE_BUILD_NUMBER",
|
|
||||||
"BUILDKITE_JOB_ID",
|
|
||||||
]
|
|
||||||
buildkite_info = {k: v for k, v in os.environ.items() if k in env_var_names}
|
|
||||||
if len(buildkite_info) != len(env_var_names):
|
|
||||||
buildkite_info = None
|
|
||||||
|
|
||||||
report, style = generate_test_report_lib.generate_report_from_files(
|
|
||||||
args.title, args.return_code, args.junit_files, buildkite_info
|
|
||||||
)
|
|
||||||
|
|
||||||
if report:
|
|
||||||
p = subprocess.Popen(
|
|
||||||
[
|
|
||||||
"buildkite-agent",
|
|
||||||
"annotate",
|
|
||||||
"--context",
|
|
||||||
args.context,
|
|
||||||
"--style",
|
|
||||||
style,
|
|
||||||
],
|
|
||||||
stdin=subprocess.PIPE,
|
|
||||||
stderr=subprocess.PIPE,
|
|
||||||
universal_newlines=True,
|
|
||||||
)
|
|
||||||
|
|
||||||
# The report can be larger than the buffer for command arguments so we send
|
|
||||||
# it over stdin instead.
|
|
||||||
_, err = p.communicate(input=report)
|
|
||||||
if p.returncode:
|
|
||||||
raise RuntimeError(f"Failed to send report to buildkite-agent:\n{err}")
|
|
@ -42,14 +42,9 @@ function at-exit {
|
|||||||
|
|
||||||
# If building fails there will be no results files.
|
# If building fails there will be no results files.
|
||||||
shopt -s nullglob
|
shopt -s nullglob
|
||||||
if command -v buildkite-agent 2>&1 >/dev/null
|
|
||||||
then
|
python3 "${MONOREPO_ROOT}"/.ci/generate_test_report_github.py ":penguin: Linux x64 Test Results" \
|
||||||
python3 "${MONOREPO_ROOT}"/.ci/generate_test_report_buildkite.py ":linux: Linux x64 Test Results" \
|
$retcode "${BUILD_DIR}"/test-results.*.xml >> $GITHUB_STEP_SUMMARY
|
||||||
"linux-x64-test-results" $retcode "${BUILD_DIR}"/test-results.*.xml
|
|
||||||
else
|
|
||||||
python3 "${MONOREPO_ROOT}"/.ci/generate_test_report_github.py ":penguin: Linux x64 Test Results" \
|
|
||||||
$retcode "${BUILD_DIR}"/test-results.*.xml >> $GITHUB_STEP_SUMMARY
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
trap at-exit EXIT
|
trap at-exit EXIT
|
||||||
|
|
||||||
|
@ -37,14 +37,9 @@ function at-exit {
|
|||||||
|
|
||||||
# If building fails there will be no results files.
|
# If building fails there will be no results files.
|
||||||
shopt -s nullglob
|
shopt -s nullglob
|
||||||
if command -v buildkite-agent 2>&1 >/dev/null
|
|
||||||
then
|
python "${MONOREPO_ROOT}"/.ci/generate_test_report_github.py ":window: Windows x64 Test Results" \
|
||||||
python "${MONOREPO_ROOT}"/.ci/generate_test_report_buildkite.py ":windows: Windows x64 Test Results" \
|
$retcode "${BUILD_DIR}"/test-results.*.xml >> $GITHUB_STEP_SUMMARY
|
||||||
"windows-x64-test-results" $retcode "${BUILD_DIR}"/test-results.*.xml
|
|
||||||
else
|
|
||||||
python "${MONOREPO_ROOT}"/.ci/generate_test_report_github.py ":window: Windows x64 Test Results" \
|
|
||||||
$retcode "${BUILD_DIR}"/test-results.*.xml >> $GITHUB_STEP_SUMMARY
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
trap at-exit EXIT
|
trap at-exit EXIT
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user