common.sh 9.5 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
#!/bin/bash

# Copyright 2016 The Kubernetes Authors All rights reserved.
#
# 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.


# This script downloads the test files from the build bucket and makes some executable.

X
Xinbo Weng 已提交
20
# The script expects the following env variables:
21
# OS_ARCH: The operating system and the architecture separated by a hyphen '-' (e.g. darwin-amd64, linux-amd64, windows-amd64)
M
Matt Rickard 已提交
22
# VM_DRIVER: the vm-driver to use for the test
23 24
# EXTRA_START_ARGS: additional flags to pass into minikube start
# EXTRA_ARGS: additional flags to pass into minikube
M
Matt Rickard 已提交
25
# JOB_NAME: the name of the logfile and check name to update on github
26
# PARALLEL_COUNT: number of tests to run in parallel
27

28

29 30 31 32 33 34 35 36 37 38 39
readonly TEST_ROOT="${HOME}/minikube-integration"
readonly TEST_HOME="${TEST_ROOT}/${OS_ARCH}-${VM_DRIVER}-${MINIKUBE_LOCATION}-$$-${COMMIT}"
echo ">> Starting at $(date)"
echo ""
echo "arch:      ${OS_ARCH}"
echo "build:     ${MINIKUBE_LOCATION}"
echo "driver:    ${VM_DRIVER}"
echo "job:       ${JOB_NAME}"
echo "test home: ${TEST_HOME}"
echo "sudo:      ${SUDO_PREFIX}"
echo "kernel:    $(uname -v)"
40
echo "uptime:    $(uptime)"
41 42 43 44
# Setting KUBECONFIG prevents the version ceck from erroring out due to permission issues
echo "kubectl:   $(env KUBECONFIG=${TEST_HOME} kubectl version --client --short=true)"
echo "docker:    $(docker version --format '{{ .Client.Version }}')"

45 46 47
readonly LOAD=$(uptime | egrep -o "load average.*: [0-9]" | cut -d" " -f3)
if [[ "${LOAD}" -gt 2 ]]; then
  echo ""
48 49 50 51 52 53 54 55 56
  echo "********************** LOAD WARNING ********************************"
  echo "Load average is very high (${LOAD}), which may cause failures. Top:"
  if [[ "$(uname)" == "Darwin" ]]; then
    # Two samples, macOS does not calculate CPU usage on the first one
    top -l 2 -o cpu -n 5 | tail -n 15
  else
    top -b -n1 | head -n 15
  fi
  echo "********************** LOAD WARNING ********************************"
57 58 59
  echo ""
fi

60 61 62 63 64 65 66 67 68 69
case "${VM_DRIVER}" in
  kvm2)
    echo "virsh:     $(virsh --version)"
  ;;
  virtualbox)
    echo "vbox:      $(vboxmanage --version)"
  ;;
esac

echo ""
70
mkdir -p out/ testdata/
71 72

# Install gsutil if necessary.
73
if ! type -P gsutil >/dev/null; then
74 75 76 77
  if [[ ! -x "out/gsutil/gsutil" ]]; then
    echo "Installing gsutil to $(pwd)/out ..."
    curl -s https://storage.googleapis.com/pub/gsutil.tar.gz | tar -C out/ -zxf -
  fi
78
  PATH="$(pwd)/out/gsutil:$PATH"
79 80 81
fi

# Add the out/ directory to the PATH, for using new drivers.
82 83
PATH="$(pwd)/out/":$PATH
export PATH
84

85 86 87 88 89
echo ""
echo ">> Downloading test inputs from ${MINIKUBE_LOCATION} ..."
gsutil -qm cp \
  "gs://minikube-builds/${MINIKUBE_LOCATION}/minikube-${OS_ARCH}" \
  "gs://minikube-builds/${MINIKUBE_LOCATION}/docker-machine-driver"-* \
90
  "gs://minikube-builds/${MINIKUBE_LOCATION}/e2e-${OS_ARCH}" out
D
dlorenc 已提交
91

92
gsutil -qm cp -r "gs://minikube-builds/${MINIKUBE_LOCATION}/testdata"/* testdata/
D
dlorenc 已提交
93

94 95
gsutil -qm cp "gs://minikube-builds/${MINIKUBE_LOCATION}/gvisor-addon" testdata/

D
dlorenc 已提交
96

97 98 99 100
# Set the executable bit on the e2e binary and out binary
export MINIKUBE_BIN="out/minikube-${OS_ARCH}"
export E2E_BIN="out/e2e-${OS_ARCH}"
chmod +x "${MINIKUBE_BIN}" "${E2E_BIN}" out/docker-machine-driver-*
T
tstromberg 已提交
101
"${MINIKUBE_BIN}" version
102

T
Thomas Stromberg 已提交
103
procs=$(pgrep "minikube-${OS_ARCH}|e2e-${OS_ARCH}" || true)
104
if [[ "${procs}" != "" ]]; then
M
Medya Gh 已提交
105
  echo "Warning: found stale test processes to kill:"
106 107 108
  ps -f -p ${procs} || true
  kill ${procs} || true
  kill -9 ${procs} || true
109
fi
110

T
tstromberg 已提交
111 112 113
# Quickly notice misconfigured test roots
mkdir -p "${TEST_ROOT}"

114
# Cleanup stale test outputs.
115 116
echo ""
echo ">> Cleaning up after previous test runs ..."
T
tstromberg 已提交
117
for entry in $(ls ${TEST_ROOT}); do
118 119 120 121 122
  test_path="${TEST_ROOT}/${entry}"
  ls -lad "${test_path}" || continue

  echo "* Cleaning stale test path: ${test_path}"
  for tunnel in $(find ${test_path} -name tunnels.json -type f); do
123 124
    env MINIKUBE_HOME="$(dirname ${tunnel})" ${MINIKUBE_BIN} tunnel --cleanup || true
  done
D
dlorenc 已提交
125

126
  for home in $(find ${test_path} -name .minikube -type d); do
127
    env MINIKUBE_HOME="$(dirname ${home})" ${MINIKUBE_BIN} delete --all || true
T
tstromberg 已提交
128
    sudo rm -Rf "${home}"
129
  done
130

131
  for kconfig in $(find ${test_path} -name kubeconfig -type f); do
132 133 134
    sudo rm -f "${kconfig}"
  done

T
tstromberg 已提交
135
  # Be very specific to avoid accidentally deleting other items, like wildcards or devices
136 137 138 139
  if [[ -d "${test_path}" ]]; then
    rm -Rf "${test_path}" || true
  elif [[ -f "${test_path}" ]]; then
    rm -f "${test_path}" || true
T
tstromberg 已提交
140
  fi
141
done
142 143 144 145

# sometimes tests left over zombie procs that won't exit
# for example:
# jenkins  20041  0.0  0.0      0     0 ?        Z    Aug19   0:00 [minikube-linux-] <defunct>
M
Medya Gh 已提交
146
zombie_defuncts=$(ps -A -ostat,ppid | awk '/[zZ]/ && !a[$2]++ {print $2}')
147 148
if [[ "${zombie_defuncts}" != "" ]]; then
  echo "Found zombie defunct procs to kill..."
M
Medya Gh 已提交
149
  ps -f -p ${zombie_defuncts} || true
150
  kill ${zombie_defuncts} || true
151 152
fi

153
if type -P virsh; then
T
Thomas Stromberg 已提交
154
  virsh -c qemu:///system list --all --uuid \
T
Thomas Stromberg 已提交
155 156
    | xargs -I {} sh -c "virsh -c qemu:///system destroy {}; virsh -c qemu:///system undefine {}" \
    || true
157
  echo ">> virsh VM list after clean up (should be empty):"
M
Medya Gh 已提交
158
  virsh -c qemu:///system list --all || true
159
fi
160

161
if type -P vboxmanage; then
162
  for guid in $(vboxmanage list vms | grep -Eo '\{[a-zA-Z0-9-]+\}'); do
163
    echo "- Removing stale VirtualBox VM: $guid"
164 165
    vboxmanage startvm "${guid}" --type emergencystop || true
    vboxmanage unregistervm "${guid}" || true
166
  done
T
tstromberg 已提交
167

168
  ifaces=$(vboxmanage list hostonlyifs | grep -E "^Name:" | awk '{ print $2 }')
169 170 171
  for if in $ifaces; do
    vboxmanage hostonlyif remove "${if}" || true
  done
T
tstromberg 已提交
172

173
  echo ">> VirtualBox VM list after clean up (should be empty):"
M
Medya Gh 已提交
174
  vboxmanage list vms || true
175 176
  echo ">> VirtualBox interface list after clean up (should be empty):"
  vboxmanage list hostonlyifs || true
177 178
fi

M
Medya Gh 已提交
179

180
if type -P hdiutil; then
T
Thomas Stromberg 已提交
181
  hdiutil info | grep -E "/dev/disk[1-9][^s]" || true
182 183
  hdiutil info \
      | grep -E "/dev/disk[1-9][^s]" \
184
      | awk '{print $1}' \
185 186
      | xargs -I {} sh -c "hdiutil detach {}" \
      || true
187
fi
188

M
Medya Gh 已提交
189 190
# cleaning up stale hyperkits
if type -P hyperkit; then
191 192 193 194 195 196
  for pid in $(pgrep hyperkit); do
    echo "Killing stale hyperkit $pid"
    ps -f -p $pid || true
    kill $pid || true
    kill -9 $pid || true
  done
M
Medya Gh 已提交
197 198
fi

199
if [[ "${VM_DRIVER}" == "hyperkit" ]]; then
200 201
  if [[ -e out/docker-machine-driver-hyperkit ]]; then
    sudo chown root:wheel out/docker-machine-driver-hyperkit || true
202
    sudo chmod u+s out/docker-machine-driver-hyperkit || true
203 204
  fi
fi
D
dlorenc 已提交
205

T
Thomas Stromberg 已提交
206
kprocs=$(pgrep kubectl || true)
207 208
if [[ "${kprocs}" != "" ]]; then
  echo "error: killing hung kubectl processes ..."
T
Thomas Stromberg 已提交
209
  ps -f -p ${kprocs} || true
210
  sudo -E kill ${kprocs} || true
D
dlorenc 已提交
211
fi
M
Matt Rickard 已提交
212

213
# clean up none drivers binding on 8443
M
Medya Gh 已提交
214 215 216 217 218 219
  none_procs=$(sudo lsof -i :8443 | tail -n +2 | awk '{print $2}' || true)
  if [[ "${none_procs}" != "" ]]; then
    echo "Found stale api servers listening on 8443 processes to kill: "
    for p in $none_procs
    do
    echo "Kiling stale none driver:  $p"
M
Medya Gh 已提交
220 221 222
    sudo -E ps -f -p $p || true
    sudo -E kill $p || true
    sudo -E kill -9 $p || true
M
Medya Gh 已提交
223 224
    done
  fi
225

226
function cleanup_stale_routes() {
227 228 229 230 231 232
  local show="netstat -rn -f inet"
  local del="sudo route -n delete"

  if [[ "$(uname)" == "Linux" ]]; then
    show="ip route show"
    del="sudo ip route delete"
233
  fi
234 235 236 237 238 239

  local troutes=$($show | awk '{ print $1 }' | grep 10.96.0.0 || true)
  for route in ${troutes}; do
    echo "WARNING: deleting stale tunnel route: ${route}"
    $del "${route}" || true
  done
240 241 242 243
}

cleanup_stale_routes || true

244
mkdir -p "${TEST_HOME}"
245 246
export MINIKUBE_HOME="${TEST_HOME}/.minikube"
export KUBECONFIG="${TEST_HOME}/kubeconfig"
247

248 249
# Build the gvisor image. This will be copied into minikube and loaded by ctr.
# Used by TestContainerd for Gvisor Test.
250 251 252 253 254 255
# TODO: move this to integration test setup.
chmod +x ./testdata/gvisor-addon
# skipping gvisor mac because ofg https://github.com/kubernetes/minikube/issues/5137
if [ "$(uname)" != "Darwin" ]; then
  docker build -t gcr.io/k8s-minikube/gvisor-addon:latest -f testdata/gvisor-addon-Dockerfile ./testdata
fi
256

257 258 259
echo ""
echo ">> Starting ${E2E_BIN} at $(date)"
${SUDO_PREFIX}${E2E_BIN} \
260
  -minikube-start-args="--vm-driver=${VM_DRIVER} ${EXTRA_START_ARGS}" \
261 262 263
  -test.timeout=60m \
  -test.parallel=${PARALLEL_COUNT} \
  -binary="${MINIKUBE_BIN}" && result=$? || result=$?
264 265
echo ">> ${E2E_BIN} exited with ${result} at $(date)"
echo ""
266

M
Matt Rickard 已提交
267 268
if [[ $result -eq 0 ]]; then
  status="success"
269
  echo "minikube: SUCCESS"
M
Matt Rickard 已提交
270 271
else
  status="failure"
272
  echo "minikube: FAIL"
M
Matt Rickard 已提交
273 274
fi

275
echo ">> Cleaning up after ourselves ..."
276
${SUDO_PREFIX}${MINIKUBE_BIN} tunnel --cleanup || true
277
${SUDO_PREFIX}${MINIKUBE_BIN} delete >/dev/null 2>/dev/null || true
278
cleanup_stale_routes || true
T
Thomas Stromberg 已提交
279 280 281

${SUDO_PREFIX} rm -Rf "${MINIKUBE_HOME}" || true
${SUDO_PREFIX} rm -f "${KUBECONFIG}" || true
282
rmdir "${TEST_HOME}"
283 284
echo ">> ${TEST_HOME} completed at $(date)"

T
Thomas Stromberg 已提交
285
if [[ "${MINIKUBE_LOCATION}" != "master" ]]; then
286
  readonly target_url="https://storage.googleapis.com/minikube-builds/logs/${MINIKUBE_LOCATION}/${JOB_NAME}.txt"
T
Thomas Stromberg 已提交
287
  curl -s "https://api.github.com/repos/kubernetes/minikube/statuses/${COMMIT}?access_token=$access_token" \
M
Matt Rickard 已提交
288 289 290
  -H "Content-Type: application/json" \
  -X POST \
  -d "{\"state\": \"$status\", \"description\": \"Jenkins\", \"target_url\": \"$target_url\", \"context\": \"${JOB_NAME}\"}"
291
fi
T
Thomas Stromberg 已提交
292
exit $result