mirror of
				https://github.com/k3s-io/kubernetes.git
				synced 2025-10-22 15:09:39 +00:00 
			
		
		
		
	Automatic merge from submit-queue. If you want to cherry-pick this change to another branch, please follow the instructions <a href="https://github.com/kubernetes/community/blob/master/contributors/devel/cherry-picks.md">here</a>. Fix update-swagger-spec.sh to always cleanup etcd **What this PR does / why we need it**: This PR fixes `hack/update-swagger-spec.sh` so it always cleanup etcd and to noe leave orphaned process after its execution. This process also doesn't allow to run the script again as it detects existing etcd and won't start. I also made a minor improvement by adding guard against an empty arguments. **Release note**: ```release-note NONE ``` CC @simo5
		
			
				
	
	
		
			97 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			97 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/bash
 | |
| 
 | |
| # Copyright 2015 The Kubernetes Authors.
 | |
| #
 | |
| # Licensed under the Apache License, Version 2.0 (the "License");
 | |
| # you may not use this file except in compliance with the License.
 | |
| # You may obtain a copy of the License at
 | |
| #
 | |
| #     http://www.apache.org/licenses/LICENSE-2.0
 | |
| #
 | |
| # Unless required by applicable law or agreed to in writing, software
 | |
| # distributed under the License is distributed on an "AS IS" BASIS,
 | |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| # See the License for the specific language governing permissions and
 | |
| # limitations under the License.
 | |
| 
 | |
| # Script to fetch latest swagger spec.
 | |
| # Puts the updated spec at api/swagger-spec/
 | |
| 
 | |
| set -o errexit
 | |
| set -o nounset
 | |
| set -o pipefail
 | |
| 
 | |
| cat << __EOF__
 | |
| Note: This assumes that the 'types_swagger_doc_generated.go' file has been
 | |
| updated for all API group versions. If you are unsure, please run
 | |
| hack/update-generated-swagger-docs.sh first.
 | |
| __EOF__
 | |
| 
 | |
| KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
 | |
| SWAGGER_ROOT_DIR="${KUBE_ROOT}/api/swagger-spec"
 | |
| source "${KUBE_ROOT}/hack/lib/init.sh"
 | |
| 
 | |
| kube::golang::setup_env
 | |
| 
 | |
| make -C "${KUBE_ROOT}" WHAT=cmd/kube-apiserver
 | |
| 
 | |
| function cleanup()
 | |
| {
 | |
|     if [[ -n "${APISERVER_PID-}" ]]; then
 | |
|       kill "${APISERVER_PID}" &>/dev/null || :
 | |
|       wait "${APISERVER_PID}" &>/dev/null || :
 | |
|     fi
 | |
| 
 | |
|     kube::etcd::cleanup
 | |
| 
 | |
|     kube::log::status "Clean up complete"
 | |
| }
 | |
| 
 | |
| kube::util::trap_add cleanup EXIT
 | |
| 
 | |
| kube::golang::setup_env
 | |
| 
 | |
| apiserver=$(kube::util::find-binary "kube-apiserver")
 | |
| 
 | |
| TMP_DIR=$(mktemp -d /tmp/update-swagger-spec.XXXX)
 | |
| ETCD_HOST=${ETCD_HOST:-127.0.0.1}
 | |
| ETCD_PORT=${ETCD_PORT:-2379}
 | |
| API_PORT=${API_PORT:-8050}
 | |
| API_HOST=${API_HOST:-127.0.0.1}
 | |
| API_LOGFILE=/tmp/swagger-api-server.log
 | |
| 
 | |
| kube::etcd::start
 | |
| 
 | |
| 
 | |
| # Start kube-apiserver, with alpha api versions on so we can harvest their swagger docs
 | |
| # Set --runtime-config to all versions in KUBE_AVAILABLE_GROUP_VERSIONS to enable alpha features.
 | |
| kube::log::status "Starting kube-apiserver"
 | |
| "${KUBE_OUTPUT_HOSTBIN}/kube-apiserver" \
 | |
|   --insecure-bind-address="${API_HOST}" \
 | |
|   --bind-address="${API_HOST}" \
 | |
|   --insecure-port="${API_PORT}" \
 | |
|   --etcd-servers="http://${ETCD_HOST}:${ETCD_PORT}" \
 | |
|   --advertise-address="10.10.10.10" \
 | |
|   --cert-dir="${TMP_DIR}/certs" \
 | |
|   --runtime-config=$(echo "${KUBE_AVAILABLE_GROUP_VERSIONS}" | sed -E 's|[[:blank:]]+|,|g') \
 | |
|   --service-cluster-ip-range="10.0.0.0/24" >"${API_LOGFILE}" 2>&1 &
 | |
| APISERVER_PID=$!
 | |
| 
 | |
| if ! kube::util::wait_for_url "${API_HOST}:${API_PORT}/healthz" "apiserver: "; then
 | |
|   kube::log::error "Here are the last 10 lines from kube-apiserver (${API_LOGFILE})"
 | |
|   kube::log::error "=== BEGIN OF LOG ==="
 | |
|   tail -10 "${API_LOGFILE}" || :
 | |
|   kube::log::error "=== END OF LOG ==="
 | |
|   exit 1
 | |
| fi
 | |
| 
 | |
| SWAGGER_API_PATH="${API_HOST}:${API_PORT}/swaggerapi/"
 | |
| 
 | |
| kube::log::status "Updating " ${SWAGGER_ROOT_DIR}
 | |
| 
 | |
| SWAGGER_API_PATH="${SWAGGER_API_PATH}" SWAGGER_ROOT_DIR="${SWAGGER_ROOT_DIR}" VERSIONS="${KUBE_AVAILABLE_GROUP_VERSIONS}" KUBE_NONSERVER_GROUP_VERSIONS="${KUBE_NONSERVER_GROUP_VERSIONS}" kube::util::fetch-swagger-spec
 | |
| 
 | |
| kube::log::status "SUCCESS"
 | |
| 
 | |
| # ex: ts=2 sw=2 et filetype=sh
 |