From ad862900acb3d4e288a5a3c3dd62b9d69d9266f4 Mon Sep 17 00:00:00 2001 From: Dimitrios Liappis Date: Wed, 10 Jan 2024 10:18:19 +0200 Subject: [PATCH] Run BK exhaustive pipeline when code is pushed (#15738) This commit enables running the exhaustive tests Buildkite pipeline (i.e. the equivalent to the `main` Jenkins tests) ; the trigger is code events, i.e. direct pushes, merge commits and creation of new branches. CI is skipped if changes are only related to files under `docs/`. --- .buildkite/exhaustive_tests_pipeline.yml | 12 ++++++++- .../scripts/common/check-files-changed.sh | 26 +++++++++++++++++++ catalog-info.yaml | 0 3 files changed, 37 insertions(+), 1 deletion(-) create mode 100755 .buildkite/scripts/common/check-files-changed.sh create mode 100644 catalog-info.yaml diff --git a/.buildkite/exhaustive_tests_pipeline.yml b/.buildkite/exhaustive_tests_pipeline.yml index 174625711a0..fadccf232d1 100644 --- a/.buildkite/exhaustive_tests_pipeline.yml +++ b/.buildkite/exhaustive_tests_pipeline.yml @@ -2,9 +2,19 @@ steps: - label: "Exhaustive tests pipeline" command: | #!/usr/bin/env bash + echo "--- Check for docs changes" + set +e + .buildkite/scripts/common/check-files-changed.sh '^docs/.*' + if [[ $$? -eq 0 ]]; then + echo "^^^ +++" + echo "Skipping running pipeline as all changes are related to docs." + exit 0 + else + echo "Changes are not exclusively related to docs, continuing." + fi + set -eo pipefail - source .buildkite/scripts/common/container-agent.sh echo "--- Downloading prerequisites" python3 -m pip install ruamel.yaml curl -fsSL --retry-max-time 60 --retry 3 --retry-delay 5 -o /usr/bin/yq https://github.com/mikefarah/yq/releases/latest/download/yq_linux_amd64 diff --git a/.buildkite/scripts/common/check-files-changed.sh b/.buildkite/scripts/common/check-files-changed.sh new file mode 100755 index 00000000000..c04db83b28b --- /dev/null +++ b/.buildkite/scripts/common/check-files-changed.sh @@ -0,0 +1,26 @@ +#!/usr/bin/env bash + +# ********************************************************** +# Returns true if current checkout compared to parent commit +# has changes ONLY matching the argument regexp +# +# Used primarily to skip running the exhaustive pipeline +# when only docs changes have happened. +# ******************************************************** + +if [[ -z "$1" ]]; then + echo "Usage: $0 " + exit 1 +fi + +previous_commit=$(git rev-parse HEAD^) +changed_files=$(git diff --name-only $previous_commit) + +if [[ -n "$changed_files" ]] && [[ -z "$(echo "$changed_files" | grep -vE "$1")" ]]; then + echo "All files compared to the previous commit [$previous_commit] match the specified regex: [$1]" + echo "Files changed:" + git diff --name-only HEAD^ + exit 0 +else + exit 1 +fi diff --git a/catalog-info.yaml b/catalog-info.yaml new file mode 100644 index 00000000000..e69de29bb2d