From c0aafbb6fdec68da5e6b729c3ccae97935324a2f Mon Sep 17 00:00:00 2001 From: zhihonl <61301537+zhihonl@users.noreply.github.com> Date: Wed, 13 Nov 2024 15:05:14 -0500 Subject: [PATCH] Add EKS integration test for FluentBit log emission with Entity field (#427) * Add EKS integration test for FluentBit emitting entity with K8sWorkload * Modify comment * Fix linter errors * Add validator struct for different platforms entity validation --- generator/test_case_generator.go | 4 + terraform/eks/daemon/entity/main.tf | 252 +++++++++++++++++++++++ terraform/eks/daemon/entity/providers.tf | 29 +++ terraform/eks/daemon/entity/variables.tf | 42 ++++ test/entity/entity_test.go | 222 ++++++++++++++++++++ util/awsservice/cloudwatchlogs.go | 41 ++++ 6 files changed, 590 insertions(+) create mode 100644 terraform/eks/daemon/entity/main.tf create mode 100644 terraform/eks/daemon/entity/providers.tf create mode 100644 terraform/eks/daemon/entity/variables.tf create mode 100644 test/entity/entity_test.go diff --git a/generator/test_case_generator.go b/generator/test_case_generator.go index 925878746..8e2a67f9f 100644 --- a/generator/test_case_generator.go +++ b/generator/test_case_generator.go @@ -231,6 +231,10 @@ var testTypeToTestConfig = map[string][]testConfig{ testDir: "./test/awsneuron", terraformDir: "terraform/eks/daemon/awsneuron", targets: map[string]map[string]struct{}{"arc": {"amd64": {}}}, }, + { + testDir: "./test/entity", terraformDir: "terraform/eks/daemon/entity", + targets: map[string]map[string]struct{}{"arc": {"amd64": {}}}, + }, }, "eks_deployment": { {testDir: "./test/metric_value_benchmark"}, diff --git a/terraform/eks/daemon/entity/main.tf b/terraform/eks/daemon/entity/main.tf new file mode 100644 index 000000000..b8d80bfd4 --- /dev/null +++ b/terraform/eks/daemon/entity/main.tf @@ -0,0 +1,252 @@ +// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. +// SPDX-License-Identifier: MIT + +module "common" { + source = "../../../common" +} + +module "basic_components" { + source = "../../../basic_components" + + region = var.region +} + +data "aws_eks_cluster_auth" "this" { + name = aws_eks_cluster.this.name +} + +resource "aws_eks_cluster" "this" { + name = "cwagent-eks-integ-${module.common.testing_id}" + role_arn = module.basic_components.role_arn + version = var.k8s_version + vpc_config { + subnet_ids = module.basic_components.public_subnet_ids + security_group_ids = [module.basic_components.security_group] + } +} + +# EKS Node Groups +resource "aws_eks_node_group" "this" { + cluster_name = aws_eks_cluster.this.name + node_group_name = "cwagent-eks-integ-node-${module.common.testing_id}" + node_role_arn = aws_iam_role.node_role.arn + subnet_ids = module.basic_components.public_subnet_ids + + scaling_config { + desired_size = 1 + max_size = 1 + min_size = 1 + } + + ami_type = var.ami_type + capacity_type = "ON_DEMAND" + disk_size = 20 + instance_types = [var.instance_type] + + depends_on = [ + aws_iam_role_policy_attachment.node_AmazonEC2ContainerRegistryReadOnly, + aws_iam_role_policy_attachment.node_AmazonEKS_CNI_Policy, + aws_iam_role_policy_attachment.node_AmazonEKSWorkerNodePolicy, + aws_iam_role_policy_attachment.node_CloudWatchAgentServerPolicy, + aws_iam_role_policy_attachment.node_AWSXRayDaemonWriteAccess + ] +} + +# EKS Node IAM Role +resource "aws_iam_role" "node_role" { + name = "cwagent-eks-Worker-Role-${module.common.testing_id}" + + assume_role_policy = <= StandardRetries { + return nil, fmt.Errorf("attempted get query results after %s without success. final status: %v", time.Duration(attempts)*retryInterval, results.Status) + } + attempts++ + time.Sleep(retryInterval) + case types.QueryStatusComplete: + return results.Results, nil + default: + return nil, fmt.Errorf("unexpected query status: %v", results.Status) + } + } +} + func GetLogStreams(logGroupName string) []types.LogStream { for i := 0; i < logStreamRetry; i++ { describeLogStreamsOutput, err := CwlClient.DescribeLogStreams(ctx, &cloudwatchlogs.DescribeLogStreamsInput{