Compare commits

..

8 Commits

Author SHA1 Message Date
148bc87b9a runners: bake step-ca root CA into image (v20260525-stepca) (#27) 2026-05-26 01:04:14 +00:00
Andrew Stoltz
2a1e842100 runners: bake step-ca root CA into image (v20260525-stepca)
Without the IAmWorkin step-ca root CA in the runner image's system
trust store, .NET HttpClient calls from CI tests against
`*.iamworkin.lan` (e.g. `https://selenium.iamworkin.lan/session`) fail
with `The remote certificate is invalid because of errors in the
certificate chain: PartialChain`. FlowerCore.Print.Web's
`WebScreenshotService` unit tests hit this on every build.

Drop the step-ca root PEM into `/usr/local/share/ca-certificates/`,
run `update-ca-certificates` once during apt install, and let OpenSSL +
.NET-on-Linux read the regenerated `/etc/ssl/certs/ca-certificates.crt`
automatically — no `SSL_CERT_FILE` env var, no per-Deployment volume
mount.

Image rebuilt + saved + imported on all 3 schedulable RKE2 nodes
(rke2-server, rke2-agent1, rke2-agent2) before this PR — verified with
`ctr images list -q | grep stepca` on each node.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-25 19:55:38 -05:00
bc28430d24 selenium: allow github-runner namespace ingress on 4444 (#26) 2026-05-26 00:44:23 +00:00
Andrew Stoltz
cc92272217 selenium: allow github-runner namespace ingress on 4444
Unblocks CI jobs running in github-runner pods (e.g. FlowerCore.Print.Web
`help-screenshots`) from reaching selenium-hub. Previously the session
POST was DNAT'd to the hub pod IP then dropped at the Calico ingress
hook, surfacing as a 60s timeout against
http://selenium-hub.selenium.svc.cluster.local:4444 while the Selenium
UI showed 0/4 sessions.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-25 19:43:12 -05:00
d6f4468a9c selenium: migrate hub + 3 nodes into ArgoCD-managed manifests (#25) 2026-05-26 00:09:35 +00:00
Andrew Stoltz
2f796a2ebd selenium: migrate hub + 3 nodes + service + ingressroute into ArgoCD
Previously orphan kubectl-applied since the Selenium Grid was first set
up. The `infra-selenium` ArgoCD app existed but only managed
`network-policy.yaml` — the deployments themselves drifted whenever
anyone `kubectl set env`'d or `kubectl scale`'d.

This commit captures the live state (with the 2026-05-25 maxSessions
bump for chrome already baked in) as canonical git source. ArgoCD's
ServerSideApply syncPolicy + selfHeal will now keep the grid in lock
step with this file.

Resources captured:
  - Service selenium-hub (ClusterIP, internal traffic on 4444)
  - Service selenium-hub-external (LoadBalancer, MetalLB 10.0.56.208)
  - Deployment selenium-hub
  - Deployment selenium-node-chrome (replicas=1, SE_NODE_MAX_SESSIONS=2)
  - Deployment selenium-node-firefox (replicas=1, maxSessions=1)
  - Deployment selenium-node-edge (replicas=1, maxSessions=1)
  - IngressRoute selenium-hub (Traefik, selenium.iamworkin.lan)

No live behavior change — server-side dry-run confirms unchanged for
hub/firefox/ingressroute, "configured" for hub-external + 3 deploys
(default-field reordering only; SSA + field managers handle the diff).

Refs: Sprint 33 morning-routine 2026-05-25 follow-up Q-MR.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-25 19:08:55 -05:00
1f1f6823db runners: right-size replica counts per 14d CI activity (#24) 2026-05-26 00:01:47 +00:00
Andrew Stoltz
b92f74b63a runners: right-size replica counts per 14d CI activity data
Drop 2 → 1 for 10 deploys based on trailing-14d run counts:
  - LlmBridge, Media, Knowledge, Intranet.Web, DNS  (0 runs each)
  - Presentations (6), Redis (3), Provisioning (3),
    MessageBoard (3), MenuBoard (3)

Bump 2 → 3 for Print.Web: 12 runs in trailing 5d, and the
help-screenshots AAT job holds a runner 30+ min, creating
head-of-line blocking for parallel PRs.

Net change: -9 replicas (≈ -9 GiB committed memory).
Aligns with Sprint 33 morning-routine capacity audit.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-25 18:55:47 -05:00
6 changed files with 553 additions and 78 deletions

View File

@@ -12,6 +12,15 @@ ENV PATH="/home/runner/_tool/Ruby/${RUBY_MINOR}/x64/bin:/opt/runner-toolcache/Ru
USER root USER root
# Bake the IAmWorkin step-ca root CA into the system trust store. Without
# this, .NET HttpClient calls from CI tests against *.iamworkin.lan
# (e.g. https://selenium.iamworkin.lan/session) fail with `PartialChain`
# because the runner image's default Ubuntu trust bundle doesn't include
# our internal Root CA. update-ca-certificates regenerates
# /etc/ssl/certs/ca-certificates.crt, which OpenSSL + .NET on Linux read
# automatically — no SSL_CERT_FILE env var needed.
COPY step-ca-root.crt /usr/local/share/ca-certificates/iamworkin-step-ca-root.crt
RUN apt-get update \ RUN apt-get update \
&& DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends \ && DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends \
autoconf \ autoconf \
@@ -31,6 +40,7 @@ RUN apt-get update \
pkg-config \ pkg-config \
uuid-dev \ uuid-dev \
zlib1g-dev \ zlib1g-dev \
&& update-ca-certificates \
&& curl -fsSL "https://github.com/rbenv/ruby-build/archive/refs/tags/${RUBY_BUILD_VERSION}.tar.gz" -o /tmp/ruby-build.tar.gz \ && curl -fsSL "https://github.com/rbenv/ruby-build/archive/refs/tags/${RUBY_BUILD_VERSION}.tar.gz" -o /tmp/ruby-build.tar.gz \
&& mkdir -p /tmp/ruby-build \ && mkdir -p /tmp/ruby-build \
&& tar -xzf /tmp/ruby-build.tar.gz --strip-components=1 -C /tmp/ruby-build \ && tar -xzf /tmp/ruby-build.tar.gz --strip-components=1 -C /tmp/ruby-build \

View File

@@ -7,7 +7,7 @@ Deployments with `kubectl`; update this manifest and let ArgoCD reconcile.
All repo-scoped Linux runners use: All repo-scoped Linux runners use:
- `localhost/fc-github-runner:v20260520-ruby3.3.11`, derived from - `localhost/fc-github-runner:v20260525-ruby3.3.11-stepca`, derived from
`myoung34/github-runner:latest` `myoung34/github-runner:latest`
- `ACCESS_TOKEN` from the `github-runner-token` Secret - `ACCESS_TOKEN` from the `github-runner-token` Secret
- `RUN_AS_ROOT=false` - `RUN_AS_ROOT=false`
@@ -40,14 +40,26 @@ still mounts an `emptyDir` over `/home/runner`, so the `setup-runner-home` init
container copies the baked toolcache from `/opt/runner-toolcache/Ruby` into container copies the baked toolcache from `/opt/runner-toolcache/Ruby` into
`/home/runner/_tool/Ruby` before the runner container starts. `/home/runner/_tool/Ruby` before the runner container starts.
The IAmWorkin step-ca root CA is also baked into the system trust store
(`/usr/local/share/ca-certificates/iamworkin-step-ca-root.crt`, registered by
`update-ca-certificates`). Without it, .NET HttpClient calls from CI tests
against `*.iamworkin.lan` (e.g. `https://selenium.iamworkin.lan/session`)
fail with `PartialChain`. To refresh the bundled cert when the root rotates,
re-extract from the cluster and overwrite `step-ca-root.crt`:
```bash
kubectl get secret -n cert-manager step-ca-root \
-o jsonpath='{.data.ca\.crt}' | base64 -d > step-ca-root.crt
```
```bash ```bash
cd apps/github-runner cd apps/github-runner
podman build -t localhost/fc-github-runner:v20260520-ruby3.3.11 . podman build -t localhost/fc-github-runner:v20260525-ruby3.3.11-stepca .
podman run --rm localhost/fc-github-runner:v20260520-ruby3.3.11 ruby -v podman run --rm localhost/fc-github-runner:v20260525-ruby3.3.11-stepca ruby -v
podman run --rm localhost/fc-github-runner:v20260520-ruby3.3.11 \ podman run --rm localhost/fc-github-runner:v20260525-ruby3.3.11-stepca \
test -f /opt/runner-toolcache/Ruby/3.3/x64.complete test -f /opt/runner-toolcache/Ruby/3.3/x64.complete
podman save localhost/fc-github-runner:v20260520-ruby3.3.11 \ podman save localhost/fc-github-runner:v20260525-ruby3.3.11-stepca \
-o fc-github-runner-v20260520-ruby3.3.11.tar -o fc-github-runner-v20260525-ruby3.3.11-stepca.tar
``` ```
Import the saved image on every schedulable RKE2 node before ArgoCD rolls the Import the saved image on every schedulable RKE2 node before ArgoCD rolls the
@@ -55,9 +67,9 @@ Deployments:
```bash ```bash
for node in rke2-server rke2-agent1 rke2-agent2; do for node in rke2-server rke2-agent1 rke2-agent2; do
scp fc-github-runner-v20260520-ruby3.3.11.tar "$node:/tmp/" scp fc-github-runner-v20260525-ruby3.3.11-stepca.tar "$node:/tmp/"
ssh "$node" 'sudo ctr -a /run/k3s/containerd/containerd.sock -n k8s.io images rm localhost/fc-github-runner:v20260520-ruby3.3.11 || true' ssh "$node" 'sudo ctr -a /run/k3s/containerd/containerd.sock -n k8s.io images rm localhost/fc-github-runner:v20260525-ruby3.3.11-stepca || true'
ssh "$node" 'sudo ctr -a /run/k3s/containerd/containerd.sock -n k8s.io images import /tmp/fc-github-runner-v20260520-ruby3.3.11.tar' ssh "$node" 'sudo ctr -a /run/k3s/containerd/containerd.sock -n k8s.io images import /tmp/fc-github-runner-v20260525-ruby3.3.11-stepca.tar'
done done
``` ```

View File

@@ -22,7 +22,7 @@
# NUGET_PACKAGES, XDG_CACHE_HOME, and RUNNER_TOOL_CACHE are all pointed at # NUGET_PACKAGES, XDG_CACHE_HOME, and RUNNER_TOOL_CACHE are all pointed at
# writable mounted paths under /home/runner so actions/setup-dotnet does not # writable mounted paths under /home/runner so actions/setup-dotnet does not
# attempt to install into /usr/share/dotnet. # attempt to install into /usr/share/dotnet.
# Ruby 3.3.11 is baked into localhost/fc-github-runner:v20260520-ruby3.3.11 # Ruby 3.3.11 is baked into localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
# under /opt/runner-toolcache; setup-runner-home copies it into # under /opt/runner-toolcache; setup-runner-home copies it into
# /home/runner/_tool because the runner-home emptyDir masks image content # /home/runner/_tool because the runner-home emptyDir masks image content
# under /home/runner at runtime. # under /home/runner at runtime.
@@ -157,7 +157,7 @@ spec:
# honors the deeper mount. # honors the deeper mount.
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -178,7 +178,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
# GitHub org/repo targeting. # GitHub org/repo targeting.
@@ -334,7 +334,7 @@ spec:
# rather than re-applied per repo as flipped lanes land. # rather than re-applied per repo as flipped lanes land.
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -355,7 +355,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -472,7 +472,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -493,7 +493,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -604,7 +604,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -625,7 +625,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -736,7 +736,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -757,7 +757,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -868,7 +868,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -889,7 +889,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -976,7 +976,10 @@ metadata:
flowercore.io/runner-repo: print-web flowercore.io/runner-repo: print-web
flowercore.io/github-repo: FlowerCore.Print.Web flowercore.io/github-repo: FlowerCore.Print.Web
spec: spec:
replicas: 2 # Sprint 33 morning-routine (2026-05-25): bumped 2 → 3 because help-screenshots
# AAT job holds a runner 30+ min, causing head-of-line blocking on parallel PRs.
# 12 runs in trailing 5d.
replicas: 3
selector: selector:
matchLabels: matchLabels:
app.kubernetes.io/name: github-runner-print-web app.kubernetes.io/name: github-runner-print-web
@@ -1000,7 +1003,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -1021,7 +1024,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -1132,7 +1135,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -1153,7 +1156,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -1264,7 +1267,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -1285,7 +1288,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -1396,7 +1399,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -1417,7 +1420,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -1530,7 +1533,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -1551,7 +1554,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -1664,7 +1667,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -1685,7 +1688,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -1774,7 +1777,8 @@ metadata:
flowercore.io/runner-repo: knowledge flowercore.io/runner-repo: knowledge
flowercore.io/github-repo: FlowerCore.Knowledge flowercore.io/github-repo: FlowerCore.Knowledge
spec: spec:
replicas: 2 # Sprint 33 morning-routine (2026-05-25): dropped 2 → 1 — zero CI runs in trailing 14d.
replicas: 1
selector: selector:
matchLabels: matchLabels:
app.kubernetes.io/name: github-runner-knowledge app.kubernetes.io/name: github-runner-knowledge
@@ -1798,7 +1802,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -1819,7 +1823,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -1907,7 +1911,8 @@ metadata:
flowercore.io/runner-repo: llm-bridge flowercore.io/runner-repo: llm-bridge
flowercore.io/github-repo: FlowerCore.LlmBridge flowercore.io/github-repo: FlowerCore.LlmBridge
spec: spec:
replicas: 2 # Sprint 33 morning-routine (2026-05-25): dropped 2 → 1 — zero CI runs in trailing 14d.
replicas: 1
selector: selector:
matchLabels: matchLabels:
app.kubernetes.io/name: github-runner-llm-bridge app.kubernetes.io/name: github-runner-llm-bridge
@@ -1931,7 +1936,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -1952,7 +1957,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -2040,7 +2045,8 @@ metadata:
flowercore.io/runner-repo: media flowercore.io/runner-repo: media
flowercore.io/github-repo: FlowerCore.Media flowercore.io/github-repo: FlowerCore.Media
spec: spec:
replicas: 2 # Sprint 33 morning-routine (2026-05-25): dropped 2 → 1 — zero CI runs in trailing 14d.
replicas: 1
selector: selector:
matchLabels: matchLabels:
app.kubernetes.io/name: github-runner-media app.kubernetes.io/name: github-runner-media
@@ -2064,7 +2070,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -2085,7 +2091,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -2173,7 +2179,8 @@ metadata:
flowercore.io/runner-repo: presentations flowercore.io/runner-repo: presentations
flowercore.io/github-repo: FlowerCore.Presentations flowercore.io/github-repo: FlowerCore.Presentations
spec: spec:
replicas: 2 # Sprint 33 morning-routine (2026-05-25): dropped 2 → 1 — only 6 CI runs in trailing 14d.
replicas: 1
selector: selector:
matchLabels: matchLabels:
app.kubernetes.io/name: github-runner-presentations app.kubernetes.io/name: github-runner-presentations
@@ -2197,7 +2204,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -2218,7 +2225,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -2330,7 +2337,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -2351,7 +2358,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -2439,7 +2446,8 @@ metadata:
flowercore.io/runner-repo: dns flowercore.io/runner-repo: dns
flowercore.io/github-repo: FlowerCore.DNS flowercore.io/github-repo: FlowerCore.DNS
spec: spec:
replicas: 2 # Sprint 33 morning-routine (2026-05-25): dropped 2 → 1 — zero CI runs in trailing 14d.
replicas: 1
selector: selector:
matchLabels: matchLabels:
app.kubernetes.io/name: github-runner-dns app.kubernetes.io/name: github-runner-dns
@@ -2463,7 +2471,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -2484,7 +2492,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -2596,7 +2604,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -2617,7 +2625,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -2729,7 +2737,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -2750,7 +2758,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -2862,7 +2870,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -2883,7 +2891,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -2995,7 +3003,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -3016,7 +3024,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -3128,7 +3136,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -3149,7 +3157,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -3237,7 +3245,8 @@ metadata:
flowercore.io/runner-repo: intranet-web flowercore.io/runner-repo: intranet-web
flowercore.io/github-repo: FlowerCore.Intranet.Web flowercore.io/github-repo: FlowerCore.Intranet.Web
spec: spec:
replicas: 2 # Sprint 33 morning-routine (2026-05-25): dropped 2 → 1 — zero CI runs in trailing 14d.
replicas: 1
selector: selector:
matchLabels: matchLabels:
app.kubernetes.io/name: github-runner-intranet-web app.kubernetes.io/name: github-runner-intranet-web
@@ -3261,7 +3270,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -3282,7 +3291,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -3370,7 +3379,8 @@ metadata:
flowercore.io/runner-repo: provisioning flowercore.io/runner-repo: provisioning
flowercore.io/github-repo: FlowerCore.Provisioning flowercore.io/github-repo: FlowerCore.Provisioning
spec: spec:
replicas: 2 # Sprint 33 morning-routine (2026-05-25): dropped 2 → 1 — only 3 CI runs in trailing 14d.
replicas: 1
selector: selector:
matchLabels: matchLabels:
app.kubernetes.io/name: github-runner-provisioning app.kubernetes.io/name: github-runner-provisioning
@@ -3394,7 +3404,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -3415,7 +3425,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -3503,7 +3513,8 @@ metadata:
flowercore.io/runner-repo: redis flowercore.io/runner-repo: redis
flowercore.io/github-repo: FlowerCore.Redis flowercore.io/github-repo: FlowerCore.Redis
spec: spec:
replicas: 2 # Sprint 33 morning-routine (2026-05-25): dropped 2 → 1 — only 3 CI runs in trailing 14d.
replicas: 1
selector: selector:
matchLabels: matchLabels:
app.kubernetes.io/name: github-runner-redis app.kubernetes.io/name: github-runner-redis
@@ -3527,7 +3538,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -3548,7 +3559,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -3636,7 +3647,8 @@ metadata:
flowercore.io/runner-repo: message-board flowercore.io/runner-repo: message-board
flowercore.io/github-repo: FlowerCore.MessageBoard flowercore.io/github-repo: FlowerCore.MessageBoard
spec: spec:
replicas: 2 # Sprint 33 morning-routine (2026-05-25): dropped 2 → 1 — only 3 CI runs in trailing 14d.
replicas: 1
selector: selector:
matchLabels: matchLabels:
app.kubernetes.io/name: github-runner-message-board app.kubernetes.io/name: github-runner-message-board
@@ -3660,7 +3672,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -3681,7 +3693,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL
@@ -3769,7 +3781,8 @@ metadata:
flowercore.io/runner-repo: menu-board flowercore.io/runner-repo: menu-board
flowercore.io/github-repo: FlowerCore.MenuBoard flowercore.io/github-repo: FlowerCore.MenuBoard
spec: spec:
replicas: 2 # Sprint 33 morning-routine (2026-05-25): dropped 2 → 1 — only 3 CI runs in trailing 14d.
replicas: 1
selector: selector:
matchLabels: matchLabels:
app.kubernetes.io/name: github-runner-menu-board app.kubernetes.io/name: github-runner-menu-board
@@ -3793,7 +3806,7 @@ spec:
fsGroup: 1001 fsGroup: 1001
initContainers: initContainers:
- name: setup-runner-home - name: setup-runner-home
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
command: command:
- sh - sh
@@ -3814,7 +3827,7 @@ spec:
mountPath: /home/runner mountPath: /home/runner
containers: containers:
- name: runner - name: runner
image: localhost/fc-github-runner:v20260520-ruby3.3.11 image: localhost/fc-github-runner:v20260525-ruby3.3.11-stepca
imagePullPolicy: Never imagePullPolicy: Never
env: env:
- name: REPO_URL - name: REPO_URL

View File

@@ -0,0 +1,12 @@
-----BEGIN CERTIFICATE-----
MIIBxDCCAWqgAwIBAgIRAPY357G6ow6zMAL5+4bS2kkwCgYIKoZIzj0EAwIwQDEa
MBgGA1UEChMRSUFtV29ya2luIEFDTUUgQ0ExIjAgBgNVBAMTGUlBbVdvcmtpbiBB
Q01FIENBIFJvb3QgQ0EwHhcNMjYwMzA4MTgwNzExWhcNMzYwMzA1MTgwNzExWjBA
MRowGAYDVQQKExFJQW1Xb3JraW4gQUNNRSBDQTEiMCAGA1UEAxMZSUFtV29ya2lu
IEFDTUUgQ0EgUm9vdCBDQTBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABJ2n04X1
JZo5Zdq/i1Idv8+fqwZyAzBh7whbqj0SWsJL8UWRabCMqYCs7+dXO0xRSzqkwFDL
x+vooOai8RgRNhajRTBDMA4GA1UdDwEB/wQEAwIBBjASBgNVHRMBAf8ECDAGAQH/
AgEBMB0GA1UdDgQWBBRnuPPQR6iM/H6vOluiU3Sygayz8jAKBggqhkjOPQQDAgNI
ADBFAiEArQK9dYPGmAZsdYnjziuFVVE5NKZUcceYvGfGC+tLXUsCIAudF2zJrCRq
3mK50ZZET/fwTkJwiEF4824mjP8p1CKM
-----END CERTIFICATE-----

View File

@@ -24,7 +24,16 @@
# (10.0.57.16:5200), public internet 80/443 (excluding RFC1918), and # (10.0.57.16:5200), public internet 80/443 (excluding RFC1918), and
# fc-signage:5190 for the signage AAT lane. # fc-signage:5190 for the signage AAT lane.
# - Ingress: Traefik (4444 + 8089 ACME-solver-style), intra-pod, # - Ingress: Traefik (4444 + 8089 ACME-solver-style), intra-pod,
# telephony / gitea / fc-system / fc-signage namespaces on 4444. # telephony / gitea / fc-system / fc-signage / github-runner namespaces
# on 4444.
#
# 2026-05-25: added github-runner ingress on 4444 so CI jobs running in
# self-hosted runner pods (e.g. FlowerCore.Print.Web `help-screenshots`)
# can reach the grid. Without this allow, the session POST to
# `selenium-hub.selenium.svc.cluster.local:4444` was DNAT'd to the hub
# pod IP and then dropped at the Calico ingress hook — Selenium UI showed
# 0/4 sessions while the .NET HTTP client timed out at 60s. Same family
# as `feedback_netpol_dnat_backend_port`, wrong-source-namespace flavor.
apiVersion: networking.k8s.io/v1 apiVersion: networking.k8s.io/v1
kind: NetworkPolicy kind: NetworkPolicy
metadata: metadata:
@@ -203,6 +212,13 @@ spec:
ports: ports:
- port: 4444 - port: 4444
protocol: TCP protocol: TCP
- from:
- namespaceSelector:
matchLabels:
kubernetes.io/metadata.name: github-runner
ports:
- port: 4444
protocol: TCP
podSelector: {} podSelector: {}
policyTypes: policyTypes:
- Ingress - Ingress

View File

@@ -0,0 +1,412 @@
# Selenium Grid 4 — RKE2 deployment
#
# Hub + chrome + firefox + edge browser nodes serving fleet-wide AAT runs from
# the GitHub Actions self-hosted runners. ArgoCD owns this namespace from
# 2026-05-25 (`infra-selenium` Application; previously these resources were
# orphan kubectl-applied since 2026-03-15).
#
# Endpoints:
# - Internal cluster: http://selenium-hub.selenium.svc.cluster.local:4444
# - LAN LoadBalancer (MetalLB): http://10.0.56.208:4444
# - Traefik public: https://selenium.iamworkin.lan
#
# Browser maxSessions:
# - chrome 2 (bumped from 1 on 2026-05-25 morning-routine — AAT-heavy
# Print.Web help-screenshots was the global bottleneck;
# see commit history for ops/runner-replica-rightsize)
# - firefox 1
# - edge 1
#
# Screenshots + video recording write to NFS via the chrome video sidecar.
# See: CLAUDE.md "Selenium Grid & Visual AAT Testing" + bluejay-infra ADR notes.
---
apiVersion: v1
kind: Service
metadata:
labels:
app: selenium-hub
app.kubernetes.io/name: selenium-hub
app.kubernetes.io/part-of: selenium-grid
name: selenium-hub
namespace: selenium
spec:
ports:
- name: web
port: 4444
targetPort: 4444
- name: publish
port: 4442
targetPort: 4442
- name: subscribe
port: 4443
targetPort: 4443
selector:
app: selenium-hub
type: ClusterIP
---
apiVersion: v1
kind: Service
metadata:
annotations:
metallb.io/ip-allocated-from-pool: bluejay-pool
metallb.universe.tf/loadBalancerIPs: 10.0.56.208
labels:
app: selenium-hub
component: external-access
name: selenium-hub-external
namespace: selenium
spec:
clusterIP: 10.43.90.147
clusterIPs:
- 10.43.90.147
externalTrafficPolicy: Local
healthCheckNodePort: 32213
ports:
- name: web
nodePort: 32411
port: 4444
targetPort: 4444
- name: publish
nodePort: 32068
port: 4442
targetPort: 4442
- name: subscribe
nodePort: 31000
port: 4443
targetPort: 4443
selector:
app: selenium-hub
type: LoadBalancer
---
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: selenium-hub
app.kubernetes.io/name: selenium-hub
app.kubernetes.io/part-of: selenium-grid
name: selenium-hub
namespace: selenium
spec:
replicas: 1
selector:
matchLabels:
app: selenium-hub
template:
metadata:
labels:
app: selenium-hub
app.kubernetes.io/name: selenium-hub
app.kubernetes.io/part-of: selenium-grid
spec:
containers:
- env:
- name: SE_NODE_SESSION_TIMEOUT
value: '300'
- name: SE_SESSION_REQUEST_TIMEOUT
value: '300'
- name: SE_SESSION_RETRY_INTERVAL
value: '5'
- name: JAVA_OPTS
value: -Xmx512m
image: selenium/hub:4.27.0
livenessProbe:
httpGet:
path: /wd/hub/status
port: 4444
initialDelaySeconds: 30
periodSeconds: 15
timeoutSeconds: 5
name: selenium-hub
ports:
- containerPort: 4444
name: web
- containerPort: 4442
name: publish
- containerPort: 4443
name: subscribe
readinessProbe:
httpGet:
path: /wd/hub/status
port: 4444
initialDelaySeconds: 10
periodSeconds: 5
timeoutSeconds: 5
resources:
limits:
cpu: 500m
memory: 1Gi
requests:
cpu: 250m
memory: 512Mi
---
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: selenium-node-chrome
app.kubernetes.io/name: selenium-node-chrome
app.kubernetes.io/part-of: selenium-grid
name: selenium-node-chrome
namespace: selenium
spec:
replicas: 1
selector:
matchLabels:
app: selenium-node-chrome
template:
metadata:
labels:
app: selenium-node-chrome
app.kubernetes.io/name: selenium-node-chrome
app.kubernetes.io/part-of: selenium-grid
spec:
containers:
- env:
- name: SE_EVENT_BUS_HOST
value: selenium-hub
- name: SE_EVENT_BUS_PUBLISH_PORT
value: '4442'
- name: SE_EVENT_BUS_SUBSCRIBE_PORT
value: '4443'
- name: SE_NODE_MAX_SESSIONS
value: '2'
- name: SE_NODE_OVERRIDE_MAX_SESSIONS
value: 'false'
- name: SE_VNC_NO_PASSWORD
value: '1'
- name: SE_SCREEN_WIDTH
value: '1920'
- name: SE_SCREEN_HEIGHT
value: '1080'
- name: SE_NODE_SESSION_TIMEOUT
value: '300'
image: selenium/node-chrome:4.27.0
livenessProbe:
httpGet:
path: /status
port: 5555
initialDelaySeconds: 30
periodSeconds: 15
name: selenium-chrome
ports:
- containerPort: 5555
name: node
readinessProbe:
httpGet:
path: /status
port: 5555
initialDelaySeconds: 15
periodSeconds: 5
resources:
limits:
cpu: '1'
memory: 1Gi
requests:
cpu: 500m
memory: 512Mi
volumeMounts:
- mountPath: /dev/shm
name: dshm
- env:
- name: DISPLAY_CONTAINER_NAME
value: localhost
- name: SE_SCREEN_WIDTH
value: '1920'
- name: SE_SCREEN_HEIGHT
value: '1080'
- name: SE_VIDEO_FILE_NAME
value: auto
- name: SE_VIDEO_UPLOAD_ENABLED
value: 'false'
image: selenium/video:ffmpeg-7.1-20250101
name: video
resources:
limits:
cpu: 500m
memory: 768Mi
requests:
cpu: 250m
memory: 384Mi
volumeMounts:
- mountPath: /videos
name: selenium-videos
volumes:
- emptyDir:
medium: Memory
sizeLimit: 2Gi
name: dshm
- emptyDir:
sizeLimit: 5Gi
name: selenium-videos
---
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: selenium-node-firefox
app.kubernetes.io/name: selenium-node-firefox
app.kubernetes.io/part-of: selenium-grid
name: selenium-node-firefox
namespace: selenium
spec:
replicas: 1
selector:
matchLabels:
app: selenium-node-firefox
template:
metadata:
labels:
app: selenium-node-firefox
app.kubernetes.io/name: selenium-node-firefox
app.kubernetes.io/part-of: selenium-grid
spec:
containers:
- env:
- name: SE_EVENT_BUS_HOST
value: selenium-hub
- name: SE_EVENT_BUS_PUBLISH_PORT
value: '4442'
- name: SE_EVENT_BUS_SUBSCRIBE_PORT
value: '4443'
- name: SE_NODE_MAX_SESSIONS
value: '1'
- name: SE_NODE_OVERRIDE_MAX_SESSIONS
value: 'true'
- name: SE_VNC_NO_PASSWORD
value: '1'
- name: SE_START_VNC
value: 'false'
- name: SE_SCREEN_WIDTH
value: '1920'
- name: SE_SCREEN_HEIGHT
value: '1080'
- name: SE_NODE_SESSION_TIMEOUT
value: '300'
image: selenium/node-firefox:4.27.0
livenessProbe:
failureThreshold: 5
httpGet:
path: /status
port: 5555
initialDelaySeconds: 30
periodSeconds: 15
timeoutSeconds: 5
name: selenium-firefox
ports:
- containerPort: 5555
name: node
readinessProbe:
failureThreshold: 5
httpGet:
path: /status
port: 5555
initialDelaySeconds: 15
periodSeconds: 5
timeoutSeconds: 5
resources:
limits:
cpu: '1'
memory: 2Gi
requests:
cpu: 500m
memory: 1Gi
volumeMounts:
- mountPath: /dev/shm
name: dshm
volumes:
- emptyDir:
medium: Memory
sizeLimit: 2Gi
name: dshm
---
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: selenium-node-edge
app.kubernetes.io/name: selenium-node-edge
app.kubernetes.io/part-of: selenium-grid
name: selenium-node-edge
namespace: selenium
spec:
replicas: 1
selector:
matchLabels:
app: selenium-node-edge
template:
metadata:
labels:
app: selenium-node-edge
app.kubernetes.io/name: selenium-node-edge
app.kubernetes.io/part-of: selenium-grid
spec:
containers:
- env:
- name: SE_EVENT_BUS_HOST
value: selenium-hub
- name: SE_EVENT_BUS_PUBLISH_PORT
value: '4442'
- name: SE_EVENT_BUS_SUBSCRIBE_PORT
value: '4443'
- name: SE_NODE_MAX_SESSIONS
value: '1'
- name: SE_NODE_OVERRIDE_MAX_SESSIONS
value: 'true'
- name: SE_VNC_NO_PASSWORD
value: '1'
- name: SE_SCREEN_WIDTH
value: '1920'
- name: SE_SCREEN_HEIGHT
value: '1080'
- name: SE_NODE_SESSION_TIMEOUT
value: '300'
image: selenium/node-edge:4.27.0
livenessProbe:
httpGet:
path: /status
port: 5555
initialDelaySeconds: 30
periodSeconds: 15
name: selenium-edge
ports:
- containerPort: 5555
name: node
readinessProbe:
httpGet:
path: /status
port: 5555
initialDelaySeconds: 15
periodSeconds: 5
resources:
limits:
cpu: '1'
memory: 1Gi
requests:
cpu: 500m
memory: 512Mi
volumeMounts:
- mountPath: /dev/shm
name: dshm
volumes:
- emptyDir:
medium: Memory
sizeLimit: 2Gi
name: dshm
---
apiVersion: traefik.io/v1alpha1
kind: IngressRoute
metadata:
name: selenium-hub
namespace: selenium
spec:
entryPoints:
- websecure
routes:
- kind: Rule
match: Host(`selenium.iamworkin.lan`)
services:
- name: selenium-hub
port: 4444
tls:
secretName: selenium-tls