Skip to content

Commit

Permalink
ci(.github): enable self hosted runners for AMD64 E2E tasks (backport…
Browse files Browse the repository at this point in the history
… of #10945) (#12277)

Automatic cherry-pick of #10945 for branch release-2.8

Generated by
[action](https://github.com/kumahq/kuma/actions/runs/12353055555)

cherry-picked commit 126029d
⚠️ ⚠️ ⚠️ Conflicts happened when cherry-picking!
⚠️ ⚠️ ⚠️
```
On branch release-2.8
Your branch is up to date with 'origin/release-2.8'.

You are currently cherry-picking commit 126029d.
  (fix conflicts and run "git cherry-pick --continue")
  (use "git cherry-pick --skip" to skip this patch)
  (use "git cherry-pick --abort" to cancel the cherry-pick operation)

Changes to be committed:
	modified:   .github/workflows/build-test-distribute.yaml
	modified:   mk/kind.mk
	modified:   test/kind/cluster-ipv6-kuma-1.yaml
	modified:   test/kind/cluster-ipv6-kuma-2.yaml
	modified:   test/kind/cluster-ipv6-kuma.yaml
	modified:   test/kind/cluster-kuma-1.yaml
	modified:   test/kind/cluster-kuma-2.yaml
	modified:   test/kind/cluster-kuma.yaml

Unmerged paths:
  (use "git add <file>..." to mark resolution)
	both modified:   .github/workflows/_e2e.yaml
	both modified:   .github/workflows/_test.yaml
	both modified:   mk/k3d.mk

```

---------

Signed-off-by: Jay Chen <[email protected]>
Signed-off-by: Charly Molter <[email protected]>
Signed-off-by: Lukasz Dziedziak <[email protected]>
Co-authored-by: Jay Jijie Chen <[email protected]>
Co-authored-by: Charly Molter <[email protected]>
Co-authored-by: Lukasz Dziedziak <[email protected]>
  • Loading branch information
4 people authored Dec 16, 2024
1 parent 06a9880 commit 1696ea1
Show file tree
Hide file tree
Showing 9 changed files with 105 additions and 34 deletions.
18 changes: 17 additions & 1 deletion .github/workflows/_e2e.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,6 @@ env:
E2E_PARAM_SIDECAR_CONTAINERS: ${{ fromJSON(inputs.matrix).sidecarContainers }}
E2E_PARAM_TARGET: ${{ fromJSON(inputs.matrix).target }}
E2E_PARAM_PARALLELISM: ${{ fromJSON(inputs.matrix).parallelism }}
E2E_RUN_NAME: ${{ fromJSON(inputs.matrix).target }}_${{ fromJSON(inputs.matrix).k8sVersion }}_${{ fromJSON(inputs.matrix).cniNetworkPlugin }}_${{ fromJSON(inputs.matrix).arch }}_${{ fromJSON(inputs.matrix).parallelism }}
jobs:
e2e:
timeout-minutes: 60
Expand Down Expand Up @@ -78,6 +77,8 @@ jobs:
EOF
sudo service docker restart
- name: "Run E2E tests"
env:
DOCKERHUB_PULL_CREDENTIAL: ${{ secrets.DOCKERHUB_PULL_CREDENTIAL }}
run: |
if [[ "${{ env.E2E_PARAM_K8S_VERSION }}" == "kindIpv6" ]]; then
export IPV6=true
Expand Down Expand Up @@ -106,6 +107,21 @@ jobs:
if [[ "${{ env.E2E_PARAM_TARGET }}" == "multizone" ]]; then
export KUMA_DEFAULT_RETRIES=60
fi
function on_exit()
{
docker logout docker.io
}
# we pull a few images during the E2E run, sometimes we get rate-limited by docker hub
# to prevent this, we support specifying a pull credential here
if [[ "$DOCKERHUB_PULL_CREDENTIAL" != "" ]]; then
DOCKER_USER=$(echo "$DOCKERHUB_PULL_CREDENTIAL" | cut -d ':' -f 1)
DOCKER_PWD=$(echo "$DOCKERHUB_PULL_CREDENTIAL" | cut -d ':' -f 2)
echo -n "$DOCKER_PWD" | docker login -u "$DOCKER_USER" --password-stdin
trap "on_exit" EXIT
fi
if [[ "${{ env.E2E_PARAM_TARGET }}" != "" ]]; then
target="test/e2e-${{ env.E2E_PARAM_TARGET }}"
else
Expand Down
21 changes: 19 additions & 2 deletions mk/k3d.mk
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ KUMA_NAMESPACE ?= kuma-system
PORT_PREFIX := $$(($(patsubst 300-%,300+%-1,$(KIND_CLUSTER_NAME:kuma%=300%))))

K3D_NETWORK_CNI ?= flannel
K3D_REGISTRY_FILE ?=
K3D_CLUSTER_CREATE_OPTS ?= -i rancher/k3s:$(CI_K3S_VERSION) \
--k3s-arg '--disable=traefik@server:0' \
--k3s-arg '--disable=metrics-server@server:0' \
Expand All @@ -49,6 +50,7 @@ K3D_CLUSTER_CREATE_OPTS ?= -i rancher/k3s:$(CI_K3S_VERSION) \
--volume '$(subst @,\@,$(TOP)/$(KUMA_DIR))/test/framework/deployments:/tmp/deployments@server:0' \
--network kind \
--port "$(PORT_PREFIX)80-$(PORT_PREFIX)99:30080-30099@server:0" \
--registry-config "/tmp/.kuma-dev/k3d-registry.yaml" \
--timeout 120s

ifeq ($(K3D_NETWORK_CNI),calico)
Expand Down Expand Up @@ -88,8 +90,23 @@ $(TOP)/$(KUMA_DIR)/test/k3d/calico.$(K3D_VERSION).yaml:
-o $(TOP)/$(KUMA_DIR)/test/k3d/calico.$(K3D_VERSION).yaml \
https://k3d.io/v$(K3D_VERSION)/usage/advanced/calico.yaml

DOCKERHUB_PULL_CREDENTIAL ?=
.PHONY: k3d/setup-docker-credentials
k3d/setup-docker-credentials:
@mkdir -p /tmp/.kuma-dev ; \
echo '{"configs": {}}' > /tmp/.kuma-dev/k3d-registry.yaml ; \
if [[ "$(DOCKERHUB_PULL_CREDENTIAL)" != "" ]]; then \
DOCKER_USER=$$(echo "$(DOCKERHUB_PULL_CREDENTIAL)" | cut -d ':' -f 1); \
DOCKER_PWD=$$(echo "$(DOCKERHUB_PULL_CREDENTIAL)" | cut -d ':' -f 2); \
echo "{\"configs\": {\"registry-1.docker.io\": {\"auth\": {\"username\": \"$${DOCKER_USER}\",\"password\":\"$${DOCKER_PWD}\"}}}}" > /tmp/.kuma-dev/k3d-registry.yaml ; \
fi

.PHONY: k3d/cleanup-docker-credentials
k3d/cleanup-docker-credentials:
@rm -f /tmp/.kuma-dev/k3d-registry.yaml

.PHONY: k3d/start
k3d/start: ${KIND_KUBECONFIG_DIR} k3d/network/create \
k3d/start: ${KIND_KUBECONFIG_DIR} k3d/network/create k3d/setup-docker-credentials
$(if $(findstring calico,$(K3D_NETWORK_CNI)),$(TOP)/$(KUMA_DIR)/test/k3d/calico.$(K3D_VERSION).yaml)
@echo "PORT_PREFIX=$(PORT_PREFIX)"
@KUBECONFIG=$(KIND_KUBECONFIG) \
Expand Down Expand Up @@ -136,7 +153,7 @@ k3d/wait:
done

.PHONY: k3d/stop
k3d/stop:
k3d/stop: k3d/cleanup-docker-credentials
@KUBECONFIG=$(KIND_KUBECONFIG) $(K3D_BIN) cluster delete "$(KIND_CLUSTER_NAME)"

.PHONY: k3d/stop/all
Expand Down
17 changes: 15 additions & 2 deletions mk/kind.mk
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,21 @@ CI_KUBERNETES_VERSION ?= v1.23.17@sha256:59c989ff8a517a93127d4a536e7014d28e235fb
KUMA_MODE ?= zone
KUMA_NAMESPACE ?= kuma-system

DOCKERHUB_PULL_CREDENTIAL ?=
.PHONY: kind/setup-docker-credentials
kind/setup-docker-credentials:
@mkdir -p /tmp/.kuma-dev ; \
echo '{"auths":{}}' > /tmp/.kuma-dev/kind-config.json ; \
if [[ "$(DOCKERHUB_PULL_CREDENTIAL)" != "" ]]; then \
echo "{\"auths\":{\"https://index.docker.io/v1/\":{\"auth\":\"$$(echo -n "$(DOCKERHUB_PULL_CREDENTIAL)" | base64)\"}}}" > /tmp/.kuma-dev/kind-config.json ; \
fi

.PHONY: kind/cleanup-docker-credentials
kind/cleanup-docker-credentials:
@rm -f /tmp/.kuma-dev/kind-config.json

.PHONY: kind/start
kind/start: ${KUBECONFIG_DIR}
kind/start: ${KUBECONFIG_DIR} kind/setup-docker-credentials
$(KIND) get clusters | grep $(KIND_CLUSTER_NAME) >/dev/null 2>&1 && echo "Kind cluster already running." && exit 0 || \
($(KIND) create cluster \
--name "$(KIND_CLUSTER_NAME)" \
Expand Down Expand Up @@ -51,7 +64,7 @@ kind/wait:
done

.PHONY: kind/stop
kind/stop:
kind/stop: kind/cleanup-docker-credentials
@$(KIND) delete cluster --name $(KIND_CLUSTER_NAME)
@rm -f $(KUBECONFIG_DIR)/$(KIND_KUBECONFIG)

Expand Down
31 changes: 17 additions & 14 deletions test/kind/cluster-ipv6-kuma-1.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -5,17 +5,20 @@ networking:
ipFamily: ipv6
apiServerAddress: 127.0.0.1
nodes:
- role: control-plane
kubeadmConfigPatches:
- |
kind: InitConfiguration
nodeRegistration:
kubeletExtraArgs:
node-labels: "ingress-ready=true"
extraPortMappings:
- containerPort: 30080
hostPort: 30080
protocol: TCP
- containerPort: 30443
hostPort: 30443
protocol: TCP
- role: control-plane
kubeadmConfigPatches:
- |
kind: InitConfiguration
nodeRegistration:
kubeletExtraArgs:
node-labels: "ingress-ready=true"
extraPortMappings:
- containerPort: 30080
hostPort: 30080
protocol: TCP
- containerPort: 30443
hostPort: 30443
protocol: TCP
extraMounts:
- containerPath: /var/lib/kubelet/config.json
hostPath: /tmp/.kuma-dev/kind-config.json
5 changes: 5 additions & 0 deletions test/kind/cluster-ipv6-kuma-2.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -4,3 +4,8 @@ apiVersion: kind.x-k8s.io/v1alpha4
networking:
ipFamily: ipv6
apiServerAddress: 127.0.0.1
nodes:
- role: control-plane
extraMounts:
- containerPath: /var/lib/kubelet/config.json
hostPath: /tmp/.kuma-dev/kind-config.json
5 changes: 5 additions & 0 deletions test/kind/cluster-ipv6-kuma.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -4,3 +4,8 @@ apiVersion: kind.x-k8s.io/v1alpha4
networking:
ipFamily: ipv6
apiServerAddress: 127.0.0.1
nodes:
- role: control-plane
extraMounts:
- containerPath: /var/lib/kubelet/config.json
hostPath: /tmp/.kuma-dev/kind-config.json
32 changes: 17 additions & 15 deletions test/kind/cluster-kuma-1.yaml
Original file line number Diff line number Diff line change
@@ -1,18 +1,20 @@
# an ipv6 cluster
kind: Cluster
apiVersion: kind.x-k8s.io/v1alpha4
nodes:
- role: control-plane
kubeadmConfigPatches:
- |
kind: InitConfiguration
nodeRegistration:
kubeletExtraArgs:
node-labels: "ingress-ready=true"
extraPortMappings:
- containerPort: 30080
hostPort: 30080
protocol: TCP
- containerPort: 30443
hostPort: 30443
protocol: TCP
- role: control-plane
kubeadmConfigPatches:
- |
kind: InitConfiguration
nodeRegistration:
kubeletExtraArgs:
node-labels: "ingress-ready=true"
extraPortMappings:
- containerPort: 30080
hostPort: 30080
protocol: TCP
- containerPort: 30443
hostPort: 30443
protocol: TCP
extraMounts:
- containerPath: /var/lib/kubelet/config.json
hostPath: /tmp/.kuma-dev/kind-config.json
5 changes: 5 additions & 0 deletions test/kind/cluster-kuma-2.yaml
Original file line number Diff line number Diff line change
@@ -1,3 +1,8 @@
# an ipv6 cluster
kind: Cluster
apiVersion: kind.x-k8s.io/v1alpha4
nodes:
- role: control-plane
extraMounts:
- containerPath: /var/lib/kubelet/config.json
hostPath: /tmp/.kuma-dev/kind-config.json
5 changes: 5 additions & 0 deletions test/kind/cluster-kuma.yaml
Original file line number Diff line number Diff line change
@@ -1,3 +1,8 @@
# an ipv6 cluster
kind: Cluster
apiVersion: kind.x-k8s.io/v1alpha4
nodes:
- role: control-plane
extraMounts:
- containerPath: /var/lib/kubelet/config.json
hostPath: /tmp/.kuma-dev/kind-config.json

0 comments on commit 1696ea1

Please sign in to comment.