From 3f1818d28c91e3de85beb6f13f5d685e9f6550f1 Mon Sep 17 00:00:00 2001 From: Jan Kantert Date: Sat, 27 Apr 2024 15:08:56 +0200 Subject: [PATCH 1/2] also hash binarydata in configmaps --- .../daemonset/daemonset_controller_test.go | 2 +- .../deployment/deployment_controller_test.go | 2 +- .../statefulset_controller_test.go | 2 +- pkg/core/handler_test.go | 2 +- pkg/core/hash.go | 20 +++++-- pkg/core/hash_test.go | 57 ++++++++++++++++--- test/utils/test_objects.go | 5 ++ 7 files changed, 74 insertions(+), 16 deletions(-) diff --git a/pkg/controller/daemonset/daemonset_controller_test.go b/pkg/controller/daemonset/daemonset_controller_test.go index 5af47513..6a582679 100644 --- a/pkg/controller/daemonset/daemonset_controller_test.go +++ b/pkg/controller/daemonset/daemonset_controller_test.go @@ -201,7 +201,7 @@ var _ = Describe("DaemonSet controller Suite", func() { eventMessage := func(event *corev1.Event) string { return event.Message } - hashMessage := "Configuration hash updated to ebabf80ef45218b27078a41ca16b35a4f91cb5672f389e520ae9da6ee3df3b1c" + hashMessage := "Configuration hash updated to bd786f47ef9b79841ddba1059752f95c4fe21906df5e2964786b4658e02758d5" Eventually(func() *corev1.EventList { events := &corev1.EventList{} m.Client.List(context.TODO(), events) diff --git a/pkg/controller/deployment/deployment_controller_test.go b/pkg/controller/deployment/deployment_controller_test.go index 7bdbc817..36bd0b51 100644 --- a/pkg/controller/deployment/deployment_controller_test.go +++ b/pkg/controller/deployment/deployment_controller_test.go @@ -204,7 +204,7 @@ var _ = Describe("Deployment controller Suite", func() { eventMessage := func(event *corev1.Event) string { return event.Message } - hashMessage := "Configuration hash updated to ebabf80ef45218b27078a41ca16b35a4f91cb5672f389e520ae9da6ee3df3b1c" + hashMessage := "Configuration hash updated to bd786f47ef9b79841ddba1059752f95c4fe21906df5e2964786b4658e02758d5" Eventually(func() *corev1.EventList { events := &corev1.EventList{} m.Client.List(context.TODO(), events) diff --git a/pkg/controller/statefulset/statefulset_controller_test.go b/pkg/controller/statefulset/statefulset_controller_test.go index 87bc07e3..d9277d2b 100644 --- a/pkg/controller/statefulset/statefulset_controller_test.go +++ b/pkg/controller/statefulset/statefulset_controller_test.go @@ -206,7 +206,7 @@ var _ = Describe("StatefulSet controller Suite", func() { eventMessage := func(event *corev1.Event) string { return event.Message } - hashMessage := "Configuration hash updated to ebabf80ef45218b27078a41ca16b35a4f91cb5672f389e520ae9da6ee3df3b1c" + hashMessage := "Configuration hash updated to bd786f47ef9b79841ddba1059752f95c4fe21906df5e2964786b4658e02758d5" Eventually(func() *corev1.EventList { events := &corev1.EventList{} m.Client.List(context.TODO(), events) diff --git a/pkg/core/handler_test.go b/pkg/core/handler_test.go index eabc84f0..b59ae8bf 100644 --- a/pkg/core/handler_test.go +++ b/pkg/core/handler_test.go @@ -194,7 +194,7 @@ var _ = Describe("Wave controller Suite", func() { eventMessage := func(event *corev1.Event) string { return event.Message } - hashMessage := "Configuration hash updated to ebabf80ef45218b27078a41ca16b35a4f91cb5672f389e520ae9da6ee3df3b1c" + hashMessage := "Configuration hash updated to bd786f47ef9b79841ddba1059752f95c4fe21906df5e2964786b4658e02758d5" Eventually(func() *corev1.EventList { events := &corev1.EventList{} m.Client.List(context.TODO(), events) diff --git a/pkg/core/hash.go b/pkg/core/hash.go index 87b74235..85befda8 100644 --- a/pkg/core/hash.go +++ b/pkg/core/hash.go @@ -30,10 +30,10 @@ import ( func calculateConfigHash(children []configObject) (string, error) { // hashSource contains all the data to be hashed hashSource := struct { - ConfigMaps map[string]map[string]string `json:"configMaps"` + ConfigMaps map[string]map[string][]byte `json:"configMaps"` Secrets map[string]map[string][]byte `json:"secrets"` }{ - ConfigMaps: make(map[string]map[string]string), + ConfigMaps: make(map[string]map[string][]byte), Secrets: make(map[string]map[string][]byte), } @@ -65,14 +65,24 @@ func calculateConfigHash(children []configObject) (string, error) { // getConfigMapData extracts all the relevant data from the ConfigMap, whether that is // the whole ConfigMap or only the specified keys. -func getConfigMapData(child configObject) map[string]string { +func getConfigMapData(child configObject) map[string][]byte { cm := *child.object.(*corev1.ConfigMap) if child.allKeys { - return cm.Data + data := make(map[string][]byte) + for key := range cm.Data { + data[key] = []byte(cm.Data[key]) + } + for key := range cm.BinaryData { + data[key] = cm.BinaryData[key] + } + return data } - keyData := make(map[string]string) + keyData := make(map[string][]byte) for key := range child.keys { if value, exists := cm.Data[key]; exists { + keyData[key] = []byte(value) + } + if value, exists := cm.BinaryData[key]; exists { keyData[key] = value } } diff --git a/pkg/core/hash_test.go b/pkg/core/hash_test.go index 76860069..3b6daead 100644 --- a/pkg/core/hash_test.go +++ b/pkg/core/hash_test.go @@ -17,10 +17,11 @@ limitations under the License. package core import ( - metricsserver "sigs.k8s.io/controller-runtime/pkg/metrics/server" "sync" "time" + metricsserver "sigs.k8s.io/controller-runtime/pkg/metrics/server" + . "github.com/onsi/ginkgo" . "github.com/onsi/gomega" "github.com/wave-k8s/wave/test/utils" @@ -97,7 +98,7 @@ var _ = Describe("Wave hash Suite", func() { ) }) - It("returns a different hash when an allKeys child's data is updated", func() { + It("returns a different hash when an allKeys child's configmap string data is updated", func() { c := []configObject{ {object: cm1, allKeys: true}, {object: cm2, allKeys: true}, @@ -120,7 +121,7 @@ var _ = Describe("Wave hash Suite", func() { Expect(h2).NotTo(Equal(h1)) }) - It("returns a different hash when an all-field child's data is updated", func() { + It("returns a different hash when an allKeys child's configmap binary data is updated", func() { c := []configObject{ {object: cm1, allKeys: true}, {object: cm2, allKeys: true}, @@ -133,7 +134,30 @@ var _ = Describe("Wave hash Suite", func() { m.Update(cm1, func(obj client.Object) client.Object { cm := obj.(*corev1.ConfigMap) - cm.Data["key1"] = modified + cm.BinaryData["binary_key1"] = []byte(modified) + + return cm + }, timeout).Should(Succeed()) + h2, err := calculateConfigHash(c) + Expect(err).NotTo(HaveOccurred()) + + Expect(h2).NotTo(Equal(h1)) + }) + + It("returns a different hash when an allKeys child's secret data is updated", func() { + c := []configObject{ + {object: cm1, allKeys: true}, + {object: cm2, allKeys: true}, + {object: s1, allKeys: true}, + {object: s2, allKeys: true}, + } + + h1, err := calculateConfigHash(c) + Expect(err).NotTo(HaveOccurred()) + + m.Update(s1, func(obj client.Object) client.Object { + cm := obj.(*corev1.Secret) + cm.Data["key1"] = []byte("modified") return cm }, timeout).Should(Succeed()) @@ -146,7 +170,8 @@ var _ = Describe("Wave hash Suite", func() { It("returns a different hash when a single-field child's data is updated", func() { c := []configObject{ {object: cm1, allKeys: false, keys: map[string]struct{}{ - "key1": {}, + "key1": {}, + "binary_key1": {}, }, }, {object: cm2, allKeys: true}, @@ -166,6 +191,17 @@ var _ = Describe("Wave hash Suite", func() { return cm }, timeout).Should(Succeed()) + h2, err := calculateConfigHash(c) + Expect(err).NotTo(HaveOccurred()) + + m.Update(cm1, func(obj client.Object) client.Object { + cm := obj.(*corev1.ConfigMap) + cm.BinaryData["binary_key1"] = []byte(modified) + + return cm + }, timeout).Should(Succeed()) + h3, err := calculateConfigHash(c) + Expect(err).NotTo(HaveOccurred()) m.Update(s1, func(obj client.Object) client.Object { s := obj.(*corev1.Secret) @@ -173,16 +209,22 @@ var _ = Describe("Wave hash Suite", func() { return s }, timeout).Should(Succeed()) - h2, err := calculateConfigHash(c) + h4, err := calculateConfigHash(c) Expect(err).NotTo(HaveOccurred()) Expect(h2).NotTo(Equal(h1)) + Expect(h3).NotTo(Equal(h1)) + Expect(h3).NotTo(Equal(h2)) + Expect(h4).NotTo(Equal(h1)) + Expect(h4).NotTo(Equal(h2)) + Expect(h4).NotTo(Equal(h3)) }) It("returns the same hash when a single-field child's data is updated but not for that field", func() { c := []configObject{ {object: cm1, allKeys: false, keys: map[string]struct{}{ - "key1": {}, + "key1": {}, + "binary_key1": {}, }, }, {object: cm2, allKeys: true}, @@ -199,6 +241,7 @@ var _ = Describe("Wave hash Suite", func() { m.Update(cm1, func(obj client.Object) client.Object { cm := obj.(*corev1.ConfigMap) cm.Data["key3"] = modified + cm.BinaryData["binary_key3"] = []byte("modified") return cm }, timeout).Should(Succeed()) diff --git a/test/utils/test_objects.go b/test/utils/test_objects.go index 2737c254..bef03127 100644 --- a/test/utils/test_objects.go +++ b/test/utils/test_objects.go @@ -736,6 +736,11 @@ var ExampleConfigMap1 = &corev1.ConfigMap{ "key2": "example1:key2", "key3": "example1:key3", }, + BinaryData: map[string][]byte{ + "binary_key1": []byte("example1:binary_key1"), + "binary_key2": []byte("example1:binary_key2"), + "binary_key3": []byte("example1:binary_key3"), + }, } // ExampleConfigMap2 is an example ConfigMap object for use within test suites From 6e1a1af48c5db7c7d0908caffd8c8b894477fc40 Mon Sep 17 00:00:00 2001 From: Jan Kantert Date: Sat, 27 Apr 2024 21:21:37 +0200 Subject: [PATCH 2/2] handle secrets and configmaps in volume projections --- .../deployment/deployment_controller_test.go | 26 +++- pkg/core/children.go | 27 ++++ pkg/core/children_test.go | 84 +++++++++-- pkg/core/handler_test.go | 26 +++- test/utils/test_objects.go | 134 ++++++++++++++++++ 5 files changed, 280 insertions(+), 17 deletions(-) diff --git a/pkg/controller/deployment/deployment_controller_test.go b/pkg/controller/deployment/deployment_controller_test.go index 36bd0b51..8d4dbea3 100644 --- a/pkg/controller/deployment/deployment_controller_test.go +++ b/pkg/controller/deployment/deployment_controller_test.go @@ -54,9 +54,15 @@ var _ = Describe("Deployment controller Suite", func() { var cm1 *corev1.ConfigMap var cm2 *corev1.ConfigMap var cm3 *corev1.ConfigMap + var cm4 *corev1.ConfigMap + var cm5 *corev1.ConfigMap + var cm6 *corev1.ConfigMap var s1 *corev1.Secret var s2 *corev1.Secret var s3 *corev1.Secret + var s4 *corev1.Secret + var s5 *corev1.Secret + var s6 *corev1.Secret const modified = "modified" @@ -97,22 +103,40 @@ var _ = Describe("Deployment controller Suite", func() { cm1 = utils.ExampleConfigMap1.DeepCopy() cm2 = utils.ExampleConfigMap2.DeepCopy() cm3 = utils.ExampleConfigMap3.DeepCopy() + cm4 = utils.ExampleConfigMap4.DeepCopy() + cm5 = utils.ExampleConfigMap5.DeepCopy() + cm6 = utils.ExampleConfigMap6.DeepCopy() s1 = utils.ExampleSecret1.DeepCopy() s2 = utils.ExampleSecret2.DeepCopy() s3 = utils.ExampleSecret3.DeepCopy() + s4 = utils.ExampleSecret4.DeepCopy() + s5 = utils.ExampleSecret5.DeepCopy() + s6 = utils.ExampleSecret6.DeepCopy() m.Create(cm1).Should(Succeed()) m.Create(cm2).Should(Succeed()) m.Create(cm3).Should(Succeed()) + m.Create(cm4).Should(Succeed()) + m.Create(cm5).Should(Succeed()) + m.Create(cm6).Should(Succeed()) m.Create(s1).Should(Succeed()) m.Create(s2).Should(Succeed()) m.Create(s3).Should(Succeed()) + m.Create(s4).Should(Succeed()) + m.Create(s5).Should(Succeed()) + m.Create(s6).Should(Succeed()) m.Get(cm1, timeout).Should(Succeed()) m.Get(cm2, timeout).Should(Succeed()) m.Get(cm3, timeout).Should(Succeed()) + m.Get(cm4, timeout).Should(Succeed()) + m.Get(cm5, timeout).Should(Succeed()) + m.Get(cm6, timeout).Should(Succeed()) m.Get(s1, timeout).Should(Succeed()) m.Get(s2, timeout).Should(Succeed()) m.Get(s3, timeout).Should(Succeed()) + m.Get(s4, timeout).Should(Succeed()) + m.Get(s5, timeout).Should(Succeed()) + m.Get(s6, timeout).Should(Succeed()) deployment = utils.ExampleDeployment.DeepCopy() @@ -204,7 +228,7 @@ var _ = Describe("Deployment controller Suite", func() { eventMessage := func(event *corev1.Event) string { return event.Message } - hashMessage := "Configuration hash updated to bd786f47ef9b79841ddba1059752f95c4fe21906df5e2964786b4658e02758d5" + hashMessage := "Configuration hash updated to 421778c325761f51dbf7a23a20eb9c1bc516ffd4aa7362ebec03175d427d7557" Eventually(func() *corev1.EventList { events := &corev1.EventList{} m.Client.List(context.TODO(), events) diff --git a/pkg/core/children.go b/pkg/core/children.go index a0dfcc87..9b109979 100644 --- a/pkg/core/children.go +++ b/pkg/core/children.go @@ -110,6 +110,33 @@ func getChildNamesByType(obj podController) (map[string]configMetadata, map[stri if s := vol.VolumeSource.Secret; s != nil { secrets[s.SecretName] = configMetadata{required: isRequired(s.Optional), allKeys: true} } + + if projection := vol.VolumeSource.Projected; projection != nil { + for _, source := range projection.Sources { + if cm := source.ConfigMap; cm != nil { + if cm.Items == nil { + configMaps[cm.Name] = configMetadata{required: isRequired(cm.Optional), allKeys: true} + } else { + keys := make(map[string]struct{}) + for _, item := range cm.Items { + keys[item.Key] = struct{}{} + } + configMaps[cm.Name] = configMetadata{required: isRequired(cm.Optional), allKeys: false, keys: keys} + } + } + if s := source.Secret; s != nil { + if s.Items == nil { + secrets[s.Name] = configMetadata{required: isRequired(s.Optional), allKeys: true} + } else { + keys := make(map[string]struct{}) + for _, item := range s.Items { + keys[item.Key] = struct{}{} + } + secrets[s.Name] = configMetadata{required: isRequired(s.Optional), allKeys: false, keys: keys} + } + } + } + } } // Range through all Containers and their respective EnvFrom, diff --git a/pkg/core/children_test.go b/pkg/core/children_test.go index e73f4d20..7672ea2c 100644 --- a/pkg/core/children_test.go +++ b/pkg/core/children_test.go @@ -17,10 +17,11 @@ limitations under the License. package core import ( - metricsserver "sigs.k8s.io/controller-runtime/pkg/metrics/server" "sync" "time" + metricsserver "sigs.k8s.io/controller-runtime/pkg/metrics/server" + . "github.com/onsi/ginkgo" . "github.com/onsi/gomega" "github.com/wave-k8s/wave/test/utils" @@ -38,7 +39,6 @@ var _ = Describe("Wave children Suite", func() { var m utils.Matcher var deploymentObject *appsv1.Deployment var podControllerDeployment podController - var existingChildren []Object var currentChildren []configObject var mgrStopped *sync.WaitGroup var stopMgr chan struct{} @@ -49,10 +49,14 @@ var _ = Describe("Wave children Suite", func() { var cm2 *corev1.ConfigMap var cm3 *corev1.ConfigMap var cm4 *corev1.ConfigMap + var cm5 *corev1.ConfigMap + var cm6 *corev1.ConfigMap var s1 *corev1.Secret var s2 *corev1.Secret var s3 *corev1.Secret var s4 *corev1.Secret + var s5 *corev1.Secret + var s6 *corev1.Secret BeforeEach(func() { mgr, err := manager.New(cfg, manager.Options{ @@ -75,19 +79,27 @@ var _ = Describe("Wave children Suite", func() { cm2 = utils.ExampleConfigMap2.DeepCopy() cm3 = utils.ExampleConfigMap3.DeepCopy() cm4 = utils.ExampleConfigMap4.DeepCopy() + cm5 = utils.ExampleConfigMap5.DeepCopy() + cm6 = utils.ExampleConfigMap6.DeepCopy() s1 = utils.ExampleSecret1.DeepCopy() s2 = utils.ExampleSecret2.DeepCopy() s3 = utils.ExampleSecret3.DeepCopy() s4 = utils.ExampleSecret4.DeepCopy() + s5 = utils.ExampleSecret5.DeepCopy() + s6 = utils.ExampleSecret6.DeepCopy() m.Create(cm1).Should(Succeed()) m.Create(cm2).Should(Succeed()) m.Create(cm3).Should(Succeed()) m.Create(cm4).Should(Succeed()) + m.Create(cm5).Should(Succeed()) + m.Create(cm6).Should(Succeed()) m.Create(s1).Should(Succeed()) m.Create(s2).Should(Succeed()) m.Create(s3).Should(Succeed()) m.Create(s4).Should(Succeed()) + m.Create(s5).Should(Succeed()) + m.Create(s6).Should(Succeed()) deploymentObject = utils.ExampleDeployment.DeepCopy() podControllerDeployment = &deployment{deploymentObject} @@ -101,10 +113,14 @@ var _ = Describe("Wave children Suite", func() { m.Get(cm2, timeout).Should(Succeed()) m.Get(cm3, timeout).Should(Succeed()) m.Get(cm4, timeout).Should(Succeed()) + m.Get(cm5, timeout).Should(Succeed()) + m.Get(cm6, timeout).Should(Succeed()) m.Get(s1, timeout).Should(Succeed()) m.Get(s2, timeout).Should(Succeed()) m.Get(s3, timeout).Should(Succeed()) m.Get(s4, timeout).Should(Succeed()) + m.Get(s5, timeout).Should(Succeed()) + m.Get(s6, timeout).Should(Succeed()) m.Get(deploymentObject, timeout).Should(Succeed()) }) @@ -134,6 +150,23 @@ var _ = Describe("Wave children Suite", func() { })) }) + It("returns ConfigMaps referenced in Volume Projections", func() { + Expect(currentChildren).To(ContainElement(configObject{ + object: cm6, + required: true, + allKeys: false, + keys: map[string]struct{}{ + "example6_key1": {}, + "example6_key3": {}, + }, + })) + Expect(currentChildren).To(ContainElement(configObject{ + object: cm5, + required: false, + allKeys: true, + })) + }) + It("returns ConfigMaps referenced in EnvFrom", func() { Expect(currentChildren).To(ContainElement(configObject{ object: cm2, @@ -171,6 +204,23 @@ var _ = Describe("Wave children Suite", func() { })) }) + It("returns Secrets referenced in Volume Projections", func() { + Expect(currentChildren).To(ContainElement(configObject{ + object: s6, + required: true, + allKeys: false, + keys: map[string]struct{}{ + "example6_key1": {}, + "example6_key3": {}, + }, + })) + Expect(currentChildren).To(ContainElement(configObject{ + object: s5, + required: false, + allKeys: true, + })) + }) + It("returns Secrets referenced in EnvFrom", func() { Expect(currentChildren).To(ContainElement(configObject{ object: s2, @@ -201,7 +251,7 @@ var _ = Describe("Wave children Suite", func() { }) It("does not return duplicate children", func() { - Expect(currentChildren).To(HaveLen(8)) + Expect(currentChildren).To(HaveLen(12)) }) It("returns an error if one of the referenced children is missing", func() { @@ -300,8 +350,8 @@ var _ = Describe("Wave children Suite", func() { }) It("does not return extra children", func() { - Expect(configMaps).To(HaveLen(7)) - Expect(secrets).To(HaveLen(7)) + Expect(configMaps).To(HaveLen(9)) + Expect(secrets).To(HaveLen(9)) }) }) @@ -319,32 +369,36 @@ var _ = Describe("Wave children Suite", func() { } var err error - existingChildren, err = h.getExistingChildren(podControllerDeployment) + _, err = h.getExistingChildren(podControllerDeployment) Expect(err).NotTo(HaveOccurred()) }) + existingChildrenFn := func() ([]Object, error) { + return h.getExistingChildren(podControllerDeployment) + } + It("returns ConfigMaps with the correct OwnerReference", func() { - Expect(existingChildren).To(ContainElement(cm1)) + Eventually(existingChildrenFn).Should(ContainElement(cm1)) }) It("doesn't return ConfigMaps without OwnerReferences", func() { - Expect(existingChildren).NotTo(ContainElement(cm2)) - Expect(existingChildren).NotTo(ContainElement(cm3)) - Expect(existingChildren).NotTo(ContainElement(cm4)) + Eventually(existingChildrenFn).ShouldNot(ContainElement(cm2)) + Eventually(existingChildrenFn).ShouldNot(ContainElement(cm3)) + Eventually(existingChildrenFn).ShouldNot(ContainElement(cm4)) }) It("returns Secrets with the correct OwnerReference", func() { - Expect(existingChildren).To(ContainElement(s1)) + Eventually(existingChildrenFn).Should(ContainElement(s1)) }) It("doesn't return Secrets without OwnerReferences", func() { - Expect(existingChildren).NotTo(ContainElement(s2)) - Expect(existingChildren).NotTo(ContainElement(s3)) - Expect(existingChildren).NotTo(ContainElement(s4)) + Eventually(existingChildrenFn).ShouldNot(ContainElement(s2)) + Eventually(existingChildrenFn).ShouldNot(ContainElement(s3)) + Eventually(existingChildrenFn).ShouldNot(ContainElement(s4)) }) It("does not return duplicate children", func() { - Expect(existingChildren).To(HaveLen(2)) + Eventually(existingChildrenFn).Should(HaveLen(2)) }) }) diff --git a/pkg/core/handler_test.go b/pkg/core/handler_test.go index b59ae8bf..b7c40718 100644 --- a/pkg/core/handler_test.go +++ b/pkg/core/handler_test.go @@ -53,9 +53,15 @@ var _ = Describe("Wave controller Suite", func() { var cm1 *corev1.ConfigMap var cm2 *corev1.ConfigMap var cm3 *corev1.ConfigMap + var cm4 *corev1.ConfigMap + var cm5 *corev1.ConfigMap + var cm6 *corev1.ConfigMap var s1 *corev1.Secret var s2 *corev1.Secret var s3 *corev1.Secret + var s4 *corev1.Secret + var s5 *corev1.Secret + var s6 *corev1.Secret var modified = "modified" @@ -79,22 +85,40 @@ var _ = Describe("Wave controller Suite", func() { cm1 = utils.ExampleConfigMap1.DeepCopy() cm2 = utils.ExampleConfigMap2.DeepCopy() cm3 = utils.ExampleConfigMap3.DeepCopy() + cm4 = utils.ExampleConfigMap4.DeepCopy() + cm5 = utils.ExampleConfigMap5.DeepCopy() + cm6 = utils.ExampleConfigMap6.DeepCopy() s1 = utils.ExampleSecret1.DeepCopy() s2 = utils.ExampleSecret2.DeepCopy() s3 = utils.ExampleSecret3.DeepCopy() + s4 = utils.ExampleSecret4.DeepCopy() + s5 = utils.ExampleSecret5.DeepCopy() + s6 = utils.ExampleSecret6.DeepCopy() m.Create(cm1).Should(Succeed()) m.Create(cm2).Should(Succeed()) m.Create(cm3).Should(Succeed()) + m.Create(cm4).Should(Succeed()) + m.Create(cm5).Should(Succeed()) + m.Create(cm6).Should(Succeed()) m.Create(s1).Should(Succeed()) m.Create(s2).Should(Succeed()) m.Create(s3).Should(Succeed()) + m.Create(s4).Should(Succeed()) + m.Create(s5).Should(Succeed()) + m.Create(s6).Should(Succeed()) m.Get(cm1, timeout).Should(Succeed()) m.Get(cm2, timeout).Should(Succeed()) m.Get(cm3, timeout).Should(Succeed()) + m.Get(cm4, timeout).Should(Succeed()) + m.Get(cm5, timeout).Should(Succeed()) + m.Get(cm6, timeout).Should(Succeed()) m.Get(s1, timeout).Should(Succeed()) m.Get(s2, timeout).Should(Succeed()) m.Get(s3, timeout).Should(Succeed()) + m.Get(s4, timeout).Should(Succeed()) + m.Get(s5, timeout).Should(Succeed()) + m.Get(s6, timeout).Should(Succeed()) deployment = utils.ExampleDeployment.DeepCopy() @@ -194,7 +218,7 @@ var _ = Describe("Wave controller Suite", func() { eventMessage := func(event *corev1.Event) string { return event.Message } - hashMessage := "Configuration hash updated to bd786f47ef9b79841ddba1059752f95c4fe21906df5e2964786b4658e02758d5" + hashMessage := "Configuration hash updated to 421778c325761f51dbf7a23a20eb9c1bc516ffd4aa7362ebec03175d427d7557" Eventually(func() *corev1.EventList { events := &corev1.EventList{} m.Client.List(context.TODO(), events) diff --git a/test/utils/test_objects.go b/test/utils/test_objects.go index bef03127..61e0b1df 100644 --- a/test/utils/test_objects.go +++ b/test/utils/test_objects.go @@ -83,6 +83,84 @@ var ExampleDeployment = &appsv1.Deployment{ }, }, }, + { + Name: "projection1", + VolumeSource: corev1.VolumeSource{ + Projected: &corev1.ProjectedVolumeSource{ + Sources: []corev1.VolumeProjection{{ + Secret: &corev1.SecretProjection{ + LocalObjectReference: corev1.LocalObjectReference{ + Name: "example5", + }, + Optional: &trueValue, + }, + }}, + }, + }, + }, + { + Name: "projection2", + VolumeSource: corev1.VolumeSource{ + Projected: &corev1.ProjectedVolumeSource{ + Sources: []corev1.VolumeProjection{{ + ConfigMap: &corev1.ConfigMapProjection{ + LocalObjectReference: corev1.LocalObjectReference{ + Name: "example5", + }, + Optional: &trueValue, + }, + }}, + }, + }, + }, + { + Name: "projection3", + VolumeSource: corev1.VolumeSource{ + Projected: &corev1.ProjectedVolumeSource{ + Sources: []corev1.VolumeProjection{{ + Secret: &corev1.SecretProjection{ + LocalObjectReference: corev1.LocalObjectReference{ + Name: "example6", + }, + Items: []corev1.KeyToPath{ + { + Key: "example6_key1", + Path: "example6_key1.txt", + }, + { + Key: "example6_key3", + Path: "example6_key3.txt", + }, + }, + }, + }}, + }, + }, + }, + { + Name: "projection4", + VolumeSource: corev1.VolumeSource{ + Projected: &corev1.ProjectedVolumeSource{ + Sources: []corev1.VolumeProjection{{ + ConfigMap: &corev1.ConfigMapProjection{ + LocalObjectReference: corev1.LocalObjectReference{ + Name: "example6", + }, + Items: []corev1.KeyToPath{ + { + Key: "example6_key1", + Path: "example6_key1.txt", + }, + { + Key: "example6_key3", + Path: "example6_key3.txt", + }, + }, + }, + }}, + }, + }, + }, }, Containers: []corev1.Container{ { @@ -785,6 +863,34 @@ var ExampleConfigMap4 = &corev1.ConfigMap{ }, } +// ExampleConfigMap5 is an example ConfigMap object for use within test suites +var ExampleConfigMap5 = &corev1.ConfigMap{ + ObjectMeta: metav1.ObjectMeta{ + Name: "example5", + Namespace: "default", + Labels: labels, + }, + Data: map[string]string{ + "key1": "example5:key1", + "key2": "example5:key2", + "key3": "example5:key3", + }, +} + +// ExampleConfigMap6 is an example ConfigMap object for use within test suites +var ExampleConfigMap6 = &corev1.ConfigMap{ + ObjectMeta: metav1.ObjectMeta{ + Name: "example6", + Namespace: "default", + Labels: labels, + }, + Data: map[string]string{ + "key1": "example6:key1", + "key2": "example6:key2", + "key3": "example6:key3", + }, +} + // ExampleSecret1 is an example Secret object for use within test suites var ExampleSecret1 = &corev1.Secret{ ObjectMeta: metav1.ObjectMeta{ @@ -840,3 +946,31 @@ var ExampleSecret4 = &corev1.Secret{ "key3": "example4:key3", }, } + +// ExampleSecret5 is an example Secret object for use within test suites +var ExampleSecret5 = &corev1.Secret{ + ObjectMeta: metav1.ObjectMeta{ + Name: "example5", + Namespace: "default", + Labels: labels, + }, + StringData: map[string]string{ + "key1": "example5:key1", + "key2": "example5:key2", + "key3": "example5:key3", + }, +} + +// ExampleSecret6 is an example Secret object for use within test suites +var ExampleSecret6 = &corev1.Secret{ + ObjectMeta: metav1.ObjectMeta{ + Name: "example6", + Namespace: "default", + Labels: labels, + }, + StringData: map[string]string{ + "key1": "example6:key1", + "key2": "example6:key2", + "key3": "example6:key3", + }, +}