From 13f78ca842b610b18f09906fc5e2f8ce280476b0 Mon Sep 17 00:00:00 2001 From: Jeffrey Chien Date: Fri, 23 Aug 2024 11:52:53 -0400 Subject: [PATCH] [processor/resourcedetection] Fix EKS detector nil panic. (#227) --- .../resourcedetectionprocessor/internal/aws/eks/detector.go | 6 +++--- .../internal/aws/eks/detector_test.go | 6 +++--- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/processor/resourcedetectionprocessor/internal/aws/eks/detector.go b/processor/resourcedetectionprocessor/internal/aws/eks/detector.go index 17331d162a37..905dbf50f197 100644 --- a/processor/resourcedetectionprocessor/internal/aws/eks/detector.go +++ b/processor/resourcedetectionprocessor/internal/aws/eks/detector.go @@ -53,7 +53,6 @@ type eksDetectorUtils struct { type detector struct { utils detectorUtils logger *zap.Logger - err error ra metadata.ResourceAttributesConfig rb *metadata.ResourceBuilder } @@ -66,11 +65,12 @@ var _ detectorUtils = (*eksDetectorUtils)(nil) func NewDetector(set processor.Settings, dcfg internal.DetectorConfig) (internal.Detector, error) { cfg := dcfg.(Config) utils, err := newK8sDetectorUtils() - + if err != nil { + return nil, err + } return &detector{ utils: utils, logger: set.Logger, - err: err, ra: cfg.ResourceAttributes, rb: metadata.NewResourceBuilder(cfg.ResourceAttributes), }, nil diff --git a/processor/resourcedetectionprocessor/internal/aws/eks/detector_test.go b/processor/resourcedetectionprocessor/internal/aws/eks/detector_test.go index e269f1bcbea6..d27d6aa2f0f6 100644 --- a/processor/resourcedetectionprocessor/internal/aws/eks/detector_test.go +++ b/processor/resourcedetectionprocessor/internal/aws/eks/detector_test.go @@ -43,8 +43,8 @@ func (detectorUtils *MockDetectorUtils) getClusterNameTagFromReservations(_ []*e func TestNewDetector(t *testing.T) { dcfg := CreateDefaultConfig() detector, err := NewDetector(processortest.NewNopSettings(), dcfg) - assert.NoError(t, err) - assert.NotNil(t, detector) + assert.Error(t, err) + assert.Nil(t, detector) } // Tests EKS resource detector running in EKS environment @@ -55,7 +55,7 @@ func TestEKS(t *testing.T) { t.Setenv("KUBERNETES_SERVICE_HOST", "localhost") detectorUtils.On("getConfigMap", authConfigmapNS, authConfigmapName).Return(map[string]string{conventions.AttributeK8SClusterName: clusterName}, nil) // Call EKS Resource detector to detect resources - eksResourceDetector := &detector{utils: detectorUtils, err: nil, ra: metadata.DefaultResourceAttributesConfig(), rb: metadata.NewResourceBuilder(metadata.DefaultResourceAttributesConfig())} + eksResourceDetector := &detector{utils: detectorUtils, ra: metadata.DefaultResourceAttributesConfig(), rb: metadata.NewResourceBuilder(metadata.DefaultResourceAttributesConfig())} res, _, err := eksResourceDetector.Detect(ctx) require.NoError(t, err)