b5606770f6
* Update verify-changes to support external docs branches Signed-off-by: Jaymala Sinha <jaymala@hashicorp.com> * Revert QT-545 as it Enos workflow is not a workflow_run event Signed-off-by: Jaymala Sinha <jaymala@hashicorp.com> --------- Signed-off-by: Jaymala Sinha <jaymala@hashicorp.com>
32 lines
1.1 KiB
Bash
Executable file
32 lines
1.1 KiB
Bash
Executable file
#!/bin/bash
|
|
# This script validates if the git diff contains on docs changes
|
|
|
|
event_type=$1 # GH event type (pull_request)
|
|
ref_name=$2 # branch reference that triggered the workflow
|
|
base_ref=$3 # PR branch base ref
|
|
|
|
changed_dir=""
|
|
|
|
if [[ "$event_type" == "pull_request" ]]; then
|
|
git fetch --no-tags --prune origin $base_ref
|
|
head_commit="HEAD"
|
|
base_commit="origin/$base_ref"
|
|
else
|
|
git fetch --no-tags --prune origin $ref_name
|
|
head_commit=$(git log origin/$ref_name --oneline | head -1 | awk '{print $1}')
|
|
base_commit=$(git log origin/$ref_name --oneline | head -2 | awk 'NR==2 {print $1}')
|
|
fi
|
|
|
|
# git diff with ... shows the differences count between base_commit and head_commit starting at the last common commit
|
|
change_count=$(git diff $base_commit...$head_commit --name-only | awk -F"/" '{ print $1}' | uniq | wc -l)
|
|
|
|
if [[ $change_count -eq 1 ]]; then
|
|
changed_dir=$(git diff $base_commit...$head_commit --name-only | awk -F"/" '{ print $1}' | uniq)
|
|
fi
|
|
|
|
if [[ "$changed_dir" == "website" ]]; then
|
|
echo "is_docs_change=true" >> "$GITHUB_OUTPUT"
|
|
else
|
|
echo "is_docs_change=false" >> "$GITHUB_OUTPUT"
|
|
fi
|