2018-07-06 03:23:27 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
# Copyright 2018 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.
|
|
|
|
|
2019-06-28 21:40:18 +00:00
|
|
|
if [ -n "$DEBUG" ]; then
|
|
|
|
set -x
|
2019-05-14 02:31:30 +00:00
|
|
|
fi
|
|
|
|
|
2018-07-06 03:23:27 +00:00
|
|
|
set -o errexit
|
|
|
|
set -o nounset
|
|
|
|
set -o pipefail
|
|
|
|
|
2019-09-25 15:55:21 +00:00
|
|
|
# temporal directory for the /etc/ingress-controller directory
|
|
|
|
INGRESS_VOLUME=$(mktemp -d)
|
2019-07-09 13:24:52 +00:00
|
|
|
|
2021-07-29 21:23:19 +00:00
|
|
|
# make sure directory for SSL cert storage exists under ingress volume
|
|
|
|
mkdir "${INGRESS_VOLUME}/ssl"
|
|
|
|
|
2020-01-25 23:17:26 +00:00
|
|
|
if [[ "$OSTYPE" == darwin* ]]; then
|
|
|
|
INGRESS_VOLUME=/private$INGRESS_VOLUME
|
|
|
|
fi
|
|
|
|
|
2019-07-09 13:24:52 +00:00
|
|
|
function cleanup {
|
2019-09-25 15:55:21 +00:00
|
|
|
rm -rf "${INGRESS_VOLUME}"
|
2019-07-09 13:24:52 +00:00
|
|
|
}
|
|
|
|
trap cleanup EXIT
|
|
|
|
|
2022-04-01 11:37:08 +00:00
|
|
|
E2E_IMAGE=${E2E_IMAGE:-k8s.gcr.io/ingress-nginx/e2e-test-runner:v20220331-controller-v1.1.2-31-gf1cb2b73c@sha256:baa326f5c726d65be828852943a259c1f0572883590b9081b7e8fa982d64d96e}
|
2018-07-06 03:23:27 +00:00
|
|
|
|
2019-06-28 21:40:18 +00:00
|
|
|
DOCKER_OPTS=${DOCKER_OPTS:-}
|
2020-06-27 15:57:00 +00:00
|
|
|
DOCKER_IN_DOCKER_ENABLED=${DOCKER_IN_DOCKER_ENABLED:-}
|
2018-07-06 03:23:27 +00:00
|
|
|
|
2019-07-09 13:24:52 +00:00
|
|
|
KUBE_ROOT=$(cd $(dirname "${BASH_SOURCE}")/.. && pwd -P)
|
|
|
|
|
2018-07-06 03:23:27 +00:00
|
|
|
FLAGS=$@
|
|
|
|
|
2019-05-24 00:47:14 +00:00
|
|
|
PKG=k8s.io/ingress-nginx
|
2020-03-19 00:00:37 +00:00
|
|
|
ARCH=${ARCH:-}
|
|
|
|
if [[ -z "$ARCH" ]]; then
|
|
|
|
ARCH=$(go env GOARCH)
|
|
|
|
fi
|
2018-07-06 03:23:27 +00:00
|
|
|
|
2020-01-09 16:48:43 +00:00
|
|
|
# create output directory as current user to avoid problem with docker.
|
|
|
|
mkdir -p "${KUBE_ROOT}/bin" "${KUBE_ROOT}/bin/${ARCH}"
|
|
|
|
|
2022-04-06 20:46:26 +00:00
|
|
|
PLATFORM="${PLATFORM:-}"
|
|
|
|
if [[ -n "$PLATFORM" ]]; then
|
|
|
|
PLATFORM_FLAG=--platform
|
|
|
|
else
|
|
|
|
PLATFORM_FLAG=
|
|
|
|
fi
|
|
|
|
|
2022-05-04 11:57:51 +00:00
|
|
|
if [[ "$DOCKER_IN_DOCKER_ENABLED" == "true" ]]; then
|
|
|
|
/bin/bash -c "${FLAGS}"
|
|
|
|
else
|
|
|
|
docker run \
|
2022-04-06 20:46:26 +00:00
|
|
|
${PLATFORM_FLAG} ${PLATFORM} \
|
2020-06-27 15:57:00 +00:00
|
|
|
--tty \
|
|
|
|
--rm \
|
|
|
|
${DOCKER_OPTS} \
|
|
|
|
-e GOCACHE="/go/src/${PKG}/.cache" \
|
2021-08-06 14:18:17 +00:00
|
|
|
-e GOMODCACHE="/go/src/${PKG}/.modcache" \
|
2020-06-27 15:57:00 +00:00
|
|
|
-e DOCKER_IN_DOCKER_ENABLED="true" \
|
|
|
|
-v "${HOME}/.kube:${HOME}/.kube" \
|
|
|
|
-v "${KUBE_ROOT}:/go/src/${PKG}" \
|
|
|
|
-v "${KUBE_ROOT}/bin/${ARCH}:/go/bin/linux_${ARCH}" \
|
|
|
|
-v "/var/run/docker.sock:/var/run/docker.sock" \
|
|
|
|
-v "${INGRESS_VOLUME}:/etc/ingress-controller/" \
|
|
|
|
-w "/go/src/${PKG}" \
|
|
|
|
-u $(id -u ${USER}):$(id -g ${USER}) \
|
|
|
|
${E2E_IMAGE} /bin/bash -c "${FLAGS}"
|
2022-05-04 11:57:51 +00:00
|
|
|
fi
|