mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-23 03:41:45 +00:00
Codegen: use ls files and pre-remove gen'ed mocks
This commit is contained in:
parent
600e46801d
commit
0a8f102497
@ -37,61 +37,66 @@ function cleanup {
|
||||
trap cleanup EXIT
|
||||
|
||||
kube::golang::verify_go_version
|
||||
kube::golang::setup_env
|
||||
|
||||
echo 'installing mockgen'
|
||||
pushd "${KUBE_ROOT}/hack/tools" >/dev/null
|
||||
go install github.com/golang/mock/mockgen
|
||||
popd >/dev/null
|
||||
|
||||
find_files() {
|
||||
find . -not \( \
|
||||
\( \
|
||||
-wholename './output' \
|
||||
-o -wholename './.git' \
|
||||
-o -wholename './_output' \
|
||||
-o -wholename './_gopath' \
|
||||
-o -wholename './release' \
|
||||
-o -wholename './target' \
|
||||
-o -wholename '*/third_party/*' \
|
||||
-o -wholename '*/vendor/*' \
|
||||
-o -wholename './staging/src/k8s.io/client-go/*vendor/*' \
|
||||
-o -wholename '*/bindata.go' \
|
||||
\) -prune \
|
||||
\) -name '*.go'
|
||||
function git_find() {
|
||||
# Similar to find but faster and easier to understand. We want to include
|
||||
# modified and untracked files because this might be running against code
|
||||
# which is not tracked by git yet.
|
||||
git ls-files -cmo --exclude-standard \
|
||||
':!:vendor/*' \
|
||||
':!:third_party/*' \
|
||||
':!:*/testdata/*' \
|
||||
"$@"
|
||||
}
|
||||
|
||||
cd "${KUBE_ROOT}"
|
||||
|
||||
GENERATED_MOCK_FILE_REGEX="^// Code generated by MockGen. DO NOT EDIT.$"
|
||||
|
||||
# We use this pattern here rather than `git grep` because we don't really want
|
||||
# to encode the pathspec list in multiple places and anything more complicated
|
||||
# just isn't worth the effort.
|
||||
git_find -z ':(glob)**/*.go' \
|
||||
| { xargs -0 grep -l --null "${GENERATED_MOCK_FILE_REGEX}" || true; } \
|
||||
| xargs -0 rm -f
|
||||
|
||||
echo 'executing go generate command on below files'
|
||||
|
||||
for IFILE in $(find_files | xargs grep --files-with-matches -e '//go:generate mockgen'); do
|
||||
temp_file_name=$(mktemp --tmpdir="${_tmp}")
|
||||
# serach for build tag used in file
|
||||
build_tag_string=$(grep -o '+build.*$' "$IFILE") || true
|
||||
git_find -z ':(glob)**/*.go' | while read -r -d $'\0' file; do
|
||||
test -f "$file" || continue
|
||||
grep -q "//go:generate mockgen" "$file" || continue
|
||||
|
||||
temp_file_name="$(kube::realpath "$(mktemp -t "$(basename "$0").XXXXXX")")"
|
||||
|
||||
# search for build tag used in file
|
||||
build_tag_string=$(grep -o '+build.*$' "$file") || true
|
||||
|
||||
# if the file does not have build string
|
||||
if [ -n "$build_tag_string" ]
|
||||
then
|
||||
if [ -n "$build_tag_string" ]; then
|
||||
# write the build tag in the temp file
|
||||
echo -n "$build_tag_string" > "$temp_file_name"
|
||||
|
||||
# if +build tag is defined in interface file
|
||||
BUILD_TAG_FILE=$temp_file_name go generate -v "$IFILE"
|
||||
BUILD_TAG_FILE=$temp_file_name go generate -v "$file"
|
||||
else
|
||||
# if no +build tag is defined in interface file
|
||||
go generate -v "$IFILE"
|
||||
go generate -v "$file"
|
||||
fi
|
||||
done
|
||||
|
||||
# get the changed or new mock files
|
||||
git ls-files -mo --exclude-standard -z | while read -r -d $'\0' file; do
|
||||
# only process files that appear to be mocks
|
||||
test -f "$file" || continue
|
||||
grep -q "${GENERATED_MOCK_FILE_REGEX}" "$file" || continue
|
||||
|
||||
# get the changed mock files
|
||||
files=$(git diff --name-only)
|
||||
for file in $files; do
|
||||
if [ "$file" == "hack/update-mocks.sh" ]; then
|
||||
continue
|
||||
fi
|
||||
|
||||
# serach for build tags used in file
|
||||
# search for build tags used in file
|
||||
# //go:build !providerless
|
||||
# // +build !providerless
|
||||
go_build_tag_string=$(grep -o 'go:build.*$' "$file") || true
|
||||
@ -128,7 +133,7 @@ for file in $files; do
|
||||
tail -n +2 "$file" > tempfile
|
||||
fi
|
||||
|
||||
# if the header if generted
|
||||
# if the header is generated
|
||||
if [ -n "$new_header" ]
|
||||
then
|
||||
# write the newly generated header file to the original file
|
||||
|
Loading…
Reference in New Issue
Block a user