Skip to content

Commit

Permalink
e2e: add tests to verify metrics endpoint
Browse files Browse the repository at this point in the history
  • Loading branch information
camilamacedo86 committed Dec 12, 2024
1 parent e461013 commit abe9cea
Showing 1 changed file with 88 additions and 0 deletions.
88 changes: 88 additions & 0 deletions test/e2e/metrics_endpoint_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
package e2e

import (
"bytes"
"os/exec"

. "github.com/onsi/ginkgo/v2"
. "github.com/onsi/gomega"
)

var _ = Describe("Catalogd Metrics Workflow Validation", func() {

var (
token string
curlPod = "curl-metrics"
namespace = "olmv1-system"
)

BeforeEach(func() {
// Step 1: Create ClusterRoleBinding
By("Creating ClusterRoleBinding for catalogd metrics")
_, err := exec.Command("kubectl", "create", "clusterrolebinding", "catalogd-metrics-binding",
"--clusterrole=catalogd-metrics-reader",
"--serviceaccount="+namespace+":catalogd-controller-manager").CombinedOutput()
Expect(err).ToNot(HaveOccurred())

// Step 2: Generate ServiceAccount Token
By("Generating a token for the catalogd-controller-manager ServiceAccount")
out, err := exec.Command("kubectl", "create", "token", "catalogd-controller-manager", "-n", namespace).Output()
Expect(err).ToNot(HaveOccurred())
token = string(bytes.TrimSpace(out))

// Step 3: Create the Curl Pod
By("Creating a curl pod to validate the metrics endpoint")
curlPodManifest := `
apiVersion: v1
kind: Pod
metadata:
name: curl-metrics
namespace: olmv1-system
spec:
serviceAccountName: catalogd-controller-manager
containers:
- name: curl
image: curlimages/curl:7.87.0
command:
- sh
- -c
- sleep 3600
restartPolicy: Never`
cmd := exec.Command("kubectl", "apply", "-f", "-")
cmd.Stdin = bytes.NewReader([]byte(curlPodManifest))
Expect(cmd.Run()).To(Succeed())

// Step 4: Ensure the Pod is Running
By("Waiting for the curl pod to be ready")
Eventually(func() string {
out, _ := exec.Command("kubectl", "get", "pod", curlPod, "-n", namespace, "-o", "jsonpath={.status.phase}").Output()
return string(out)
}, "60s", "5s").Should(Equal("Running"))
})

It("Validates the metrics endpoint", func() {
// Step 5: Exec into the curl pod and call the metrics endpoint
By("Calling the metrics endpoint from within the curl pod")
metricsURL := "https://catalogd-service.olmv1-system.svc.cluster.local:7443/metrics"
curlCmd := []string{
"exec", "-it", curlPod, "-n", namespace, "--", "curl", "-v", "-k",
"-H", "Authorization: Bearer " + token, metricsURL,
}
cmd := exec.Command("kubectl", curlCmd...)
output, err := cmd.CombinedOutput()

// Verify the response
Expect(err).ToNot(HaveOccurred())
Expect(string(output)).To(ContainSubstring("HTTP/2 200"))
Expect(string(output)).To(ContainSubstring("# HELP"))
})

AfterEach(func() {
By("Cleaning up resources")
// Delete the curl pod
_ = exec.Command("kubectl", "delete", "pod", curlPod, "-n", namespace, "--ignore-not-found=true").Run()

// Delete the ClusterRoleBinding
_ = exec.Command("kubectl", "delete", "clusterrolebinding", "catalogd-metrics-binding", "--ignore-not-found=true").Run()
})
})

0 comments on commit abe9cea

Please sign in to comment.