From e453f3553ec2a761c1d4a8b6dda3ebe6511bd39a Mon Sep 17 00:00:00 2001 From: zhihonl <61301537+zhihonl@users.noreply.github.com> Date: Tue, 19 Nov 2024 10:49:57 -0500 Subject: [PATCH] Add EKS integration test for FluentBit log emission with custom environment (#432) --- terraform/eks/daemon/entity/main.tf | 42 ++++++++++++++++++++++++++++- test/entity/entity_test.go | 18 +++++++++++++ 2 files changed, 59 insertions(+), 1 deletion(-) diff --git a/terraform/eks/daemon/entity/main.tf b/terraform/eks/daemon/entity/main.tf index a5dca2aeb..3a5db09aa 100644 --- a/terraform/eks/daemon/entity/main.tf +++ b/terraform/eks/daemon/entity/main.tf @@ -164,6 +164,9 @@ resource "aws_security_group_rule" "nodes_cluster_inbound" { } resource "null_resource" "clone_helm_chart" { + triggers = { + timestamp = "${timestamp()}" # Forces re-run on every apply + } provisioner "local-exec" { command = <<-EOT if [ ! -d "./helm-charts" ]; then @@ -272,9 +275,45 @@ resource "kubernetes_pod" "petclinic_instrumentation" { } } + +resource "kubernetes_pod" "petclinic_custom_env" { + depends_on = [aws_eks_node_group.this, helm_release.aws_observability, null_resource.update_image] + metadata { + name = "petclinic-instrumentation-custom-env" + annotations = { + "instrumentation.opentelemetry.io/inject-java" = "true" + } + labels = { + app = "petclinic" + } + } + + spec { + container { + name = "petclinic" + image = "506463145083.dkr.ecr.us-west-2.amazonaws.com/cwagent-integ-test-petclinic:latest" + + port { + container_port = 8080 + } + + env { + name = "OTEL_SERVICE_NAME" + value = "petclinic-custom-service-name" + } + + env { + name = "OTEL_RESOURCE_ATTRIBUTES" + value = "deployment.environment=petclinic-custom-environment" + } + + } + } +} + # Traffic generator pod with bash command resource "kubernetes_pod" "traffic_generator_instrumentation" { - depends_on = [kubernetes_pod.petclinic_instrumentation, kubernetes_service.petclinic_service] + depends_on = [kubernetes_pod.petclinic_instrumentation, kubernetes_pod.petclinic_custom_env, kubernetes_service.petclinic_service] metadata { name = "traffic-generator-instrumentation-default-env" } @@ -339,6 +378,7 @@ resource "null_resource" "validator" { null_resource.update_image, kubernetes_pod.log_generator, kubernetes_pod.petclinic_instrumentation, + kubernetes_pod.petclinic_custom_env, kubernetes_pod.traffic_generator_instrumentation ] diff --git a/test/entity/entity_test.go b/test/entity/entity_test.go index fedfb4117..a45b7464b 100644 --- a/test/entity/entity_test.go +++ b/test/entity/entity_test.go @@ -197,6 +197,24 @@ func TestPutLogEventEntityEKS(t *testing.T) { serviceNameSource: entityServiceNameSourceInstrumentation, }, }, + "Entity/InstrumentationServiceNameSourceCustomEnvironment": { + agentConfigPath: filepath.Join("resources", "compass_default_log.json"), + podName: "petclinic-instrumentation-custom-env", + expectedEntity: expectedEntity{ + entityType: eksServiceEntityType, + // This service name comes from OTEL_SERVICE_NAME which is + // customized in the terraform code when creating the pod + name: "petclinic-custom-service-name", + environment: "petclinic-custom-environment", + platformType: entityEKSPlatform, + k8sWorkload: "petclinic-instrumentation-custom-env", + k8sNode: *instancePrivateDNS, + k8sNamespace: k8sDefaultNamespace, + eksCluster: env.EKSClusterName, + instanceId: env.InstanceId, + serviceNameSource: entityServiceNameSourceInstrumentation, + }, + }, } for name, testCase := range testCases { t.Run(name, func(t *testing.T) {