From d10271944e8e3b9295469906bbda8962933ba15d Mon Sep 17 00:00:00 2001 From: Miles Garnsey Date: Thu, 23 May 2024 14:05:01 +1000 Subject: [PATCH] Test to demonstrate that the vector container is not being created correctly. --- .../k8ssandracluster_controller_test.go | 24 +++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/controllers/k8ssandra/k8ssandracluster_controller_test.go b/controllers/k8ssandra/k8ssandracluster_controller_test.go index fdf92e5ca..6328b6aa3 100644 --- a/controllers/k8ssandra/k8ssandracluster_controller_test.go +++ b/controllers/k8ssandra/k8ssandracluster_controller_test.go @@ -2415,6 +2415,11 @@ func injectContainersAndVolumes(t *testing.T, ctx context.Context, f *framework. Cassandra: &api.CassandraClusterTemplate{ DatacenterOptions: api.DatacenterOptions{ ServerVersion: serverVersion, + Telemetry: &telemetryapi.TelemetrySpec{ + Vector: &telemetryapi.VectorSpec{ + Enabled: ptr.To(true), + }, + }, StorageConfig: &cassdcapi.StorageConfig{ CassandraDataVolumeClaimSpec: &corev1.PersistentVolumeClaimSpec{ StorageClassName: &defaultStorageClass, @@ -2431,6 +2436,13 @@ func injectContainersAndVolumes(t *testing.T, ctx context.Context, f *framework. }, }, }, + { + Name: "server-system-logger", + SecurityContext: &corev1.SecurityContext{ + RunAsUser: ptr.To[int64](9999), + ReadOnlyRootFilesystem: ptr.To(true), + }, + }, }, ExtraVolumes: &api.K8ssandraVolumes{ PVCs: []cassdcapi.AdditionalVolumes{ @@ -2505,6 +2517,18 @@ func injectContainersAndVolumes(t *testing.T, ctx context.Context, f *framework. _, foundMain := cassandra.FindContainer(dc.Spec.PodTemplateSpec, "injected-container") require.True(foundMain, "failed to find injected-container") + vectorContainerIdx, foundVector := cassandra.FindContainer(dc.Spec.PodTemplateSpec, "server-system-logger") + require.True(foundVector, "failed to find injected-container") + require.Equal(ptr.To[int64](9999), + dc.Spec.PodTemplateSpec.Spec.Containers[vectorContainerIdx].SecurityContext.RunAsUser, + "server-system-logger RunAsUser is not set") + require.Equal(ptr.To(true), + dc.Spec.PodTemplateSpec.Spec.Containers[vectorContainerIdx].SecurityContext.ReadOnlyRootFilesystem, + "server-system-logger RunAsUser is not set") + require.Equal(ptr.To(true), + dc.Spec.PodTemplateSpec.Spec.Containers[vectorContainerIdx].SecurityContext.ReadOnlyRootFilesystem, + "server-system-logger RunAsUser is not set") + require.Equal(2, len(dc.Spec.StorageConfig.AdditionalVolumes), "expected 2 additionals volumes") require.Equal("/etc/injected", dc.Spec.StorageConfig.AdditionalVolumes[0].MountPath, "expected injected-volume mount path")