Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
79 commits
Select commit Hold shift + click to select a range
8d470f3
start cypress
davdhacs Nov 12, 2025
9f1727b
testmode no auth
davdhacs Nov 12, 2025
eeb9adc
add cypress to package
davdhacs Nov 12, 2025
a9427bb
add deploy-local.sh
davdhacs Nov 12, 2025
3d11c37
move local deploy into make+helm.sh
davdhacs Nov 12, 2025
d3fda41
add local env as an option
davdhacs Nov 12, 2025
90b73ae
Fix secrets.yaml template syntax and format Cypress README
davdhacs Nov 13, 2025
134edd2
use http for test_mode
davdhacs Nov 14, 2025
7639f75
add to cypress readme
davdhacs Nov 17, 2025
6d47780
make tests work
davdhacs Nov 17, 2025
8dca15e
rename cypress readme
davdhacs Nov 17, 2025
d7dc433
simplify
davdhacs Nov 18, 2025
731fa2a
wrong path
davdhacs Nov 18, 2025
5fbfd3c
finish flavors list check
davdhacs Nov 19, 2025
d9cd117
start with kind
davdhacs Nov 19, 2025
536d149
run on push
davdhacs Nov 19, 2025
1b806e6
version pins
davdhacs Nov 19, 2025
0375c48
remove quotes
davdhacs Nov 20, 2025
e2c8565
without cache
davdhacs Nov 20, 2025
8f20eeb
simpler infra-pr tag
davdhacs Nov 20, 2025
c20ec74
lint
davdhacs Nov 20, 2025
9a4347a
specify registry
davdhacs Nov 20, 2025
e0cebf3
tag
davdhacs Nov 20, 2025
300f96c
specify registry with tag
davdhacs Nov 20, 2025
98c2f61
specify local-reg
davdhacs Nov 20, 2025
c38c346
colon
davdhacs Nov 20, 2025
88259e6
only tag
davdhacs Nov 20, 2025
9d90196
checkout
davdhacs Nov 20, 2025
c41d5a0
depth:0
davdhacs Nov 20, 2025
1267bc9
tag with registry again
davdhacs Nov 20, 2025
77b265d
remove fix
davdhacs Nov 20, 2025
4bfe483
set registry
davdhacs Nov 20, 2025
006aae6
slash
davdhacs Nov 20, 2025
791ec75
use cypress action
davdhacs Nov 20, 2025
38769da
5m timeout
davdhacs Nov 20, 2025
83e327c
lint
davdhacs Nov 20, 2025
bf44ef3
restore master install-crds
davdhacs Nov 20, 2025
cd87ea2
ssl in non-local
davdhacs Nov 20, 2025
7500a65
Merge branch 'rox-29520-start-ui-tests' into rox-29520-ui-test-on-git…
davdhacs Nov 20, 2025
8c9ec4c
try local kind direct with quay tag
davdhacs Nov 20, 2025
7c3afdb
remove build-push-action and use direct build
davdhacs Nov 20, 2025
e574093
lint
davdhacs Nov 20, 2025
11a19f2
name kind cluster
davdhacs Nov 20, 2025
89dd5aa
lint
davdhacs Nov 20, 2025
2e56618
ui working dir
davdhacs Nov 20, 2025
a892e69
set infra api endpoint
davdhacs Nov 20, 2025
0e8e696
lint
davdhacs Nov 20, 2025
d23a305
remove component supportfile
davdhacs Nov 20, 2025
3c6746a
cache docker layers
davdhacs Nov 20, 2025
7788770
docker load
davdhacs Nov 21, 2025
f7fe615
artifacts from cypress
davdhacs Nov 21, 2025
922b1a9
ui/ artifact path
davdhacs Nov 21, 2025
30a4b25
without validate
davdhacs Nov 22, 2025
afa9377
fix image tag syntax
davdhacs Nov 25, 2025
5e842ef
rename testmode joined with localdeploy
davdhacs Nov 25, 2025
ffb47ed
rename test_mode to local_deploy
davdhacs Nov 25, 2025
e03d599
Merge branch 'master' into rox-29520-ui-test-on-githubaction
davdhacs Dec 1, 2025
98291f7
restore test_mode
davdhacs Dec 1, 2025
92b970e
restore test_mode in pr workflow
davdhacs Dec 1, 2025
1f4bcf9
restore test_mode description
davdhacs Dec 1, 2025
1025330
reduce
davdhacs Dec 2, 2025
c6fc739
remove fake secrets
davdhacs Dec 2, 2025
9124fe0
remove local_deploy vs prod check
davdhacs Dec 2, 2025
6b66b18
restore registry name
davdhacs Dec 2, 2025
64d55ff
reuse make target for gha test
davdhacs Dec 2, 2025
aaaf5c2
fixing local deploy
davdhacs Dec 3, 2025
7f45e79
install ui deps
davdhacs Dec 3, 2025
67e14c2
go lint
davdhacs Dec 3, 2025
6065e47
fix intercepter
davdhacs Dec 4, 2025
7db20a4
Merge branch 'master' into rox-29520-ui-test-on-githubaction
davdhacs Dec 4, 2025
68e0b71
use cypress action
davdhacs Dec 4, 2025
1585132
run ui for test
davdhacs Dec 4, 2025
142fa49
set localDeploy only from deploy-local
davdhacs Dec 4, 2025
c3dea6f
copy cleanup from rox
davdhacs Dec 4, 2025
922d579
action lint
davdhacs Dec 5, 2025
d2fba22
remove image build from deploy-local
davdhacs Dec 5, 2025
11ceff9
free 22gb
davdhacs Dec 5, 2025
424836f
fix secret conditional
davdhacs Dec 5, 2025
0038d2b
remove duplicate end
davdhacs Dec 5, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
108 changes: 108 additions & 0 deletions .github/workflows/ui.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,108 @@
name: UI tests

on: [push]

jobs:
create-cluster-with-registry:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v5
with:
fetch-depth: 0

- name: Free disk space (delete unused tools)
id: delete-unused-tools
continue-on-error: true
shell: bash
run: |
free_disk_space=22
# delete preinstalled unused tools
cleanup=(
/usr/share/dotnet
/usr/share/miniconda
/usr/share/swift
/usr/share/kotlinc
#/opt/ghc
#/opt/hostedtoolcache/CodeQL
#/opt/hostedtoolcache/Ruby
#/opt/az
#/usr/local/lib/android
)
for d in "${cleanup[@]}"; do
if [[ -d "$d" ]]; then
rm -rf -- "$d" && echo "deleted $d"
else
echo "$d not found"
continue
fi
free=$(df -BGB --output=avail / | tail -1)
if [[ ${free%GB} -ge "${free_disk_space}" ]]; then
echo "Reached requested free disk space ${free_disk_space} [${free} free]."
exit 0
fi
done
df -h

- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3

- name: Create KinD Cluster
uses: helm/kind-action@v1
with:
cluster_name: kind

- name: tags
run: |
echo "TAG=$(make tag)" | tee -a "$GITHUB_ENV"

- name: Build Docker image
uses: docker/build-push-action@v5
with:
file: image/Dockerfile
context: .
push: false
load: true
tags: quay.io/rhacs-eng/infra-server:${{ env.TAG }}
cache-from: type=gha
cache-to: type=gha,mode=max

- name: Load into KinD
run: |
# Check cluster name
kind get clusters
#docker build -t quay.io/rhacs-eng/infra-server:${{ env.TAG }} -f image/Dockerfile .
kind load docker-image quay.io/rhacs-eng/infra-server:${{ env.TAG }} --name kind
docker images | grep infra-server

- name: Deploy
run: make deploy-local

- name: Wait for pods
run: kubectl wait --for=condition=ready pod -l app=infra-server -n infra --timeout=3m

- name: Start port-forward
run: |
kubectl port-forward -n infra svc/infra-server-service 8443:8443 >/dev/null 2>&1 &
echo "PORT_FORWARD_PID=$!" >> "$GITHUB_ENV"
sleep 3

- name: Run E2E tests
uses: cypress-io/github-action@v6
with:
working-directory: ui
start: npm run start
wait-on: 'http://localhost:3001'
wait-on-timeout: 60
command: npm run cypress:run:e2e
env:
BROWSER: none
PORT: 3001
INFRA_API_ENDPOINT: http://localhost:8443

- name: Cleanup port-forward
if: always()
run: |
if [ -n "${{ env.PORT_FORWARD_PID }}" ]; then
echo "Cleaning up port-forward (PID: ${{ env.PORT_FORWARD_PID }})..."
kill ${{ env.PORT_FORWARD_PID }} 2>/dev/null || true
fi
8 changes: 8 additions & 0 deletions DEPLOYMENT.md
Original file line number Diff line number Diff line change
Expand Up @@ -116,6 +116,14 @@ Use the environment variable `TEST_MODE` to disable certain infra service behavi

This is used in the infra PR clusters to set the login referer and disable telemetry.

#### Local Deploy Mode

For local test clusters (such as KinD/Colima), you can use the deploy-local make target to disable authentication, skip loading secrets, and use HTTP instead of HTTPS.

`make deploy-local`

This is only intended for local development deployments. For remote dev clusters, use the standard deployment method.

### Rollback

Use `helm rollback infra-server <REVISION>`.
Expand Down
25 changes: 25 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -253,6 +253,31 @@ helm-deploy: pre-check helm-dependency-update create-namespaces
helm-diff: pre-check helm-dependency-update create-namespaces
@./scripts/deploy/helm.sh diff $(VERSION) $(ENVIRONMENT) $(SECRET_VERSION)

## Deploy to local cluster (e.g., Colima) without GCP Secret Manager
.PHONY: deploy-local
deploy-local: helm-dependency-update create-namespaces
TEST_MODE=true ./scripts/deploy/helm.sh deploy-local $(shell make tag) local

## Run UI E2E tests against local deployment
.PHONY: test-e2e
test-e2e:
@echo "Waiting for infra-server to be ready..." >&2
@kubectl wait --for=condition=ready pod -l app=infra-server -n infra --timeout=3m >&2 || \
(echo "ERROR: infra-server pods did not become ready" >&2 && exit 1)
@echo "" >&2
@echo "Starting port-forward and running E2E tests..." >&2
@kubectl port-forward -n infra svc/infra-server-service 8443:8443 >/dev/null 2>&1 & \
PF_PID=$$!; \
cleanup() { \
echo "" >&2; \
echo "Cleaning up port-forward (PID: $$PF_PID)..." >&2; \
kill $$PF_PID 2>/dev/null || true; \
}; \
trap cleanup EXIT; \
sleep 5; \
echo "Running Cypress E2E tests..." >&2; \
cd ui && BROWSER=none PORT=3001 INFRA_API_ENDPOINT=http://localhost:8443 npm run test:e2e

## Bounce pods
.PHONY: bounce-infra-pods
bounce-infra-pods:
Expand Down
33 changes: 33 additions & 0 deletions chart/infra-server/configuration/local-values.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
environment: local

# Disable Auth0 for local development - allow anonymous access
auth0:
clientID: ""
tenant: ""

# Set local deploy mode to true for local development
localDeploy: true

# Enable test mode for faster cluster resume intervals
testMode: true

# Use local Docker images instead of pulling from registry
imagePullPolicy: Never

# Pull secrets for container registries - dummy values for local development
pullSecrets:
docker:
registry: "docker.io"
username: "dummy"
password: "dummy"
quay:
registry: "quay.io"
username: "dummy"
password: "dummy"
stackrox:
registry: "stackrox.io"
username: "dummy"
password: "dummy"

# Alertmanager configuration
alertmanagerSlackTeam: "dummy-team"
1 change: 0 additions & 1 deletion chart/infra-server/templates/_helpers.tpl
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@

{{- define "docker-io-pull-secret" }}
{{- printf "{\"auths\": {\"%s\": {\"auth\": \"%s\"}}}" .Values.pullSecrets.docker.registry (printf "%s:%s" .Values.pullSecrets.docker.username .Values.pullSecrets.docker.password | b64enc) | b64enc }}
{{- end }}
Expand Down
2 changes: 2 additions & 0 deletions chart/infra-server/templates/argo/secrets.yaml
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
{{- if not .Values.localDeploy }}
---
apiVersion: v1
kind: Secret
Expand All @@ -7,3 +8,4 @@ metadata:
data:
credentials.json: |-
{{ required ".Values.google_credentials_json is undefined" .Values.google_credentials_json }}
{{- end }}
2 changes: 2 additions & 0 deletions chart/infra-server/templates/aro/secrets.yaml
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
{{- if not .Values.localDeploy }}
---
apiVersion: v1
kind: Secret
Expand All @@ -16,3 +17,4 @@ data:
{{ .Values.aroClusterManager.azureSPSecretVal | b64enc }}
REDHAT_PULL_SECRET_BASE64: |-
{{ .Values.aroClusterManager.redHatPullSecretBase64 | b64enc }}
{{- end }}
2 changes: 2 additions & 0 deletions chart/infra-server/templates/aws/secrets.yaml
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
{{- if not .Values.localDeploy }}
---
apiVersion: v1
kind: Secret
Expand All @@ -10,3 +11,4 @@ data:
{{ .Values.aws.accessKeyId | b64enc }}
AWS_SECRET_ACCESS_KEY: |-
{{ .Values.aws.secretAccessKey | b64enc }}
{{- end }}
2 changes: 2 additions & 0 deletions chart/infra-server/templates/azure/secrets.yaml
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
{{- if not .Values.localDeploy }}

---

Expand All @@ -18,3 +19,4 @@ data:
{{ .Values.azure.sp_tenant | b64enc }}
ACR_TO_ATTACH: |-
{{ .Values.azure.aks_attached_acr | b64enc }}
{{- end }}
2 changes: 2 additions & 0 deletions chart/infra-server/templates/demo/secrets.yaml
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
{{- if not .Values.localDeploy }}
---

apiVersion: v1
Expand Down Expand Up @@ -90,3 +91,4 @@ data:
.dockerconfigjson: {{ template "pull-secret" .Values.pullSecrets.quay }}

---
{{- end }}
6 changes: 4 additions & 2 deletions chart/infra-server/templates/deployment.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -29,13 +29,15 @@ spec:
env:
- name: GOOGLE_APPLICATION_CREDENTIALS
value: /configuration/google-credentials.json
- name: LOCAL_DEPLOY
value: "{{ .Values.localDeploy }}"
- name: TEST_MODE
value: "{{ .Values.testMode }}"
readinessProbe:
httpGet:
path: /
port: 8443
scheme: HTTPS
scheme: {{ if eq .Values.environment "local" }}HTTP{{ else }}HTTPS{{ end }}
initialDelaySeconds: 5
periodSeconds: 5
command:
Expand All @@ -47,7 +49,7 @@ spec:
containerPort: 8443
- name: metrics
containerPort: 9101
imagePullPolicy: Always
imagePullPolicy: {{ .Values.imagePullPolicy | default "Always" }}
volumeMounts:
- mountPath: /configuration
name: configuration
Expand Down
2 changes: 2 additions & 0 deletions chart/infra-server/templates/gke/secrets.yaml
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
{{- if not .Values.localDeploy }}
---

apiVersion: v1
Expand All @@ -13,3 +14,4 @@ data:
{{ required ".Values.gke__gke_provisioner_json is undefined" .Values.gke__gke_provisioner_json }}

---
{{- end }}
2 changes: 2 additions & 0 deletions chart/infra-server/templates/ibm/secrets.yaml
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
{{- if not .Values.localDeploy }}
---
apiVersion: v1
kind: Secret
Expand All @@ -8,3 +9,4 @@ metadata:
data:
IBM_ROKS_API_KEY: |-
{{ .Values.ibmCloudSecrets.ibmRoksApiKey | b64enc }}
{{- end }}
2 changes: 2 additions & 0 deletions chart/infra-server/templates/monitoring/secrets.yaml
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
{{- if not .Values.localDeploy }}
---
apiVersion: v1
kind: Secret
Expand All @@ -6,3 +7,4 @@ metadata:
namespace: monitoring
data:
webhookURL: "{{ .Values.alertmanagerSlackWebhook | b64enc }}"
{{- end }}
2 changes: 2 additions & 0 deletions chart/infra-server/templates/openshift-4/secrets.yaml
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
{{- if not .Values.localDeploy }}
apiVersion: v1
kind: Secret
type: Opaque
Expand Down Expand Up @@ -43,3 +44,4 @@ metadata:
data:
REDHAT_PULL_SECRET: |-
{{ required ".Values.openshift_4__redhat_pull_secret_json is undefined" .Values.openshift_4__redhat_pull_secret_json }}
{{- end }}
2 changes: 2 additions & 0 deletions chart/infra-server/templates/openshift/secrets.yaml
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
{{- if not .Values.localDeploy }}
apiVersion: v1
kind: Secret
type: Opaque
Expand All @@ -9,3 +10,4 @@ metadata:
data:
google-credentials.json: |-
{{ required ".Values.openshift__google_credentials_json is undefined" .Values.openshift__google_credentials_json }}
{{- end }}
2 changes: 2 additions & 0 deletions chart/infra-server/templates/osd/secrets.yaml
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
{{- if not .Values.localDeploy }}
---
apiVersion: v1
kind: Secret
Expand All @@ -19,3 +20,4 @@ data:
{{ .Values.osdClusterManager.gcpSaCredsJsonBase64 | b64enc }}
GCP_SERVICE_ACCOUNT_KEY_BASE64: |-
{{ .Values.osdClusterManager.gcpServiceAccountKeyBase64 | b64enc }}
{{- end }}
Loading
Loading