Merge pull request #80 from privilegedescalation/ci/e2e-default-namespace
ci: rework E2E infrastructure to use default namespace
This commit was merged in pull request #80.
This commit is contained in:
@@ -11,7 +11,7 @@ permissions:
|
|||||||
contents: read
|
contents: read
|
||||||
|
|
||||||
env:
|
env:
|
||||||
E2E_NAMESPACE: headlamp-e2e
|
E2E_NAMESPACE: default
|
||||||
E2E_RELEASE: headlamp-e2e
|
E2E_RELEASE: headlamp-e2e
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
|
|||||||
@@ -2,20 +2,19 @@
|
|||||||
# RBAC for the GitHub Actions CI runner to manage the E2E Headlamp instance.
|
# RBAC for the GitHub Actions CI runner to manage the E2E Headlamp instance.
|
||||||
# CI-only test fixture — NOT for production use.
|
# CI-only test fixture — NOT for production use.
|
||||||
#
|
#
|
||||||
# Grants the ARC runner service account permissions in the headlamp-e2e
|
# Grants the ARC runner service account permissions in the default namespace
|
||||||
# namespace to deploy and tear down a dedicated Headlamp instance via Helm.
|
# to deploy and tear down a dedicated Headlamp instance via Helm.
|
||||||
|
# E2E resources run in `default` — nothing persists beyond a test run.
|
||||||
#
|
#
|
||||||
# No kube-system access needed — E2E tests use a separate namespace.
|
|
||||||
# Plugin is loaded via ConfigMap volume mount — no custom Docker images.
|
# Plugin is loaded via ConfigMap volume mount — no custom Docker images.
|
||||||
#
|
#
|
||||||
# Prerequisites:
|
# Prerequisites:
|
||||||
# kubectl create namespace headlamp-e2e
|
|
||||||
# kubectl apply -f deployment/e2e-ci-runner-rbac.yaml
|
# kubectl apply -f deployment/e2e-ci-runner-rbac.yaml
|
||||||
apiVersion: rbac.authorization.k8s.io/v1
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
kind: Role
|
kind: Role
|
||||||
metadata:
|
metadata:
|
||||||
name: e2e-ci-runner
|
name: e2e-ci-runner
|
||||||
namespace: headlamp-e2e
|
namespace: default
|
||||||
rules:
|
rules:
|
||||||
# Helm needs to manage these resources for the Headlamp chart
|
# Helm needs to manage these resources for the Headlamp chart
|
||||||
- apiGroups: ["apps"]
|
- apiGroups: ["apps"]
|
||||||
@@ -36,7 +35,7 @@ apiVersion: rbac.authorization.k8s.io/v1
|
|||||||
kind: RoleBinding
|
kind: RoleBinding
|
||||||
metadata:
|
metadata:
|
||||||
name: e2e-ci-runner-binding
|
name: e2e-ci-runner-binding
|
||||||
namespace: headlamp-e2e
|
namespace: default
|
||||||
subjects:
|
subjects:
|
||||||
- kind: ServiceAccount
|
- kind: ServiceAccount
|
||||||
name: runners-privilegedescalation-gha-rs-no-permission
|
name: runners-privilegedescalation-gha-rs-no-permission
|
||||||
@@ -45,29 +44,3 @@ roleRef:
|
|||||||
kind: Role
|
kind: Role
|
||||||
name: e2e-ci-runner
|
name: e2e-ci-runner
|
||||||
apiGroup: rbac.authorization.k8s.io
|
apiGroup: rbac.authorization.k8s.io
|
||||||
---
|
|
||||||
# ClusterRole to allow the runner SA to verify the headlamp-e2e namespace
|
|
||||||
# exists before attempting namespaced operations. kubectl get namespace is a
|
|
||||||
# cluster-scoped operation not coverable by a namespaced Role.
|
|
||||||
apiVersion: rbac.authorization.k8s.io/v1
|
|
||||||
kind: ClusterRole
|
|
||||||
metadata:
|
|
||||||
name: e2e-ci-namespace-reader
|
|
||||||
rules:
|
|
||||||
- apiGroups: [""]
|
|
||||||
resources: ["namespaces"]
|
|
||||||
verbs: ["get"]
|
|
||||||
resourceNames: ["headlamp-e2e"]
|
|
||||||
---
|
|
||||||
apiVersion: rbac.authorization.k8s.io/v1
|
|
||||||
kind: ClusterRoleBinding
|
|
||||||
metadata:
|
|
||||||
name: e2e-ci-namespace-reader-binding
|
|
||||||
subjects:
|
|
||||||
- kind: ServiceAccount
|
|
||||||
name: runners-privilegedescalation-gha-rs-no-permission
|
|
||||||
namespace: arc-runners
|
|
||||||
roleRef:
|
|
||||||
kind: ClusterRole
|
|
||||||
name: e2e-ci-namespace-reader
|
|
||||||
apiGroup: rbac.authorization.k8s.io
|
|
||||||
|
|||||||
@@ -7,7 +7,7 @@
|
|||||||
#
|
#
|
||||||
# Usage:
|
# Usage:
|
||||||
# helm install headlamp-e2e headlamp/headlamp \
|
# helm install headlamp-e2e headlamp/headlamp \
|
||||||
# -n headlamp-e2e --create-namespace \
|
# -n default \
|
||||||
# -f deployment/headlamp-e2e-values.yaml \
|
# -f deployment/headlamp-e2e-values.yaml \
|
||||||
# --set image.registry=ghcr.io \
|
# --set image.registry=ghcr.io \
|
||||||
# --set image.repository=headlamp-k8s/headlamp \
|
# --set image.repository=headlamp-k8s/headlamp \
|
||||||
|
|||||||
@@ -275,7 +275,6 @@ No custom Docker images, no PVCs, no kubectl exec/cp, no patching of existing de
|
|||||||
One-time setup by a cluster admin:
|
One-time setup by a cluster admin:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
kubectl create namespace headlamp-e2e
|
|
||||||
kubectl apply -f deployment/e2e-ci-runner-rbac.yaml
|
kubectl apply -f deployment/e2e-ci-runner-rbac.yaml
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|||||||
@@ -5,14 +5,17 @@
|
|||||||
# a ConfigMap volume mount. No custom Docker images — the plugin is built
|
# a ConfigMap volume mount. No custom Docker images — the plugin is built
|
||||||
# in CI and injected as a ConfigMap.
|
# in CI and injected as a ConfigMap.
|
||||||
#
|
#
|
||||||
|
# E2E resources are deployed to the `default` namespace. Nothing persists
|
||||||
|
# beyond the test run — teardown cleans up all created resources.
|
||||||
|
#
|
||||||
# Prerequisites:
|
# Prerequisites:
|
||||||
# - Plugin built (dist/ exists with plugin-main.js + package.json)
|
# - Plugin built (dist/ exists with plugin-main.js + package.json)
|
||||||
# - kubectl configured with cluster access
|
# - kubectl configured with cluster access
|
||||||
# - Helm 3 installed
|
# - Helm 3 installed
|
||||||
# - E2E namespace pre-created by cluster admin (see deployment/e2e-ci-runner-rbac.yaml)
|
# - RBAC applied: kubectl apply -f deployment/e2e-ci-runner-rbac.yaml
|
||||||
#
|
#
|
||||||
# Environment:
|
# Environment:
|
||||||
# E2E_NAMESPACE — namespace for E2E Headlamp (default: headlamp-e2e)
|
# E2E_NAMESPACE — namespace for E2E Headlamp (default: default)
|
||||||
# E2E_RELEASE — Helm release name (default: headlamp-e2e)
|
# E2E_RELEASE — Helm release name (default: headlamp-e2e)
|
||||||
# HEADLAMP_VERSION — Headlamp image tag (default: latest)
|
# HEADLAMP_VERSION — Headlamp image tag (default: latest)
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
@@ -20,7 +23,7 @@ set -euo pipefail
|
|||||||
REPO_ROOT="$(cd "$(dirname "$0")/.." && pwd)"
|
REPO_ROOT="$(cd "$(dirname "$0")/.." && pwd)"
|
||||||
DIST_DIR="$REPO_ROOT/dist"
|
DIST_DIR="$REPO_ROOT/dist"
|
||||||
|
|
||||||
E2E_NAMESPACE="${E2E_NAMESPACE:-headlamp-e2e}"
|
E2E_NAMESPACE="${E2E_NAMESPACE:-default}"
|
||||||
E2E_RELEASE="${E2E_RELEASE:-headlamp-e2e}"
|
E2E_RELEASE="${E2E_RELEASE:-headlamp-e2e}"
|
||||||
HEADLAMP_VERSION="${HEADLAMP_VERSION:-latest}"
|
HEADLAMP_VERSION="${HEADLAMP_VERSION:-latest}"
|
||||||
|
|
||||||
@@ -29,21 +32,19 @@ if [ ! -d "$DIST_DIR" ]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# --- Preflight: verify RBAC before touching the cluster ---
|
||||||
|
echo "Checking RBAC permissions in namespace '${E2E_NAMESPACE}'..."
|
||||||
|
if ! kubectl auth can-i delete configmaps -n "$E2E_NAMESPACE" --quiet 2>/dev/null; then
|
||||||
|
echo "ERROR: Missing RBAC — cannot delete configmaps in namespace '${E2E_NAMESPACE}'." >&2
|
||||||
|
echo " Apply RBAC first: kubectl apply -f deployment/e2e-ci-runner-rbac.yaml" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
echo "=== E2E Headlamp Deployment ==="
|
echo "=== E2E Headlamp Deployment ==="
|
||||||
echo " Image: ghcr.io/headlamp-k8s/headlamp:${HEADLAMP_VERSION}"
|
echo " Image: ghcr.io/headlamp-k8s/headlamp:${HEADLAMP_VERSION}"
|
||||||
echo " Namespace: $E2E_NAMESPACE"
|
echo " Namespace: $E2E_NAMESPACE"
|
||||||
echo " Release: $E2E_RELEASE"
|
echo " Release: $E2E_RELEASE"
|
||||||
|
|
||||||
# --- Verify namespace exists (must be pre-created by cluster admin) ---
|
|
||||||
echo ""
|
|
||||||
echo "Verifying namespace ${E2E_NAMESPACE} exists..."
|
|
||||||
if ! kubectl get namespace "$E2E_NAMESPACE" >/dev/null 2>&1; then
|
|
||||||
echo "ERROR: Namespace ${E2E_NAMESPACE} does not exist." >&2
|
|
||||||
echo "A cluster admin must create it first: kubectl create namespace ${E2E_NAMESPACE}" >&2
|
|
||||||
echo "Then apply RBAC: kubectl apply -f deployment/e2e-ci-runner-rbac.yaml" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# --- Create ConfigMap from built plugin ---
|
# --- Create ConfigMap from built plugin ---
|
||||||
echo ""
|
echo ""
|
||||||
echo "Creating ConfigMap with plugin files..."
|
echo "Creating ConfigMap with plugin files..."
|
||||||
|
|||||||
@@ -4,21 +4,15 @@
|
|||||||
# Tears down the dedicated E2E Headlamp instance deployed by deploy-e2e-headlamp.sh.
|
# Tears down the dedicated E2E Headlamp instance deployed by deploy-e2e-headlamp.sh.
|
||||||
#
|
#
|
||||||
# Environment:
|
# Environment:
|
||||||
# E2E_NAMESPACE — namespace to clean up (default: headlamp-e2e)
|
# E2E_NAMESPACE — namespace to clean up (default: default)
|
||||||
# E2E_RELEASE — Helm release to uninstall (default: headlamp-e2e)
|
# E2E_RELEASE — Helm release to uninstall (default: headlamp-e2e)
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
REPO_ROOT="$(cd "$(dirname "$0")/.." && pwd)"
|
REPO_ROOT="$(cd "$(dirname "$0")/.." && pwd)"
|
||||||
|
|
||||||
E2E_NAMESPACE="${E2E_NAMESPACE:-headlamp-e2e}"
|
E2E_NAMESPACE="${E2E_NAMESPACE:-default}"
|
||||||
E2E_RELEASE="${E2E_RELEASE:-headlamp-e2e}"
|
E2E_RELEASE="${E2E_RELEASE:-headlamp-e2e}"
|
||||||
|
|
||||||
# Exit early if the namespace does not exist — nothing to tear down.
|
|
||||||
if ! kubectl get namespace "$E2E_NAMESPACE" >/dev/null 2>&1; then
|
|
||||||
echo "Namespace $E2E_NAMESPACE does not exist, nothing to tear down."
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "=== E2E Headlamp Teardown ==="
|
echo "=== E2E Headlamp Teardown ==="
|
||||||
echo " Namespace: $E2E_NAMESPACE"
|
echo " Namespace: $E2E_NAMESPACE"
|
||||||
echo " Release: $E2E_RELEASE"
|
echo " Release: $E2E_RELEASE"
|
||||||
@@ -32,9 +26,6 @@ kubectl delete configmap headlamp-polaris-plugin -n "$E2E_NAMESPACE" --ignore-no
|
|||||||
echo "Cleaning up service account..."
|
echo "Cleaning up service account..."
|
||||||
kubectl delete serviceaccount headlamp-e2e-test -n "$E2E_NAMESPACE" --ignore-not-found
|
kubectl delete serviceaccount headlamp-e2e-test -n "$E2E_NAMESPACE" --ignore-not-found
|
||||||
|
|
||||||
# Note: namespace is NOT deleted — it is managed by a cluster admin.
|
|
||||||
# The runner SA only has namespace-scoped permissions (see deployment/e2e-ci-runner-rbac.yaml).
|
|
||||||
|
|
||||||
# Clean up local env file
|
# Clean up local env file
|
||||||
rm -f "$REPO_ROOT/.env.e2e"
|
rm -f "$REPO_ROOT/.env.e2e"
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user