From f9676e69a6fd5d3eef3cefc56e35dfe32b8f32ae Mon Sep 17 00:00:00 2001 From: Camila Macedo <7708031+camilamacedo86@users.noreply.github.com> Date: Thu, 12 Dec 2024 22:44:58 +0000 Subject: [PATCH] e2e: add tests to verify metrics endpoint --- test/e2e/metrics_endpoint_test.go | 85 +++++++++++++++++++++++++++++++ 1 file changed, 85 insertions(+) create mode 100644 test/e2e/metrics_endpoint_test.go diff --git a/test/e2e/metrics_endpoint_test.go b/test/e2e/metrics_endpoint_test.go new file mode 100644 index 00000000..cefc1cd8 --- /dev/null +++ b/test/e2e/metrics_endpoint_test.go @@ -0,0 +1,85 @@ +package e2e + +import ( + "bytes" + "os/exec" + "testing" + "time" + + "github.com/stretchr/testify/require" +) + +func TestCatalogdMetricsWorkflowValidation(t *testing.T) { + var ( + token string + curlPod = "curl-metrics" + namespace = "olmv1-system" + ) + + // Step 1: Create ClusterRoleBinding for catalogd metrics + t.Log("Creating ClusterRoleBinding for catalogd metrics") + cmd := exec.Command("kubectl", "create", "clusterrolebinding", "catalogd-metrics-binding", + "--clusterrole=catalogd-metrics-reader", + "--serviceaccount="+namespace+":catalogd-controller-manager") + output, err := cmd.CombinedOutput() + require.NoError(t, err, "Error creating ClusterRoleBinding: %s", string(output)) + + // Step 2: Generate ServiceAccount Token + t.Log("Generating ServiceAccount token") + tokenCmd := exec.Command("kubectl", "create", "token", "catalogd-controller-manager", "-n", namespace) + tokenOutput, err := tokenCmd.Output() + require.NoError(t, err, "Error creating token: %s", string(tokenOutput)) + token = string(bytes.TrimSpace(tokenOutput)) + + // Step 3: Create and Run the Curl Pod + t.Log("Creating curl pod to validate the metrics endpoint") + cmd = exec.Command("kubectl", "run", curlPod, + "--image=curlimages/curl:7.87.0", "-n", namespace, + "--restart=Never", + "--overrides", `{ + "spec": { + "containers": [{ + "name": "curl", + "image": "curlimages/curl:7.87.0", + "command": ["sh", "-c", "sleep 3600"], + "securityContext": { + "allowPrivilegeEscalation": false, + "capabilities": { + "drop": ["ALL"] + }, + "runAsNonRoot": true, + "runAsUser": 1000, + "seccompProfile": { + "type": "RuntimeDefault" + } + } + }], + "serviceAccountName": "catalogd-controller-manager" + } + }`) + output, err = cmd.CombinedOutput() + require.NoError(t, err, "Error creating curl pod: %s", string(output)) + + // Step 4: Validate Pod Readiness + t.Log("Waiting for the curl pod to be ready") + require.Eventually(t, func() bool { + statusCmd := exec.Command("kubectl", "get", "pod", curlPod, "-n", namespace, "-o", "jsonpath={.status.phase}") + statusOutput, _ := statusCmd.Output() + return string(bytes.TrimSpace(statusOutput)) == "Running" + }, 60*time.Second, 5*time.Second, "Curl pod is not running") + + // Step 5: Call the Metrics Endpoint + t.Log("Validating the metrics endpoint") + metricsURL := "https://catalogd-service.olmv1-system.svc.cluster.local:7443/metrics" + curlCmd := exec.Command("kubectl", "exec", curlPod, "-n", namespace, "--", + "curl", "-v", "-k", "-H", "Authorization: Bearer "+token, metricsURL) + output, err = curlCmd.CombinedOutput() + require.NoError(t, err, "Error calling metrics endpoint: %s", string(output)) + require.Contains(t, string(output), "200 OK", "Metrics endpoint did not return 200 OK") + require.Contains(t, string(output), "# HELP", "Metrics data not found in response") + + // Step 6: Cleanup + t.Log("Cleaning up resources") + _ = exec.Command("kubectl", "delete", "pod", curlPod, "-n", namespace, "--ignore-not-found=true").Run() + _ = exec.Command("kubectl", "delete", "clusterrolebinding", "catalogd-metrics-binding", "--ignore-not-found=true").Run() +}