From deb03c28930f6e1e83c39fc69e45b25eb6a990f6 Mon Sep 17 00:00:00 2001 From: Amir Blum Date: Tue, 29 Oct 2024 17:29:13 +0200 Subject: [PATCH] fix: check for empty pointers in describe --- k8sutils/pkg/describe/source.go | 32 ++++++++++++------------- k8sutils/pkg/describe/source/analyze.go | 7 +++++- 2 files changed, 22 insertions(+), 17 deletions(-) diff --git a/k8sutils/pkg/describe/source.go b/k8sutils/pkg/describe/source.go index b8f599556..389923387 100644 --- a/k8sutils/pkg/describe/source.go +++ b/k8sutils/pkg/describe/source.go @@ -11,7 +11,7 @@ import ( "k8s.io/client-go/kubernetes" ) -func printWorkloadManifestInfo(analyze *source.SourceAnalyze, sb *strings.Builder) bool { +func printWorkloadManifestInfo(analyze *source.SourceAnalyze, sb *strings.Builder) { printProperty(sb, 0, &analyze.Name) printProperty(sb, 0, &analyze.Kind) printProperty(sb, 0, &analyze.Namespace) @@ -21,8 +21,6 @@ func printWorkloadManifestInfo(analyze *source.SourceAnalyze, sb *strings.Builde printProperty(sb, 1, analyze.Labels.Workload) printProperty(sb, 1, analyze.Labels.Namespace) printProperty(sb, 1, &analyze.Labels.InstrumentedText) - - return analyze.Labels.Instrumented.Value.(bool) } func printInstrumentationConfigInfo(analyze *source.SourceAnalyze, sb *strings.Builder) { @@ -60,22 +58,24 @@ func printInstrumentedApplicationInfo(analyze *source.SourceAnalyze, sb *strings printProperty(sb, 1, &analyze.InstrumentedApplication.Created) printProperty(sb, 1, analyze.InstrumentedApplication.CreateTime) - printProperty(sb, 1, &analyze.RuntimeInfo.Generation) - describeText(sb, 1, "Detected Containers:") - for _, container := range analyze.RuntimeInfo.Containers { - printProperty(sb, 2, &container.ContainerName) - printProperty(sb, 3, &container.Language) - printProperty(sb, 3, &container.RuntimeVersion) - if len(container.EnvVars) > 0 { - describeText(sb, 3, "Relevant Environment Variables:") - for _, envVar := range container.EnvVars { - describeText(sb, 4, fmt.Sprintf("%s: %s", envVar.Name, envVar.Value)) + if analyze.RuntimeInfo != nil { + printProperty(sb, 1, &analyze.RuntimeInfo.Generation) + describeText(sb, 1, "Detected Containers:") + for _, container := range analyze.RuntimeInfo.Containers { + printProperty(sb, 2, &container.ContainerName) + printProperty(sb, 3, &container.Language) + printProperty(sb, 3, &container.RuntimeVersion) + if len(container.EnvVars) > 0 { + describeText(sb, 3, "Relevant Environment Variables:") + for _, envVar := range container.EnvVars { + describeText(sb, 4, fmt.Sprintf("%s: %s", envVar.Name, envVar.Value)) + } } } } } -func printAppliedInstrumentationDeviceInfo(analyze *source.SourceAnalyze, workloadObj *source.K8sSourceObject, instrumented bool, sb *strings.Builder) { +func printAppliedInstrumentationDeviceInfo(analyze *source.SourceAnalyze, sb *strings.Builder) { describeText(sb, 0, "\nInstrumentation Device:") printProperty(sb, 1, &analyze.InstrumentationDevice.StatusText) @@ -124,11 +124,11 @@ func printPodsInfo(analyze *source.SourceAnalyze, sb *strings.Builder) { func DescribeSourceToText(analyze *source.SourceAnalyze) string { var sb strings.Builder - instrumented := printWorkloadManifestInfo(analyze, &sb) + printWorkloadManifestInfo(analyze, &sb) printInstrumentationConfigInfo(analyze, &sb) printRuntimeDetails(analyze, &sb) printInstrumentedApplicationInfo(analyze, &sb) - printAppliedInstrumentationDeviceInfo(analyze, nil, instrumented, &sb) + printAppliedInstrumentationDeviceInfo(analyze, &sb) printPodsInfo(analyze, &sb) return sb.String() diff --git a/k8sutils/pkg/describe/source/analyze.go b/k8sutils/pkg/describe/source/analyze.go index 55a578849..a27e8898d 100644 --- a/k8sutils/pkg/describe/source/analyze.go +++ b/k8sutils/pkg/describe/source/analyze.go @@ -255,10 +255,15 @@ func analyzeInstrumentedApplication(resources *OdigosSourceResources) Instrument } } + containers := make([]ContainerRuntimeInfoAnalyze, 0) + if resources.InstrumentedApplication != nil { + containers = analyzeRuntimeDetails(resources.InstrumentedApplication.Spec.RuntimeDetails) + } + return InstrumentedApplicationAnalyze{ Created: created, CreateTime: createdTime, - Containers: analyzeRuntimeDetails(resources.InstrumentedApplication.Spec.RuntimeDetails), + Containers: containers, } }