k8s.io/kubernetes@v1.31.0-alpha.0.0.20240520171757-56147500dadc/hack/verify-fieldname-docs.sh (about) 1 #!/usr/bin/env bash 2 3 # Copyright 2023 The Kubernetes Authors. 4 # 5 # Licensed under the Apache License, Version 2.0 (the "License"); 6 # you may not use this file except in compliance with the License. 7 # You may obtain a copy of the License at 8 # 9 # http://www.apache.org/licenses/LICENSE-2.0 10 # 11 # Unless required by applicable law or agreed to in writing, software 12 # distributed under the License is distributed on an "AS IS" BASIS, 13 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14 # See the License for the specific language governing permissions and 15 # limitations under the License. 16 17 # This script checks API-related files for mismatch in docs and field names, 18 # and outputs a list of fields that their docs and field names are mismatched. 19 # Usage: `hack/verify-fieldname-docs.sh`. 20 21 set -o errexit 22 set -o nounset 23 set -o pipefail 24 25 KUBE_ROOT=$(dirname "${BASH_SOURCE[0]}")/.. 26 source "${KUBE_ROOT}/hack/lib/init.sh" 27 source "${KUBE_ROOT}/hack/lib/util.sh" 28 29 kube::golang::setup_env 30 31 GOPROXY=off go install ./cmd/fieldnamedocscheck 32 33 find_files() { 34 find . -not \( \ 35 \( \ 36 -wholename '.git' \ 37 -o -wholename './_output' \ 38 -o -wholename './release' \ 39 -o -wholename './target' \ 40 -o -wholename '*/third_party/*' \ 41 -o -wholename '*/vendor/*' \ 42 -o -wholename './pkg/*' \ 43 \) -prune \ 44 \) \ 45 \( -wholename './staging/src/k8s.io/api/*/v*/types.go' \ 46 -o -wholename './staging/src/k8s.io/kube-aggregator/pkg/apis/*/v*/types.go' \ 47 -o -wholename './staging/src/k8s.io/apiextensions-apiserver/pkg/apis/*/v*/types.go' \ 48 \) 49 } 50 51 versioned_api_files=$(find_files) || true 52 53 result=0 54 for file in ${versioned_api_files}; do 55 package="${file%"/types.go"}" 56 echo "Checking ${package}" 57 fieldnamedocscheck -s "${file}" || result=$? 58 done 59 60 exit ${result}