From 91ea494c96ee3949af676760ba5739a4b0dfc19d Mon Sep 17 00:00:00 2001 From: Tommi Hovi Date: Mon, 25 Sep 2023 13:39:27 +0300 Subject: [PATCH] Add test for deterministic volume/volumemount order for sensor deployment Signed-off-by: Tommi Hovi --- controllers/sensor/resource_test.go | 39 +++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) diff --git a/controllers/sensor/resource_test.go b/controllers/sensor/resource_test.go index 83863d01d6..deb8deb7f9 100644 --- a/controllers/sensor/resource_test.go +++ b/controllers/sensor/resource_test.go @@ -262,6 +262,45 @@ func Test_BuildDeployment(t *testing.T) { assert.True(t, hasTLSSecretVolume) assert.True(t, hasTLSSecretVolumeMount) }) + + t.Run("test secret volume and volumemount order determinisitc", func(t *testing.T) { + + args := &AdaptorArgs{ + Image: testImage, + Sensor: sensorObj, + Labels: testLabels, + } + + wantVolumeNames := []string{"test-data", "auth-volume", "tmp"} + wantVolumeMountNames := []string{"test-data", "auth-volume", "tmp"} + + deployment, err := buildDeployment(args, fakeEventBus) + assert.Nil(t, err) + assert.NotNil(t, deployment) + gotVolumes := deployment.Spec.Template.Spec.Volumes + gotVolumeMounts := deployment.Spec.Template.Spec.Containers[0].VolumeMounts + + var gotVolumeNames []string + var gotVolumeMountNames []string + + for _, v := range gotVolumes { + gotVolumeNames = append(gotVolumeNames, v.Name) + } + for _, v := range gotVolumeMounts { + gotVolumeMountNames = append(gotVolumeMountNames, v.Name) + } + + assert.Equal(t, len(gotVolumes), len(wantVolumeNames)) + assert.Equal(t, len(gotVolumeMounts), len(wantVolumeMountNames)) + + for i := range gotVolumeNames { + assert.Equal(t, gotVolumeNames[i], wantVolumeNames[i]) + } + for i := range gotVolumeMountNames { + assert.Equal(t, gotVolumeMountNames[i], wantVolumeMountNames[i]) + } + }) + } func TestResourceReconcile(t *testing.T) {