From 9e194abaff9407b9124b17cf3319ee0381af9691 Mon Sep 17 00:00:00 2001 From: Guilherme Vicentin <79584418+gvicentin@users.noreply.github.com> Date: Tue, 11 Jun 2024 10:38:36 -0300 Subject: [PATCH] fix: unset metadatada validate reserved keys (#154) --- internal/pkg/rpaas/metadata.go | 9 +++++++++ internal/pkg/rpaas/metadata_test.go | 26 ++++++++++++++++++++++---- 2 files changed, 31 insertions(+), 4 deletions(-) diff --git a/internal/pkg/rpaas/metadata.go b/internal/pkg/rpaas/metadata.go index 781e7874..d94d602c 100644 --- a/internal/pkg/rpaas/metadata.go +++ b/internal/pkg/rpaas/metadata.go @@ -112,6 +112,15 @@ func (m *k8sRpaasManager) UnsetMetadata(ctx context.Context, instanceName string if err != nil { return err } + + if err = validateMetadata(metadata.Labels); err != nil { + return err + } + + if err = validateMetadata(metadata.Annotations); err != nil { + return err + } + originalInstance := instance.DeepCopy() if metadata.Labels != nil { diff --git a/internal/pkg/rpaas/metadata_test.go b/internal/pkg/rpaas/metadata_test.go index 4876ea96..6967048f 100644 --- a/internal/pkg/rpaas/metadata_test.go +++ b/internal/pkg/rpaas/metadata_test.go @@ -155,7 +155,7 @@ func Test_k8sRpaasManager_UnsetMetadata(t *testing.T) { }, }, { - name: "unset invalid label", + name: "unset label that doesn't exist", objMeta: metav1.ObjectMeta{ Name: "my-instance", Namespace: "rpaasv2", @@ -170,21 +170,39 @@ func Test_k8sRpaasManager_UnsetMetadata(t *testing.T) { }, expectedErr: "label \"invalid-label\" not found in instance \"my-instance\"", }, + { + name: "unset invalid label", + objMeta: metav1.ObjectMeta{ + Name: "my-instance", + Namespace: "rpaasv2", + Labels: map[string]string{ + "rpaas_instance": "my-instance", + "rpaas_service": "my-service", + }, + }, + meta: clientTypes.Metadata{ + Labels: []clientTypes.MetadataItem{ + {Name: "rpaas_instance"}, + }, + }, + expectedErr: "metadata key \"rpaas_instance\" is reserved", + }, { name: "unset invalid annotation", objMeta: metav1.ObjectMeta{ Name: "my-instance", Namespace: "rpaasv2", Annotations: map[string]string{ - "my-annotation": "my-annotation-value", + "my-annotation": "my-annotation-value", + "rpaas.extensions.tsuru.io/tags": "my-tag=my-value", }, }, meta: clientTypes.Metadata{ Annotations: []clientTypes.MetadataItem{ - {Name: "invalid-annotation"}, + {Name: "rpaas.extensions.tsuru.io/tags"}, }, }, - expectedErr: "annotation \"invalid-annotation\" not found in instance \"my-instance\"", + expectedErr: "metadata key \"rpaas.extensions.tsuru.io/tags\" is reserved", }, }