89 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
| #!/bin/bash
 | |
| 
 | |
| # Copyright 2017 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.
 | |
| 
 | |
| ROOT="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"/..
 | |
| . ${ROOT}/hack/versions
 | |
| 
 | |
| # start_cri_containerd starts containerd and cri-containerd.
 | |
| start_cri_containerd() {
 | |
|   local report_dir=$1 
 | |
|   if [ ! -x ${ROOT}/_output/cri-containerd ]; then
 | |
|     echo "cri-containerd is not built"
 | |
|     exit 1
 | |
|   fi
 | |
| 
 | |
|   # Start containerd
 | |
|   if [ ! -x "$(command -v containerd)" ]; then
 | |
|     echo "containerd is not installed, please run hack/install-deps.sh"
 | |
|     exit 1
 | |
|   fi
 | |
|   kill_cri_containerd
 | |
|   sudo containerd -l debug &> ${report_dir}/containerd.log &
 | |
| 
 | |
|   # Wait for containerd to be running by using the containerd client ctr to check the version
 | |
|   # of the containerd server. Wait an increasing amount of time after each of five attempts
 | |
|   local MAX_ATTEMPTS=5
 | |
|   local attempt_num=1
 | |
|   until sudo ctr version &> /dev/null || (( attempt_num == MAX_ATTEMPTS ))
 | |
|   do
 | |
|       echo "attempt $attempt_num to connect to containerd failed! Trying again in $attempt_num seconds..."
 | |
|       sleep $(( attempt_num++ ))
 | |
|   done
 | |
| 
 | |
|   # Start cri-containerd
 | |
|   sudo ${ROOT}/_output/cri-containerd --alsologtostderr --v 4 &> ${report_dir}/cri-containerd.log &
 | |
| }
 | |
| 
 | |
| # kill_cri_containerd kills containerd and cri-containerd.
 | |
| kill_cri_containerd() {
 | |
|   sudo pkill containerd
 | |
| }
 | |
| 
 | |
| # upload_logs_to_gcs uploads test logs to gcs.
 | |
| # Var set:
 | |
| # 1. Bucket: gcs bucket to upload logs.
 | |
| # 2. Dir: directory name to upload logs.
 | |
| # 3. Test Result: directory of the test result.
 | |
| upload_logs_to_gcs() {
 | |
|   local -r bucket=$1
 | |
|   local -r dir=$2
 | |
|   local -r result=$3
 | |
|   if ! gsutil ls "gs://${bucket}" > /dev/null; then
 | |
|     create_ttl_bucket ${bucket}
 | |
|   fi
 | |
|   local -r upload_log_path=${bucket}/${dir}
 | |
|   gsutil cp -r "${REPORT_DIR}" "gs://${upload_log_path}"
 | |
|   echo "Test logs are uploaed to:
 | |
|     http://gcsweb.k8s.io/gcs/${upload_log_path}/"
 | |
| }
 | |
| 
 | |
| # create_ttl_bucket create a public bucket in which all objects
 | |
| # have a default TTL (30 days).
 | |
| # Var set:
 | |
| # 1. Bucket: gcs bucket name.
 | |
| create_ttl_bucket() {
 | |
|   local -r bucket=$1
 | |
|   gsutil mb "gs://${bucket}"
 | |
|   local -r bucket_rule=$(mktemp)
 | |
|   # Set 30 day TTL for logs inside the bucket.
 | |
|   echo '{"rule": [{"action": {"type": "Delete"},"condition": {"age": 30}}]}' > ${bucket_rule}
 | |
|   gsutil lifecycle set "${bucket_rule}" "gs://${bucket}"
 | |
|   rm "${bucket_rule}"
 | |
| 
 | |
|   gsutil -m acl ch -g all:R "gs://${bucket}"
 | |
|   gsutil defacl set public-read "gs://${bucket}"
 | |
| }
 | 
