From f892b0575d29d25d97fdbe7f08b8753e138af4bf Mon Sep 17 00:00:00 2001 From: Chun-Hung Tseng Date: Wed, 18 Sep 2024 14:32:09 +0200 Subject: [PATCH] Update update_dep.sh Based on the experience of performing dependency bumps, some minor improvements are made to the script to make it conform to our current dependency bump procedure, listed as follows: - print out the dependency's version before and after the bump - check if the dependency is fully indirect - change the behavior of bumping dependency (doesn't ignore bumping indirect dependency in the go mod files anymore) - check if all dependencies across all go mod files have the same pinned version respectively after bumping a dependency Signed-off-by: Chun-Hung Tseng --- scripts/update_dep.sh | 43 +++++++++++++++++++++++++++++++++++++------ 1 file changed, 37 insertions(+), 6 deletions(-) diff --git a/scripts/update_dep.sh b/scripts/update_dep.sh index e76ecaff5c5a..dc2fbdf281e5 100755 --- a/scripts/update_dep.sh +++ b/scripts/update_dep.sh @@ -13,21 +13,52 @@ set -euo pipefail source ./scripts/test_lib.sh +if [ "$#" -ne 2 ]; then + echo "Illegal number of parameters" + exit 1 +fi + mod="$1" ver="$2" -function maybe_update_module { +function print_current_dep_version { + echo "${mod} version in all go mod files" + grep --exclude-dir=.git --include=\*.mod -Ri "^.*${mod} v.*$" | grep -v sum + printf "\n\n" +} + +function is_fully_indirect { + # check if all lines end with "// indirect" + # if grep found nothing, the error code will be non-zero + ALL=$(grep --exclude-dir=.git --include=\*.mod -Ri "^.*${mod} v.*$" | grep -v sum | wc -l) + ONLY_INDIRECT=$(grep --exclude-dir=.git --include=\*.mod -Ri "^.*${mod} v.*// indirect$" | grep -v sum | wc -l) + if [[ "$ALL" == "$ONLY_INDIRECT" ]]; then + echo "Fully indirect, we will terminate the script" + exit 1 + else + echo "Not fully indirect, we will perform dependency bump" + fi +} + +function update_module { run go mod tidy - deps=$(go list -f '{{if not .Indirect}}{{if .Version}}{{.Path}},{{.Version}}{{end}}{{end}}' -m all) + deps=$(go list -f '{{if .Version}}{{.Path}},{{.Version}}{{end}}' -m all) if [[ "$deps" == *"${mod}"* ]]; then if [ -z "${ver}" ]; then - run go get "${mod}" + run go get -u "${mod}" else run go get "${mod}@${ver}" fi fi - } +} + +print_current_dep_version +is_fully_indirect +run_for_modules update_module + +# check all dependencies across all go mod files have the same pinned version respectively +PASSES="dep" ./scripts/test.sh -go mod tidy -run_for_modules maybe_update_module +./scripts/fix.sh +print_current_dep_version