update all container tags with date and sha, upgrade all containers (#9834)
Signed-off-by: James Strong <strong.james.e@gmail.com>
This commit is contained in:
parent
6c3b83d8cb
commit
ea46af8c8e
24 changed files with 90 additions and 68 deletions
1
.github/workflows/ci.yaml
vendored
1
.github/workflows/ci.yaml
vendored
|
@ -22,6 +22,7 @@ on:
|
||||||
required: false
|
required: false
|
||||||
type: boolean
|
type: boolean
|
||||||
|
|
||||||
|
|
||||||
permissions:
|
permissions:
|
||||||
contents: read
|
contents: read
|
||||||
|
|
||||||
|
|
|
@ -20,5 +20,5 @@ set -o pipefail
|
||||||
|
|
||||||
KUBE_ROOT="$( cd "$(dirname "$0")../" >/dev/null 2>&1 ; pwd -P )"
|
KUBE_ROOT="$( cd "$(dirname "$0")../" >/dev/null 2>&1 ; pwd -P )"
|
||||||
# TODO: This is a temporary workaround while we don't update Helm Chart test
|
# TODO: This is a temporary workaround while we don't update Helm Chart test
|
||||||
curl https://raw.githubusercontent.com/helm/chart-testing/v3.7.0/etc/chart_schema.yaml -o /tmp/chart_schema.yaml
|
curl https://raw.githubusercontent.com/helm/chart-testing/v3.8.0/etc/chart_schema.yaml -o /tmp/chart_schema.yaml
|
||||||
ct lint --charts ${KUBE_ROOT}/charts/ingress-nginx --validate-maintainers=false --chart-yaml-schema=/tmp/chart_schema.yaml
|
ct lint --charts ${KUBE_ROOT}/charts/ingress-nginx --validate-maintainers=false --chart-yaml-schema=/tmp/chart_schema.yaml
|
||||||
|
|
|
@ -6,7 +6,6 @@ steps:
|
||||||
entrypoint: bash
|
entrypoint: bash
|
||||||
env:
|
env:
|
||||||
- DOCKER_CLI_EXPERIMENTAL=enabled
|
- DOCKER_CLI_EXPERIMENTAL=enabled
|
||||||
- TAG=$_GIT_TAG
|
|
||||||
- BASE_REF=$_PULL_BASE_REF
|
- BASE_REF=$_PULL_BASE_REF
|
||||||
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
||||||
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
||||||
|
|
|
@ -14,8 +14,11 @@
|
||||||
|
|
||||||
FROM alpine:3.17.2
|
FROM alpine:3.17.2
|
||||||
|
|
||||||
|
|
||||||
RUN echo "@testing http://nl.alpinelinux.org/alpine/edge/testing" >> /etc/apk/repositories
|
RUN echo "@testing http://nl.alpinelinux.org/alpine/edge/testing" >> /etc/apk/repositories
|
||||||
RUN apk add --no-cache \
|
RUN apk update \
|
||||||
|
&& apk upgrade && \
|
||||||
|
apk add --no-cache \
|
||||||
bash \
|
bash \
|
||||||
cfssl@testing
|
cfssl@testing
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,6 @@ steps:
|
||||||
entrypoint: bash
|
entrypoint: bash
|
||||||
env:
|
env:
|
||||||
- DOCKER_CLI_EXPERIMENTAL=enabled
|
- DOCKER_CLI_EXPERIMENTAL=enabled
|
||||||
- TAG=$_GIT_TAG
|
|
||||||
- BASE_REF=$_PULL_BASE_REF
|
- BASE_REF=$_PULL_BASE_REF
|
||||||
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
||||||
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
||||||
|
|
|
@ -13,7 +13,9 @@
|
||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
FROM golang:1.20.1-alpine3.17 as builder
|
FROM golang:1.20.1-alpine3.17 as builder
|
||||||
RUN apk add git
|
|
||||||
|
RUN apk update \
|
||||||
|
&& apk upgrade && apk add git
|
||||||
|
|
||||||
WORKDIR /go/src/k8s.io/ingress-nginx/images/custom-error-pages
|
WORKDIR /go/src/k8s.io/ingress-nginx/images/custom-error-pages
|
||||||
|
|
||||||
|
|
|
@ -18,7 +18,7 @@ SHELL=/bin/bash -o pipefail -o errexit
|
||||||
DIR:=$(strip $(shell dirname $(realpath $(lastword $(MAKEFILE_LIST)))))
|
DIR:=$(strip $(shell dirname $(realpath $(lastword $(MAKEFILE_LIST)))))
|
||||||
INIT_BUILDX=$(DIR)/../../hack/init-buildx.sh
|
INIT_BUILDX=$(DIR)/../../hack/init-buildx.sh
|
||||||
|
|
||||||
TAG ?=v1.0.0
|
TAG ?=v$(shell date +%Y%m%d)-$(shell git rev-parse --short HEAD)
|
||||||
REGISTRY ?= local
|
REGISTRY ?= local
|
||||||
|
|
||||||
IMAGE = $(REGISTRY)/e2e-test-echo
|
IMAGE = $(REGISTRY)/e2e-test-echo
|
||||||
|
|
|
@ -6,7 +6,6 @@ steps:
|
||||||
entrypoint: bash
|
entrypoint: bash
|
||||||
env:
|
env:
|
||||||
- DOCKER_CLI_EXPERIMENTAL=enabled
|
- DOCKER_CLI_EXPERIMENTAL=enabled
|
||||||
- TAG=$_GIT_TAG
|
|
||||||
- BASE_REF=$_PULL_BASE_REF
|
- BASE_REF=$_PULL_BASE_REF
|
||||||
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
||||||
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
||||||
|
|
|
@ -2,7 +2,7 @@ ARG BASE_IMAGE
|
||||||
|
|
||||||
FROM ${BASE_IMAGE}
|
FROM ${BASE_IMAGE}
|
||||||
|
|
||||||
RUN apk add -U perl curl make unzip
|
RUN apk update && apk upgrade && apk add -U --no-cache perl curl make unzip
|
||||||
|
|
||||||
ARG LUAROCKS_VERSION
|
ARG LUAROCKS_VERSION
|
||||||
ARG LUAROCKS_SHA
|
ARG LUAROCKS_SHA
|
||||||
|
|
|
@ -8,7 +8,6 @@ steps:
|
||||||
entrypoint: bash
|
entrypoint: bash
|
||||||
env:
|
env:
|
||||||
- DOCKER_CLI_EXPERIMENTAL=enabled
|
- DOCKER_CLI_EXPERIMENTAL=enabled
|
||||||
- TAG=$_GIT_TAG
|
|
||||||
- BASE_REF=$_PULL_BASE_REF
|
- BASE_REF=$_PULL_BASE_REF
|
||||||
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
||||||
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
||||||
|
|
|
@ -6,7 +6,6 @@ steps:
|
||||||
entrypoint: bash
|
entrypoint: bash
|
||||||
env:
|
env:
|
||||||
- DOCKER_CLI_EXPERIMENTAL=enabled
|
- DOCKER_CLI_EXPERIMENTAL=enabled
|
||||||
- TAG=$_GIT_TAG
|
|
||||||
- BASE_REF=$_PULL_BASE_REF
|
- BASE_REF=$_PULL_BASE_REF
|
||||||
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
||||||
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
||||||
|
|
|
@ -8,7 +8,6 @@ steps:
|
||||||
entrypoint: bash
|
entrypoint: bash
|
||||||
env:
|
env:
|
||||||
- DOCKER_CLI_EXPERIMENTAL=enabled
|
- DOCKER_CLI_EXPERIMENTAL=enabled
|
||||||
- TAG=$_GIT_TAG
|
|
||||||
- BASE_REF=$_PULL_BASE_REF
|
- BASE_REF=$_PULL_BASE_REF
|
||||||
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
||||||
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
||||||
|
|
|
@ -8,7 +8,6 @@ steps:
|
||||||
entrypoint: bash
|
entrypoint: bash
|
||||||
env:
|
env:
|
||||||
- DOCKER_CLI_EXPERIMENTAL=enabled
|
- DOCKER_CLI_EXPERIMENTAL=enabled
|
||||||
- TAG=$_GIT_TAG
|
|
||||||
- BASE_REF=$_PULL_BASE_REF
|
- BASE_REF=$_PULL_BASE_REF
|
||||||
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
||||||
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
||||||
|
|
|
@ -17,7 +17,7 @@ FROM alpine:3.17.2
|
||||||
ENV LC_ALL=C.UTF-8
|
ENV LC_ALL=C.UTF-8
|
||||||
ENV LANG=C.UTF-8
|
ENV LANG=C.UTF-8
|
||||||
|
|
||||||
RUN apk update \
|
RUN apk upgrade && apk update \
|
||||||
&& apk add --no-cache \
|
&& apk add --no-cache \
|
||||||
python3 python3-dev \
|
python3 python3-dev \
|
||||||
musl-dev gcc g++ make \
|
musl-dev gcc g++ make \
|
||||||
|
|
|
@ -21,7 +21,6 @@ steps:
|
||||||
entrypoint: bash
|
entrypoint: bash
|
||||||
env:
|
env:
|
||||||
- DOCKER_CLI_EXPERIMENTAL=enabled
|
- DOCKER_CLI_EXPERIMENTAL=enabled
|
||||||
- TAG=$_GIT_TAG
|
|
||||||
- BASE_REF=$_PULL_BASE_REF
|
- BASE_REF=$_PULL_BASE_REF
|
||||||
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
||||||
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
||||||
|
|
|
@ -21,7 +21,7 @@ DIR:=$(strip $(shell dirname $(realpath $(lastword $(MAKEFILE_LIST)))))
|
||||||
INIT_BUILDX=$(DIR)/../../hack/init-buildx.sh
|
INIT_BUILDX=$(DIR)/../../hack/init-buildx.sh
|
||||||
|
|
||||||
# 0.0.0 shouldn't clobber any released builds
|
# 0.0.0 shouldn't clobber any released builds
|
||||||
TAG ?= 0.0
|
TAG ?=v$(shell date +%Y%m%d)-$(shell git rev-parse --short HEAD)
|
||||||
REGISTRY ?= gcr.io/k8s-staging-ingress-nginx
|
REGISTRY ?= gcr.io/k8s-staging-ingress-nginx
|
||||||
|
|
||||||
IMAGE = $(REGISTRY)/nginx
|
IMAGE = $(REGISTRY)/nginx
|
||||||
|
|
|
@ -9,7 +9,6 @@ steps:
|
||||||
env:
|
env:
|
||||||
- DOCKER_CLI_EXPERIMENTAL=enabled
|
- DOCKER_CLI_EXPERIMENTAL=enabled
|
||||||
- BASE_REF=$_PULL_BASE_REF
|
- BASE_REF=$_PULL_BASE_REF
|
||||||
- TAG=$_PULL_BASE_SHA
|
|
||||||
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
||||||
- HOME=/root
|
- HOME=/root
|
||||||
args:
|
args:
|
||||||
|
|
|
@ -17,7 +17,7 @@ COPY . /
|
||||||
|
|
||||||
RUN apk update \
|
RUN apk update \
|
||||||
&& apk upgrade \
|
&& apk upgrade \
|
||||||
&& apk add -U bash \
|
&& apk add -U bash --no-cache \
|
||||||
&& /build.sh
|
&& /build.sh
|
||||||
|
|
||||||
# Use a multi-stage build
|
# Use a multi-stage build
|
||||||
|
|
|
@ -8,7 +8,6 @@ steps:
|
||||||
entrypoint: bash
|
entrypoint: bash
|
||||||
env:
|
env:
|
||||||
- DOCKER_CLI_EXPERIMENTAL=enabled
|
- DOCKER_CLI_EXPERIMENTAL=enabled
|
||||||
- TAG=$_GIT_TAG
|
|
||||||
- BASE_REF=$_PULL_BASE_REF
|
- BASE_REF=$_PULL_BASE_REF
|
||||||
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
||||||
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
||||||
|
|
|
@ -30,27 +30,52 @@ export DOCKER_CLI_EXPERIMENTAL=enabled
|
||||||
|
|
||||||
# build with buildx
|
# build with buildx
|
||||||
PLATFORMS?=linux/amd64,linux/arm64
|
PLATFORMS?=linux/amd64,linux/arm64
|
||||||
OUTPUT=
|
OUTPUT?=
|
||||||
PROGRESS=plain
|
PROGRESS=plain
|
||||||
|
|
||||||
build: ensure-buildx
|
image:
|
||||||
docker buildx build \
|
echo "Building docker image ($(ARCH))..."
|
||||||
--platform=${PLATFORMS} $(OUTPUT) \
|
docker build \
|
||||||
--progress=$(PROGRESS) \
|
${PLATFORM_FLAG} ${PLATFORM} \
|
||||||
|
--no-cache \
|
||||||
--pull \
|
--pull \
|
||||||
--build-arg BASE_IMAGE=$(NGINX_BASE_IMAGE) \
|
--push \
|
||||||
|
--build-arg BASE_IMAGE=${NGINX_BASE_IMAGE} \
|
||||||
--build-arg GOLANG_VERSION=1.20.1 \
|
--build-arg GOLANG_VERSION=1.20.1 \
|
||||||
--build-arg ETCD_VERSION=3.4.3-0 \
|
--build-arg ETCD_VERSION=3.4.3-0 \
|
||||||
--build-arg K8S_RELEASE=v1.24.2 \
|
--build-arg K8S_RELEASE=v1.26.0 \
|
||||||
--build-arg RESTY_CLI_VERSION=0.27 \
|
--build-arg RESTY_CLI_VERSION=0.27 \
|
||||||
--build-arg RESTY_CLI_SHA=e5f4f3128af49ba5c4d039d0554e5ae91bbe05866f60eccfa96d3653274bff90 \
|
--build-arg RESTY_CLI_SHA=e5f4f3128af49ba5c4d039d0554e5ae91bbe05866f60eccfa96d3653274bff90 \
|
||||||
--build-arg LUAROCKS_VERSION=3.8.0 \
|
--build-arg LUAROCKS_VERSION=3.8.0 \
|
||||||
--build-arg LUAROCKS_SHA=ab6612ca9ab87c6984871d2712d05525775e8b50172701a0a1cabddf76de2be7 \
|
--build-arg LUAROCKS_SHA=ab6612ca9ab87c6984871d2712d05525775e8b50172701a0a1cabddf76de2be7 \
|
||||||
--build-arg CHART_TESTING_VERSION=3.7.0 \
|
--build-arg CHART_TESTING_VERSION=3.8.0 \
|
||||||
--build-arg YAML_LINT_VERSION=1.27.1 \
|
--build-arg YAML_LINT_VERSION=1.27.1 \
|
||||||
--build-arg YAMALE_VERSION=4.0.4 \
|
--build-arg YAMALE_VERSION=4.0.4 \
|
||||||
--build-arg HELM_VERSION=v3.9.0 \
|
--build-arg HELM_VERSION=3.11.2 \
|
||||||
-t $(IMAGE):$(TAG) rootfs
|
--build-arg GINKGO_VERSION=2.9.0 \
|
||||||
|
--build-arg GOLINT_VERSION=latest \
|
||||||
|
-t ${IMAGE}:${TAG} rootfs
|
||||||
|
|
||||||
|
build: ensure-buildx
|
||||||
|
docker buildx build \
|
||||||
|
--platform=${PLATFORMS} ${OUTPUT} \
|
||||||
|
--progress=${PROGRESS} \
|
||||||
|
--pull \
|
||||||
|
--build-arg BASE_IMAGE=${NGINX_BASE_IMAGE} \
|
||||||
|
--build-arg GOLANG_VERSION=1.20.1 \
|
||||||
|
--build-arg ETCD_VERSION=3.4.3-0 \
|
||||||
|
--build-arg K8S_RELEASE=v1.26.0 \
|
||||||
|
--build-arg RESTY_CLI_VERSION=0.27 \
|
||||||
|
--build-arg RESTY_CLI_SHA=e5f4f3128af49ba5c4d039d0554e5ae91bbe05866f60eccfa96d3653274bff90 \
|
||||||
|
--build-arg LUAROCKS_VERSION=3.8.0 \
|
||||||
|
--build-arg LUAROCKS_SHA=ab6612ca9ab87c6984871d2712d05525775e8b50172701a0a1cabddf76de2be7 \
|
||||||
|
--build-arg CHART_TESTING_VERSION=3.8.0 \
|
||||||
|
--build-arg YAML_LINT_VERSION=1.27.1 \
|
||||||
|
--build-arg YAMALE_VERSION=4.0.4 \
|
||||||
|
--build-arg HELM_VERSION=3.11.2 \
|
||||||
|
--build-arg GINKGO_VERSION=2.9.0 \
|
||||||
|
--build-arg GOLINT_VERSION=latest \
|
||||||
|
-t ${IMAGE}:${TAG} rootfs
|
||||||
|
|
||||||
# push the cross built image
|
# push the cross built image
|
||||||
push: OUTPUT=--push
|
push: OUTPUT=--push
|
||||||
|
|
|
@ -6,7 +6,6 @@ steps:
|
||||||
entrypoint: bash
|
entrypoint: bash
|
||||||
env:
|
env:
|
||||||
- DOCKER_CLI_EXPERIMENTAL=enabled
|
- DOCKER_CLI_EXPERIMENTAL=enabled
|
||||||
- TAG=$_GIT_TAG
|
|
||||||
- BASE_REF=$_PULL_BASE_REF
|
- BASE_REF=$_PULL_BASE_REF
|
||||||
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
- REGISTRY=gcr.io/k8s-staging-ingress-nginx
|
||||||
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
# default cloudbuild has HOME=/builder/home and docker buildx is in /root/.docker/cli-plugins/docker-buildx
|
||||||
|
@ -20,3 +19,4 @@ steps:
|
||||||
substitutions:
|
substitutions:
|
||||||
_GIT_TAG: "12345"
|
_GIT_TAG: "12345"
|
||||||
_PULL_BASE_REF: "master"
|
_PULL_BASE_REF: "master"
|
||||||
|
_PULL_BASE_SHA: '12345'
|
|
@ -11,7 +11,6 @@
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
# See the License for the specific language governing permissions and
|
# See the License for the specific language governing permissions and
|
||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
ARG BASE_IMAGE
|
ARG BASE_IMAGE
|
||||||
ARG GOLANG_VERSION
|
ARG GOLANG_VERSION
|
||||||
ARG ETCD_VERSION
|
ARG ETCD_VERSION
|
||||||
|
@ -21,6 +20,20 @@ FROM registry.k8s.io/etcd:${ETCD_VERSION} as etcd
|
||||||
|
|
||||||
FROM ${BASE_IMAGE}
|
FROM ${BASE_IMAGE}
|
||||||
|
|
||||||
|
ARG RESTY_CLI_VERSION
|
||||||
|
ARG RESTY_CLI_SHA
|
||||||
|
ARG LUAROCKS_VERSION
|
||||||
|
ARG LUAROCKS_SHA
|
||||||
|
ARG TARGETARCH
|
||||||
|
ARG K8S_RELEASE
|
||||||
|
ARG CHART_TESTING_VERSION
|
||||||
|
ARG HELM_VERSION
|
||||||
|
ARG YAMALE_VERSION
|
||||||
|
ARG YAML_LINT_VERSION
|
||||||
|
ARG GINKGO_VERSION
|
||||||
|
ARG GOLINT_VERSION
|
||||||
|
|
||||||
|
|
||||||
RUN set -eux; \
|
RUN set -eux; \
|
||||||
if [ -e /etc/nsswitch.conf ]; then \
|
if [ -e /etc/nsswitch.conf ]; then \
|
||||||
grep '^hosts: files dns' /etc/nsswitch.conf; \
|
grep '^hosts: files dns' /etc/nsswitch.conf; \
|
||||||
|
@ -28,13 +41,16 @@ RUN set -eux; \
|
||||||
echo 'hosts: files dns' > /etc/nsswitch.conf; \
|
echo 'hosts: files dns' > /etc/nsswitch.conf; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
COPY --from=GO /usr/local/go /usr/local/go
|
COPY --from=GO /usr/local/go /usr/local/go
|
||||||
|
ENV GOPATH /go
|
||||||
|
ENV PATH $GOPATH/bin:/usr/local/go/bin:$PATH
|
||||||
|
RUN mkdir -p "$GOPATH/src" "$GOPATH/bin" && chmod -R 777 "$GOPATH"
|
||||||
|
|
||||||
COPY --from=etcd /usr/local/bin/etcd /usr/local/bin/etcd
|
COPY --from=etcd /usr/local/bin/etcd /usr/local/bin/etcd
|
||||||
|
|
||||||
RUN echo "@testing http://nl.alpinelinux.org/alpine/edge/testing" >> /etc/apk/repositories
|
RUN echo "@testing https://nl.alpinelinux.org/alpine/edge/testing" >> /etc/apk/repositories
|
||||||
|
|
||||||
RUN apk add --no-cache \
|
RUN apk update && apk upgrade && apk add --no-cache \
|
||||||
bash \
|
bash \
|
||||||
ca-certificates \
|
ca-certificates \
|
||||||
wget \
|
wget \
|
||||||
|
@ -48,19 +64,15 @@ RUN apk add --no-cache \
|
||||||
py-pip \
|
py-pip \
|
||||||
unzip \
|
unzip \
|
||||||
openssl \
|
openssl \
|
||||||
cfssl@testing
|
cfssl@testing \
|
||||||
|
curl \
|
||||||
|
tzdata \
|
||||||
|
libc6-compat
|
||||||
|
|
||||||
ENV GOPATH /go
|
RUN go install -v github.com/onsi/ginkgo/v2/ginkgo@v${GINKGO_VERSION} \
|
||||||
ENV PATH $GOPATH/bin:/usr/local/go/bin:$PATH
|
&& go install golang.org/x/lint/golint@${GOLINT_VERSION}
|
||||||
|
|
||||||
RUN mkdir -p "$GOPATH/src" "$GOPATH/bin" && chmod -R 777 "$GOPATH"
|
RUN wget -qO /tmp/resty_cli.tgz \
|
||||||
|
|
||||||
RUN go install github.com/onsi/ginkgo/v2/ginkgo@v2.9.0 && go install golang.org/x/lint/golint@latest
|
|
||||||
|
|
||||||
ARG RESTY_CLI_VERSION
|
|
||||||
ARG RESTY_CLI_SHA
|
|
||||||
|
|
||||||
RUN wget -O /tmp/resty_cli.tgz \
|
|
||||||
https://github.com/openresty/resty-cli/archive/v${RESTY_CLI_VERSION}.tar.gz \
|
https://github.com/openresty/resty-cli/archive/v${RESTY_CLI_VERSION}.tar.gz \
|
||||||
&& echo "${RESTY_CLI_SHA} */tmp/resty_cli.tgz" | sha256sum -c - \
|
&& echo "${RESTY_CLI_SHA} */tmp/resty_cli.tgz" | sha256sum -c - \
|
||||||
&& tar -C /tmp -xzf /tmp/resty_cli.tgz \
|
&& tar -C /tmp -xzf /tmp/resty_cli.tgz \
|
||||||
|
@ -68,10 +80,7 @@ RUN wget -O /tmp/resty_cli.tgz \
|
||||||
&& resty -V \
|
&& resty -V \
|
||||||
&& rm -rf /tmp/*
|
&& rm -rf /tmp/*
|
||||||
|
|
||||||
ARG LUAROCKS_VERSION
|
RUN wget -qO /tmp/luarocks.tgz \
|
||||||
ARG LUAROCKS_SHA
|
|
||||||
|
|
||||||
RUN wget -O /tmp/luarocks.tgz \
|
|
||||||
https://github.com/luarocks/luarocks/archive/v${LUAROCKS_VERSION}.tar.gz \
|
https://github.com/luarocks/luarocks/archive/v${LUAROCKS_VERSION}.tar.gz \
|
||||||
&& echo "${LUAROCKS_SHA} */tmp/luarocks.tgz" | sha256sum -c - \
|
&& echo "${LUAROCKS_SHA} */tmp/luarocks.tgz" | sha256sum -c - \
|
||||||
&& tar -C /tmp -xzf /tmp/luarocks.tgz \
|
&& tar -C /tmp -xzf /tmp/luarocks.tgz \
|
||||||
|
@ -82,48 +91,39 @@ RUN wget -O /tmp/luarocks.tgz \
|
||||||
RUN luarocks install busted \
|
RUN luarocks install busted \
|
||||||
&& luarocks install luacheck
|
&& luarocks install luacheck
|
||||||
|
|
||||||
ARG TARGETARCH
|
RUN wget -qO /usr/local/bin/kubectl \
|
||||||
|
|
||||||
ARG K8S_RELEASE
|
|
||||||
|
|
||||||
RUN wget -O /usr/local/bin/kubectl \
|
|
||||||
https://storage.googleapis.com/kubernetes-release/release/${K8S_RELEASE}/bin/linux/${TARGETARCH}/kubectl \
|
https://storage.googleapis.com/kubernetes-release/release/${K8S_RELEASE}/bin/linux/${TARGETARCH}/kubectl \
|
||||||
&& chmod +x /usr/local/bin/kubectl
|
&& chmod +x /usr/local/bin/kubectl
|
||||||
|
|
||||||
RUN wget -O /usr/local/bin/kube-apiserver \
|
RUN wget -qO /usr/local/bin/kube-apiserver \
|
||||||
https://storage.googleapis.com/kubernetes-release/release/${K8S_RELEASE}/bin/linux/${TARGETARCH}/kube-apiserver \
|
https://storage.googleapis.com/kubernetes-release/release/${K8S_RELEASE}/bin/linux/${TARGETARCH}/kube-apiserver \
|
||||||
&& chmod +x /usr/local/bin/kube-apiserver
|
&& chmod +x /usr/local/bin/kube-apiserver
|
||||||
|
|
||||||
ARG CHART_TESTING_VERSION
|
RUN wget -qO /tmp/ct-${CHART_TESTING_VERSION}-linux-${TARGETARCH}.tar.gz \
|
||||||
|
https://github.com/helm/chart-testing/releases/download/v${CHART_TESTING_VERSION}/chart-testing_${CHART_TESTING_VERSION}_linux_${TARGETARCH}.tar.gz \
|
||||||
RUN wget -O /tmp/ct-${CHART_TESTING_VERSION}-linux-amd64.tar.gz \
|
|
||||||
https://github.com/helm/chart-testing/releases/download/v${CHART_TESTING_VERSION}/chart-testing_${CHART_TESTING_VERSION}_linux_amd64.tar.gz \
|
|
||||||
&& mkdir -p /tmp/ct-download \
|
&& mkdir -p /tmp/ct-download \
|
||||||
&& tar xzvf /tmp/ct-${CHART_TESTING_VERSION}-linux-amd64.tar.gz -C /tmp/ct-download \
|
&& tar xzvf /tmp/ct-${CHART_TESTING_VERSION}-linux-${TARGETARCH}.tar.gz -C /tmp/ct-download \
|
||||||
&& rm /tmp/ct-${CHART_TESTING_VERSION}-linux-amd64.tar.gz \
|
&& rm /tmp/ct-${CHART_TESTING_VERSION}-linux-${TARGETARCH}.tar.gz \
|
||||||
&& cp /tmp/ct-download/ct /usr/local/bin \
|
&& cp /tmp/ct-download/ct /usr/local/bin \
|
||||||
&& mkdir -p /etc/ct \
|
&& mkdir -p /etc/ct \
|
||||||
&& cp -R /tmp/ct-download/etc/* /etc/ct \
|
&& cp -R /tmp/ct-download/etc/* /etc/ct \
|
||||||
&& rm -rf /tmp/*
|
&& rm -rf /tmp/*
|
||||||
|
|
||||||
RUN wget -O /usr/local/bin/lj-releng \
|
RUN wget -qO /usr/local/bin/lj-releng \
|
||||||
https://raw.githubusercontent.com/openresty/openresty-devel-utils/master/lj-releng \
|
https://raw.githubusercontent.com/openresty/openresty-devel-utils/master/lj-releng \
|
||||||
&& chmod +x /usr/local/bin/lj-releng
|
&& chmod +x /usr/local/bin/lj-releng
|
||||||
|
|
||||||
ARG HELM_VERSION
|
|
||||||
|
|
||||||
RUN wget -O /tmp/helm.tgz \
|
RUN wget -qO /tmp/helm.tgz \
|
||||||
https://get.helm.sh/helm-${HELM_VERSION}-linux-${TARGETARCH}.tar.gz \
|
https://get.helm.sh/helm-v${HELM_VERSION}-linux-${TARGETARCH}.tar.gz \
|
||||||
&& tar -C /tmp -xzf /tmp/helm.tgz \
|
&& tar -C /tmp -xzf /tmp/helm.tgz \
|
||||||
&& cp /tmp/linux*/helm /usr/local/bin \
|
&& cp /tmp/linux*/helm /usr/local/bin \
|
||||||
&& rm -rf /tmp/*
|
&& rm -rf /tmp/*
|
||||||
|
|
||||||
# Install a YAML Linter
|
# Install a YAML Linter
|
||||||
ARG YAML_LINT_VERSION
|
|
||||||
RUN pip install "yamllint==$YAML_LINT_VERSION"
|
RUN pip install "yamllint==$YAML_LINT_VERSION"
|
||||||
|
|
||||||
# Install Yamale YAML schema validator
|
# Install Yamale YAML schema validator
|
||||||
ARG YAMALE_VERSION
|
|
||||||
RUN pip install "yamale==$YAMALE_VERSION"
|
RUN pip install "yamale==$YAMALE_VERSION"
|
||||||
|
|
||||||
WORKDIR $GOPATH
|
WORKDIR $GOPATH
|
||||||
|
|
|
@ -3,7 +3,8 @@ FROM ${E2E_BASE_IMAGE} AS BASE
|
||||||
|
|
||||||
FROM alpine:3.17.2
|
FROM alpine:3.17.2
|
||||||
|
|
||||||
RUN apk add -U --no-cache \
|
RUN apk update \
|
||||||
|
&& apk upgrade && apk add -U --no-cache \
|
||||||
ca-certificates \
|
ca-certificates \
|
||||||
bash \
|
bash \
|
||||||
curl \
|
curl \
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
|
|
||||||
DIR:=$(shell dirname $(realpath $(firstword $(MAKEFILE_LIST))))
|
DIR:=$(shell dirname $(realpath $(firstword $(MAKEFILE_LIST))))
|
||||||
E2E_BASE_IMAGE="registry.k8s.io/ingress-nginx/e2e-test-runner:v20230314-helm-chart-4.5.2-32-g520384b11@sha256:754c62f9a5efd1ee515ee908ecc16c0c4d1dda96a8cc8019667182a55f3a9035"
|
E2E_BASE_IMAGE ?= "registry.k8s.io/ingress-nginx/e2e-test-runner:v20230314-helm-chart-4.5.2-32-g520384b11@sha256:754c62f9a5efd1ee515ee908ecc16c0c4d1dda96a8cc8019667182a55f3a9035"
|
||||||
|
|
||||||
image:
|
image:
|
||||||
echo "..entered Makefile in /test/e2e-image"
|
echo "..entered Makefile in /test/e2e-image"
|
||||||
|
|
Loading…
Reference in a new issue