From 5f23d35c6b1e3a7ce94caf459295c50ebaed9ce1 Mon Sep 17 00:00:00 2001 From: Humair Khan Date: Fri, 18 Oct 2024 14:40:37 -0400 Subject: [PATCH] Set dsp-version label on managed resources This change makes it so that new reconciles on dspa owned resources are labelled with a dsp-version= label. This is to allow for the dspa selectively watch (for manual WatchesRawSources) on resources that are descendents of DSPAs with .spec.dspVersion set to supported versions. Signed-off-by: Humair Khan --- ...b.io_datasciencepipelinesapplications.yaml | 2 +- controllers/config/defaults.go | 13 +++- controllers/dspipeline_controller.go | 46 +++++++++---- .../created/apiserver_deployment.yaml | 2 + .../created/configmap_server_config.yaml | 1 + .../expected/created/mariadb_deployment.yaml | 2 + .../created/persistence-agent_deployment.yaml | 2 + .../scheduled-workflow_deployment.yaml | 2 + .../created/apiserver_deployment.yaml | 2 + .../expected/created/mariadb_deployment.yaml | 2 + .../expected/created/minio_deployment.yaml | 2 + .../created/mlmd_envoy_deployment.yaml | 2 + .../created/mlmd_grpc_deployment.yaml | 2 + .../created/mlpipelines-ui_deployment.yaml | 2 + .../created/persistence-agent_deployment.yaml | 2 + .../expected/created/sample-config.yaml.tmpl | 1 + .../scheduled-workflow_deployment.yaml | 2 + .../created/apiserver_deployment.yaml | 2 + .../created/apiserver_deployment.yaml | 2 + .../expected/created/mariadb_deployment.yaml | 2 + .../expected/created/minio_deployment.yaml | 2 + .../created/mlmd_envoy_deployment.yaml | 2 + .../created/mlmd_grpc_deployment.yaml | 2 + .../created/mlpipelines-ui_deployment.yaml | 2 + .../created/persistence-agent_deployment.yaml | 2 + .../scheduled-workflow_deployment.yaml | 2 + .../created/apiserver_deployment.yaml | 2 + .../created/configmap_dspa_trusted_ca.yaml | 2 + .../expected/created/mariadb_deployment.yaml | 2 + .../created/apiserver_deployment.yaml | 2 + .../created/mlpipelines-ui_deployment.yaml | 2 + .../created/persistence-agent_deployment.yaml | 2 + controllers/util/util.go | 69 +++++++++++++++++++ 33 files changed, 168 insertions(+), 18 deletions(-) diff --git a/config/crd/bases/datasciencepipelinesapplications.opendatahub.io_datasciencepipelinesapplications.yaml b/config/crd/bases/datasciencepipelinesapplications.opendatahub.io_datasciencepipelinesapplications.yaml index 8eea820ea..380aaeb5c 100644 --- a/config/crd/bases/datasciencepipelinesapplications.opendatahub.io_datasciencepipelinesapplications.yaml +++ b/config/crd/bases/datasciencepipelinesapplications.opendatahub.io_datasciencepipelinesapplications.yaml @@ -859,7 +859,7 @@ spec: status: {} - deprecated: true deprecationWarning: datasciencepipelinesapplications.opendatahub.io/v1alpha1 is - deprecated + deprecated. name: v1alpha1 schema: openAPIV3Schema: diff --git a/controllers/config/defaults.go b/controllers/config/defaults.go index 728daa57a..63c92bc58 100644 --- a/controllers/config/defaults.go +++ b/controllers/config/defaults.go @@ -27,10 +27,13 @@ import ( "k8s.io/apimachinery/pkg/api/resource" ) +const DSPV2VersionString = "v2" +const DSPVersionk8sLabel = "dsp-version" + +var SupportedDSPVersions = []string{DSPV2VersionString} + const ( - DSPDefaultVersion = "v2" - DSPV2VersionString = DSPDefaultVersion - DefaultImageValue = "MustSetInConfig" + DefaultImageValue = "MustSetInConfig" CustomCABundleRootMountPath = "/dsp-custom-certs" @@ -222,3 +225,7 @@ func GetDefaultDBExtraParams(params DBExtraParams, log logr.Logger) (string, err } return string(extraParamsJson), nil } + +func GetSupportedDSPAVersions() []string { + return SupportedDSPVersions +} diff --git a/controllers/dspipeline_controller.go b/controllers/dspipeline_controller.go index 16cf8252c..c972705aa 100644 --- a/controllers/dspipeline_controller.go +++ b/controllers/dspipeline_controller.go @@ -19,7 +19,6 @@ package controllers import ( "context" "fmt" - "github.com/opendatahub-io/data-science-pipelines-operator/controllers/dspastatus" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "sigs.k8s.io/controller-runtime/pkg/controller" @@ -82,18 +81,25 @@ func (r *DSPAReconciler) Apply(owner mf.Owner, params *DSPAParams, template stri if err != nil { return fmt.Errorf("error loading template (%s) yaml: %w", template, err) } + + // Apply the owner injection transformation tmplManifest, err = tmplManifest.Transform( mf.InjectOwner(owner), + // Apply dsp-version= label on all resources managed by this dspo + util.AddLabelTransformer(config.DSPVersionk8sLabel, params.DSPVersion), + util.AddDeploymentPodLabelTransformer(config.DSPVersionk8sLabel, params.DSPVersion), ) if err != nil { return err } + // Apply dsp-version labels to all manifests tmplManifest, err = tmplManifest.Transform(fns...) if err != nil { return err } + // Apply the manifest return tmplManifest.Apply() } @@ -188,7 +194,7 @@ func (r *DSPAReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl. defer r.updateStatus(ctx, dspa, dspaStatus, log, req) - if dspa.Spec.DSPVersion != config.DSPV2VersionString { + if !util.DSPAWithSupportedDSPVersion(dspa) { err1 := fmt.Errorf("unsupported DSP version %s detected. Please manually remove "+ "this DSP resource and re-apply with a supported version field set", dspa.Spec.DSPVersion) dspaStatus.SetDatabaseNotReady(err1, config.UnsupportedVersion) @@ -594,7 +600,6 @@ func (r *DSPAReconciler) SetupWithManager(mgr ctrl.Manager) error { // Watch for global ca bundle, if one is added to this namespace // we need to reconcile on all the dspa's in this namespace // so they may mount this cert in the appropriate containers - WatchesRawSource(source.Kind(mgr.GetCache(), &corev1.ConfigMap{}), handler.EnqueueRequestsFromMapFunc(func(ctx context.Context, o client.Object) []reconcile.Request { cm := o.(*corev1.ConfigMap) @@ -605,8 +610,6 @@ func (r *DSPAReconciler) SetupWithManager(mgr ctrl.Manager) error { return nil } - log.V(1).Info(fmt.Sprintf("Reconcile event triggered by change in event on Global CA Bundle: %s", cm.Name)) - var dspaList dspav1.DataSciencePipelinesApplicationList if err := r.List(ctx, &dspaList, client.InNamespace(thisNamespace)); err != nil { log.Error(err, "unable to list DSPA's when attempting to handle Global CA Bundle event.") @@ -615,11 +618,18 @@ func (r *DSPAReconciler) SetupWithManager(mgr ctrl.Manager) error { var reconcileRequests []reconcile.Request for _, dspa := range dspaList.Items { - namespacedName := types.NamespacedName{ - Name: dspa.Name, - Namespace: thisNamespace, + // Only update supported DSP versions + if util.DSPAWithSupportedDSPVersion(&dspa) { + namespacedName := types.NamespacedName{ + Name: dspa.Name, + Namespace: thisNamespace, + } + reconcileRequests = append(reconcileRequests, reconcile.Request{NamespacedName: namespacedName}) } - reconcileRequests = append(reconcileRequests, reconcile.Request{NamespacedName: namespacedName}) + } + + if len(reconcileRequests) > 0 { + log.V(1).Info(fmt.Sprintf("Reconcile event triggered by change in event on Global CA Bundle: %s", cm.Name)) } return reconcileRequests @@ -635,6 +645,12 @@ func (r *DSPAReconciler) SetupWithManager(mgr ctrl.Manager) error { return nil } + // Silently skip reconcile on this pod if the resource was owned + // by an unsupported dspa + if !util.HasSupportedDSPVersionLabel(pod.Labels) { + return nil + } + dspaName, hasDSPALabel := pod.Labels["dspa"] if !hasDSPALabel { msg := fmt.Sprintf("Pod with data-science-pipelines label encountered, but is missing dspa "+ @@ -659,9 +675,6 @@ func (r *DSPAReconciler) SetupWithManager(mgr ctrl.Manager) error { if secret.Annotations["openshift.io/owning-component"] != "service-ca" { return nil } - - log.V(1).Info(fmt.Sprintf("Reconcile event triggered by change on Secret owned by service-ca: %s", secret.Name)) - serviceName := secret.Annotations["service.beta.openshift.io/originating-service-name"] namespacedServiceName := types.NamespacedName{ @@ -675,17 +688,22 @@ func (r *DSPAReconciler) SetupWithManager(mgr ctrl.Manager) error { if err != nil { return nil } - dspaName, hasDSPALabel := service.Labels["dspa"] if !hasDSPALabel { return nil } - log.V(1).Info(fmt.Sprintf("Reconcile event triggered by [Service: %s] ", serviceName)) + // Silently skip reconcile on this ervice if the resource was owned + // by an unsupported DSPA + if !util.HasSupportedDSPVersionLabel(service.Labels) { + return nil + } + namespacedDspaName := types.NamespacedName{ Name: dspaName, Namespace: secret.Namespace, } + log.V(1).Info(fmt.Sprintf("Reconcile event triggered by change on Secret: %s owned by service-ca: %s", secret.Name, serviceName)) return []reconcile.Request{{NamespacedName: namespacedDspaName}} }), ). diff --git a/controllers/testdata/declarative/case_0/expected/created/apiserver_deployment.yaml b/controllers/testdata/declarative/case_0/expected/created/apiserver_deployment.yaml index c6a01bf52..4a9529835 100644 --- a/controllers/testdata/declarative/case_0/expected/created/apiserver_deployment.yaml +++ b/controllers/testdata/declarative/case_0/expected/created/apiserver_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-testdsp0 namespace: default labels: + dsp-version: v2 app: ds-pipeline-testdsp0 component: data-science-pipelines dspa: testdsp0 @@ -16,6 +17,7 @@ spec: template: metadata: labels: + dsp-version: v2 app: ds-pipeline-testdsp0 component: data-science-pipelines dspa: testdsp0 diff --git a/controllers/testdata/declarative/case_0/expected/created/configmap_server_config.yaml b/controllers/testdata/declarative/case_0/expected/created/configmap_server_config.yaml index a8d8ad457..20b920a7c 100644 --- a/controllers/testdata/declarative/case_0/expected/created/configmap_server_config.yaml +++ b/controllers/testdata/declarative/case_0/expected/created/configmap_server_config.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-server-config-testdsp0 namespace: default labels: + dsp-version: v2 app: ds-pipeline-testdsp0 component: data-science-pipelines data: diff --git a/controllers/testdata/declarative/case_0/expected/created/mariadb_deployment.yaml b/controllers/testdata/declarative/case_0/expected/created/mariadb_deployment.yaml index 20aad1f79..3a2c4adf0 100644 --- a/controllers/testdata/declarative/case_0/expected/created/mariadb_deployment.yaml +++ b/controllers/testdata/declarative/case_0/expected/created/mariadb_deployment.yaml @@ -5,6 +5,7 @@ metadata: name: mariadb-testdsp0 namespace: default labels: + dsp-version: v2 app: mariadb-testdsp0 component: data-science-pipelines dspa: testdsp0 @@ -19,6 +20,7 @@ spec: template: metadata: labels: + dsp-version: v2 app: mariadb-testdsp0 component: data-science-pipelines dspa: testdsp0 diff --git a/controllers/testdata/declarative/case_0/expected/created/persistence-agent_deployment.yaml b/controllers/testdata/declarative/case_0/expected/created/persistence-agent_deployment.yaml index ed2a18971..d0029e971 100644 --- a/controllers/testdata/declarative/case_0/expected/created/persistence-agent_deployment.yaml +++ b/controllers/testdata/declarative/case_0/expected/created/persistence-agent_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-persistenceagent-testdsp0 namespace: default labels: + dsp-version: v2 app: ds-pipeline-persistenceagent-testdsp0 component: data-science-pipelines dspa: testdsp0 @@ -18,6 +19,7 @@ spec: annotations: cluster-autoscaler.kubernetes.io/safe-to-evict: "true" labels: + dsp-version: v2 app: ds-pipeline-persistenceagent-testdsp0 component: data-science-pipelines dspa: testdsp0 diff --git a/controllers/testdata/declarative/case_0/expected/created/scheduled-workflow_deployment.yaml b/controllers/testdata/declarative/case_0/expected/created/scheduled-workflow_deployment.yaml index 7ba917a40..9c476cf6a 100644 --- a/controllers/testdata/declarative/case_0/expected/created/scheduled-workflow_deployment.yaml +++ b/controllers/testdata/declarative/case_0/expected/created/scheduled-workflow_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-scheduledworkflow-testdsp0 namespace: default labels: + dsp-version: v2 app: ds-pipeline-scheduledworkflow-testdsp0 component: data-science-pipelines dspa: testdsp0 @@ -18,6 +19,7 @@ spec: annotations: cluster-autoscaler.kubernetes.io/safe-to-evict: "true" labels: + dsp-version: v2 app: ds-pipeline-scheduledworkflow-testdsp0 component: data-science-pipelines dspa: testdsp0 diff --git a/controllers/testdata/declarative/case_2/expected/created/apiserver_deployment.yaml b/controllers/testdata/declarative/case_2/expected/created/apiserver_deployment.yaml index 4a19db478..66c7e8332 100644 --- a/controllers/testdata/declarative/case_2/expected/created/apiserver_deployment.yaml +++ b/controllers/testdata/declarative/case_2/expected/created/apiserver_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-testdsp2 namespace: default labels: + dsp-version: v2 app: ds-pipeline-testdsp2 component: data-science-pipelines dspa: testdsp2 @@ -16,6 +17,7 @@ spec: template: metadata: labels: + dsp-version: v2 app: ds-pipeline-testdsp2 component: data-science-pipelines dspa: testdsp2 diff --git a/controllers/testdata/declarative/case_2/expected/created/mariadb_deployment.yaml b/controllers/testdata/declarative/case_2/expected/created/mariadb_deployment.yaml index d122f60d7..9d64497c4 100644 --- a/controllers/testdata/declarative/case_2/expected/created/mariadb_deployment.yaml +++ b/controllers/testdata/declarative/case_2/expected/created/mariadb_deployment.yaml @@ -5,6 +5,7 @@ metadata: name: mariadb-testdsp2 namespace: default labels: + dsp-version: v2 app: mariadb-testdsp2 component: data-science-pipelines dspa: testdsp2 @@ -19,6 +20,7 @@ spec: template: metadata: labels: + dsp-version: v2 app: mariadb-testdsp2 component: data-science-pipelines dspa: testdsp2 diff --git a/controllers/testdata/declarative/case_2/expected/created/minio_deployment.yaml b/controllers/testdata/declarative/case_2/expected/created/minio_deployment.yaml index c31501585..7387e0723 100644 --- a/controllers/testdata/declarative/case_2/expected/created/minio_deployment.yaml +++ b/controllers/testdata/declarative/case_2/expected/created/minio_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: minio-testdsp2 namespace: default labels: + dsp-version: v2 app: minio-testdsp2 component: data-science-pipelines dspa: testdsp2 @@ -18,6 +19,7 @@ spec: template: metadata: labels: + dsp-version: v2 app: minio-testdsp2 component: data-science-pipelines dspa: testdsp2 diff --git a/controllers/testdata/declarative/case_2/expected/created/mlmd_envoy_deployment.yaml b/controllers/testdata/declarative/case_2/expected/created/mlmd_envoy_deployment.yaml index da1263501..91040713f 100644 --- a/controllers/testdata/declarative/case_2/expected/created/mlmd_envoy_deployment.yaml +++ b/controllers/testdata/declarative/case_2/expected/created/mlmd_envoy_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-metadata-envoy-testdsp2 namespace: default labels: + dsp-version: v2 app: ds-pipeline-metadata-envoy-testdsp2 component: data-science-pipelines dspa: testdsp2 @@ -19,6 +20,7 @@ spec: annotations: sidecar.istio.io/inject: "false" labels: + dsp-version: v2 app: ds-pipeline-metadata-envoy-testdsp2 component: data-science-pipelines dspa: testdsp2 diff --git a/controllers/testdata/declarative/case_2/expected/created/mlmd_grpc_deployment.yaml b/controllers/testdata/declarative/case_2/expected/created/mlmd_grpc_deployment.yaml index c7f1e9030..7b81e773b 100644 --- a/controllers/testdata/declarative/case_2/expected/created/mlmd_grpc_deployment.yaml +++ b/controllers/testdata/declarative/case_2/expected/created/mlmd_grpc_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-metadata-grpc-testdsp2 namespace: default labels: + dsp-version: v2 app: ds-pipeline-metadata-grpc-testdsp2 component: data-science-pipelines dspa: testdsp2 @@ -17,6 +18,7 @@ spec: template: metadata: labels: + dsp-version: v2 app: ds-pipeline-metadata-grpc-testdsp2 component: data-science-pipelines dspa: testdsp2 diff --git a/controllers/testdata/declarative/case_2/expected/created/mlpipelines-ui_deployment.yaml b/controllers/testdata/declarative/case_2/expected/created/mlpipelines-ui_deployment.yaml index 53b19793b..371484772 100644 --- a/controllers/testdata/declarative/case_2/expected/created/mlpipelines-ui_deployment.yaml +++ b/controllers/testdata/declarative/case_2/expected/created/mlpipelines-ui_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-ui-testdsp2 namespace: default labels: + dsp-version: v2 app: ds-pipeline-ui-testdsp2 component: data-science-pipelines dspa: testdsp2 @@ -18,6 +19,7 @@ spec: annotations: cluster-autoscaler.kubernetes.io/safe-to-evict: "true" labels: + dsp-version: v2 app: ds-pipeline-ui-testdsp2 component: data-science-pipelines dspa: testdsp2 diff --git a/controllers/testdata/declarative/case_2/expected/created/persistence-agent_deployment.yaml b/controllers/testdata/declarative/case_2/expected/created/persistence-agent_deployment.yaml index 67c750f31..500a95d5d 100644 --- a/controllers/testdata/declarative/case_2/expected/created/persistence-agent_deployment.yaml +++ b/controllers/testdata/declarative/case_2/expected/created/persistence-agent_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-persistenceagent-testdsp2 namespace: default labels: + dsp-version: v2 app: ds-pipeline-persistenceagent-testdsp2 component: data-science-pipelines dspa: testdsp2 @@ -18,6 +19,7 @@ spec: annotations: cluster-autoscaler.kubernetes.io/safe-to-evict: "true" labels: + dsp-version: v2 app: ds-pipeline-persistenceagent-testdsp2 component: data-science-pipelines dspa: testdsp2 diff --git a/controllers/testdata/declarative/case_2/expected/created/sample-config.yaml.tmpl b/controllers/testdata/declarative/case_2/expected/created/sample-config.yaml.tmpl index 99fa4fd11..aca6d21e4 100644 --- a/controllers/testdata/declarative/case_2/expected/created/sample-config.yaml.tmpl +++ b/controllers/testdata/declarative/case_2/expected/created/sample-config.yaml.tmpl @@ -4,6 +4,7 @@ metadata: name: sample-config-testdsp2 namespace: default labels: + dsp-version: v2 app: ds-pipeline-testdsp2 component: data-science-pipelines data: diff --git a/controllers/testdata/declarative/case_2/expected/created/scheduled-workflow_deployment.yaml b/controllers/testdata/declarative/case_2/expected/created/scheduled-workflow_deployment.yaml index 16d314888..b855c94d7 100644 --- a/controllers/testdata/declarative/case_2/expected/created/scheduled-workflow_deployment.yaml +++ b/controllers/testdata/declarative/case_2/expected/created/scheduled-workflow_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-scheduledworkflow-testdsp2 namespace: default labels: + dsp-version: v2 app: ds-pipeline-scheduledworkflow-testdsp2 component: data-science-pipelines dspa: testdsp2 @@ -18,6 +19,7 @@ spec: annotations: cluster-autoscaler.kubernetes.io/safe-to-evict: "true" labels: + dsp-version: v2 app: ds-pipeline-scheduledworkflow-testdsp2 component: data-science-pipelines dspa: testdsp2 diff --git a/controllers/testdata/declarative/case_3/expected/created/apiserver_deployment.yaml b/controllers/testdata/declarative/case_3/expected/created/apiserver_deployment.yaml index ab05ca095..8646f1eac 100644 --- a/controllers/testdata/declarative/case_3/expected/created/apiserver_deployment.yaml +++ b/controllers/testdata/declarative/case_3/expected/created/apiserver_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-testdsp3 namespace: default labels: + dsp-version: v2 app: ds-pipeline-testdsp3 component: data-science-pipelines dspa: testdsp3 @@ -16,6 +17,7 @@ spec: template: metadata: labels: + dsp-version: v2 app: ds-pipeline-testdsp3 component: data-science-pipelines dspa: testdsp3 diff --git a/controllers/testdata/declarative/case_4/expected/created/apiserver_deployment.yaml b/controllers/testdata/declarative/case_4/expected/created/apiserver_deployment.yaml index a8dea3141..b0474ff87 100644 --- a/controllers/testdata/declarative/case_4/expected/created/apiserver_deployment.yaml +++ b/controllers/testdata/declarative/case_4/expected/created/apiserver_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-testdsp4 namespace: default labels: + dsp-version: v2 app: ds-pipeline-testdsp4 component: data-science-pipelines dspa: testdsp4 @@ -16,6 +17,7 @@ spec: template: metadata: labels: + dsp-version: v2 app: ds-pipeline-testdsp4 component: data-science-pipelines dspa: testdsp4 diff --git a/controllers/testdata/declarative/case_4/expected/created/mariadb_deployment.yaml b/controllers/testdata/declarative/case_4/expected/created/mariadb_deployment.yaml index 3130c29a4..a88cf751a 100644 --- a/controllers/testdata/declarative/case_4/expected/created/mariadb_deployment.yaml +++ b/controllers/testdata/declarative/case_4/expected/created/mariadb_deployment.yaml @@ -5,6 +5,7 @@ metadata: name: mariadb-testdsp4 namespace: default labels: + dsp-version: v2 app: mariadb-testdsp4 component: data-science-pipelines dspa: testdsp4 @@ -19,6 +20,7 @@ spec: template: metadata: labels: + dsp-version: v2 app: mariadb-testdsp4 component: data-science-pipelines dspa: testdsp4 diff --git a/controllers/testdata/declarative/case_4/expected/created/minio_deployment.yaml b/controllers/testdata/declarative/case_4/expected/created/minio_deployment.yaml index 0ea9304b2..dddd17f63 100644 --- a/controllers/testdata/declarative/case_4/expected/created/minio_deployment.yaml +++ b/controllers/testdata/declarative/case_4/expected/created/minio_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: minio-testdsp4 namespace: default labels: + dsp-version: v2 app: minio-testdsp4 component: data-science-pipelines dspa: testdsp4 @@ -18,6 +19,7 @@ spec: template: metadata: labels: + dsp-version: v2 app: minio-testdsp4 component: data-science-pipelines dspa: testdsp4 diff --git a/controllers/testdata/declarative/case_4/expected/created/mlmd_envoy_deployment.yaml b/controllers/testdata/declarative/case_4/expected/created/mlmd_envoy_deployment.yaml index cdf98087c..0dc50500b 100644 --- a/controllers/testdata/declarative/case_4/expected/created/mlmd_envoy_deployment.yaml +++ b/controllers/testdata/declarative/case_4/expected/created/mlmd_envoy_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-metadata-envoy-testdsp4 namespace: default labels: + dsp-version: v2 app: ds-pipeline-metadata-envoy-testdsp4 component: data-science-pipelines dspa: testdsp4 @@ -19,6 +20,7 @@ spec: annotations: sidecar.istio.io/inject: "false" labels: + dsp-version: v2 app: ds-pipeline-metadata-envoy-testdsp4 component: data-science-pipelines dspa: testdsp4 diff --git a/controllers/testdata/declarative/case_4/expected/created/mlmd_grpc_deployment.yaml b/controllers/testdata/declarative/case_4/expected/created/mlmd_grpc_deployment.yaml index 136aa5541..f8c79bc8d 100644 --- a/controllers/testdata/declarative/case_4/expected/created/mlmd_grpc_deployment.yaml +++ b/controllers/testdata/declarative/case_4/expected/created/mlmd_grpc_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-metadata-grpc-testdsp4 namespace: default labels: + dsp-version: v2 app: ds-pipeline-metadata-grpc-testdsp4 component: data-science-pipelines dspa: testdsp4 @@ -17,6 +18,7 @@ spec: template: metadata: labels: + dsp-version: v2 app: ds-pipeline-metadata-grpc-testdsp4 component: data-science-pipelines dspa: testdsp4 diff --git a/controllers/testdata/declarative/case_4/expected/created/mlpipelines-ui_deployment.yaml b/controllers/testdata/declarative/case_4/expected/created/mlpipelines-ui_deployment.yaml index 62022305b..fbeb5e5fa 100644 --- a/controllers/testdata/declarative/case_4/expected/created/mlpipelines-ui_deployment.yaml +++ b/controllers/testdata/declarative/case_4/expected/created/mlpipelines-ui_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-ui-testdsp4 namespace: default labels: + dsp-version: v2 app: ds-pipeline-ui-testdsp4 component: data-science-pipelines dspa: testdsp4 @@ -18,6 +19,7 @@ spec: annotations: cluster-autoscaler.kubernetes.io/safe-to-evict: "true" labels: + dsp-version: v2 app: ds-pipeline-ui-testdsp4 component: data-science-pipelines dspa: testdsp4 diff --git a/controllers/testdata/declarative/case_4/expected/created/persistence-agent_deployment.yaml b/controllers/testdata/declarative/case_4/expected/created/persistence-agent_deployment.yaml index 3818ab387..f009d959c 100644 --- a/controllers/testdata/declarative/case_4/expected/created/persistence-agent_deployment.yaml +++ b/controllers/testdata/declarative/case_4/expected/created/persistence-agent_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-persistenceagent-testdsp4 namespace: default labels: + dsp-version: v2 app: ds-pipeline-persistenceagent-testdsp4 component: data-science-pipelines dspa: testdsp4 @@ -18,6 +19,7 @@ spec: annotations: cluster-autoscaler.kubernetes.io/safe-to-evict: "true" labels: + dsp-version: v2 app: ds-pipeline-persistenceagent-testdsp4 component: data-science-pipelines dspa: testdsp4 diff --git a/controllers/testdata/declarative/case_4/expected/created/scheduled-workflow_deployment.yaml b/controllers/testdata/declarative/case_4/expected/created/scheduled-workflow_deployment.yaml index e36acc69b..5f15836ed 100644 --- a/controllers/testdata/declarative/case_4/expected/created/scheduled-workflow_deployment.yaml +++ b/controllers/testdata/declarative/case_4/expected/created/scheduled-workflow_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-scheduledworkflow-testdsp4 namespace: default labels: + dsp-version: v2 app: ds-pipeline-scheduledworkflow-testdsp4 component: data-science-pipelines dspa: testdsp4 @@ -18,6 +19,7 @@ spec: annotations: cluster-autoscaler.kubernetes.io/safe-to-evict: "true" labels: + dsp-version: v2 app: ds-pipeline-scheduledworkflow-testdsp4 component: data-science-pipelines dspa: testdsp4 diff --git a/controllers/testdata/declarative/case_5/expected/created/apiserver_deployment.yaml b/controllers/testdata/declarative/case_5/expected/created/apiserver_deployment.yaml index c0b04ebbe..03a74eeba 100644 --- a/controllers/testdata/declarative/case_5/expected/created/apiserver_deployment.yaml +++ b/controllers/testdata/declarative/case_5/expected/created/apiserver_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-testdsp5 namespace: default labels: + dsp-version: v2 app: ds-pipeline-testdsp5 component: data-science-pipelines dspa: testdsp5 @@ -16,6 +17,7 @@ spec: template: metadata: labels: + dsp-version: v2 app: ds-pipeline-testdsp5 component: data-science-pipelines dspa: testdsp5 diff --git a/controllers/testdata/declarative/case_5/expected/created/configmap_dspa_trusted_ca.yaml b/controllers/testdata/declarative/case_5/expected/created/configmap_dspa_trusted_ca.yaml index 134b47fcf..c136947ab 100644 --- a/controllers/testdata/declarative/case_5/expected/created/configmap_dspa_trusted_ca.yaml +++ b/controllers/testdata/declarative/case_5/expected/created/configmap_dspa_trusted_ca.yaml @@ -2,6 +2,8 @@ kind: ConfigMap apiVersion: v1 metadata: name: dsp-trusted-ca-testdsp5 + labels: + dsp-version: v2 data: testcabundleconfigmapkey5.crt: |- -----BEGIN CERTIFICATE----- diff --git a/controllers/testdata/declarative/case_5/expected/created/mariadb_deployment.yaml b/controllers/testdata/declarative/case_5/expected/created/mariadb_deployment.yaml index 06777e778..de101cf63 100644 --- a/controllers/testdata/declarative/case_5/expected/created/mariadb_deployment.yaml +++ b/controllers/testdata/declarative/case_5/expected/created/mariadb_deployment.yaml @@ -5,6 +5,7 @@ metadata: name: mariadb-testdsp5 namespace: default labels: + dsp-version: v2 app: mariadb-testdsp5 component: data-science-pipelines dspa: testdsp5 @@ -19,6 +20,7 @@ spec: template: metadata: labels: + dsp-version: v2 app: mariadb-testdsp5 component: data-science-pipelines dspa: testdsp5 diff --git a/controllers/testdata/declarative/case_6/expected/created/apiserver_deployment.yaml b/controllers/testdata/declarative/case_6/expected/created/apiserver_deployment.yaml index e72cdfe17..f4809db80 100644 --- a/controllers/testdata/declarative/case_6/expected/created/apiserver_deployment.yaml +++ b/controllers/testdata/declarative/case_6/expected/created/apiserver_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-testdsp6 namespace: default labels: + dsp-version: v2 app: ds-pipeline-testdsp6 component: data-science-pipelines dspa: testdsp6 @@ -16,6 +17,7 @@ spec: template: metadata: labels: + dsp-version: v2 app: ds-pipeline-testdsp6 component: data-science-pipelines dspa: testdsp6 diff --git a/controllers/testdata/declarative/case_6/expected/created/mlpipelines-ui_deployment.yaml b/controllers/testdata/declarative/case_6/expected/created/mlpipelines-ui_deployment.yaml index cd41b1b67..5d9d2f248 100644 --- a/controllers/testdata/declarative/case_6/expected/created/mlpipelines-ui_deployment.yaml +++ b/controllers/testdata/declarative/case_6/expected/created/mlpipelines-ui_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-ui-testdsp6 namespace: default labels: + dsp-version: v2 app: ds-pipeline-ui-testdsp6 component: data-science-pipelines dspa: testdsp6 @@ -18,6 +19,7 @@ spec: annotations: cluster-autoscaler.kubernetes.io/safe-to-evict: "true" labels: + dsp-version: v2 app: ds-pipeline-ui-testdsp6 component: data-science-pipelines dspa: testdsp6 diff --git a/controllers/testdata/declarative/case_6/expected/created/persistence-agent_deployment.yaml b/controllers/testdata/declarative/case_6/expected/created/persistence-agent_deployment.yaml index f0d592c80..da50f82ff 100644 --- a/controllers/testdata/declarative/case_6/expected/created/persistence-agent_deployment.yaml +++ b/controllers/testdata/declarative/case_6/expected/created/persistence-agent_deployment.yaml @@ -4,6 +4,7 @@ metadata: name: ds-pipeline-persistenceagent-testdsp6 namespace: default labels: + dsp-version: v2 app: ds-pipeline-persistenceagent-testdsp6 component: data-science-pipelines dspa: testdsp6 @@ -18,6 +19,7 @@ spec: annotations: cluster-autoscaler.kubernetes.io/safe-to-evict: "true" labels: + dsp-version: v2 app: ds-pipeline-persistenceagent-testdsp6 component: data-science-pipelines dspa: testdsp6 diff --git a/controllers/util/util.go b/controllers/util/util.go index 08276d528..469cbbc60 100644 --- a/controllers/util/util.go +++ b/controllers/util/util.go @@ -18,6 +18,9 @@ package util import ( "fmt" + mf "github.com/manifestival/manifestival" + dspav1 "github.com/opendatahub-io/data-science-pipelines-operator/api/v1" + "k8s.io/apimachinery/pkg/apis/meta/v1/unstructured" "os" "path/filepath" @@ -211,3 +214,69 @@ func GetSecret(ctx context.Context, secretName, ns string, client client.Client) } return secret, nil } + +// DSPAWithSupportedDSPVersion returns True if dspa's dsp version is supported, return False otherwise. +// Note that the procedure verifies the DSPA's .spec.dspVerson field. Not to be confused with the apiversion. +func DSPAWithSupportedDSPVersion(dspa *dspav1.DataSciencePipelinesApplication) bool { + isSupported := false + for _, supportedVersion := range config.GetSupportedDSPAVersions() { + if dspa.Spec.DSPVersion == supportedVersion { + isSupported = true + } + } + return isSupported +} + +// HasSupportedDSPVersionLabel returns true if labels (representing labels for a k8s resource) +// has the DSPVersionk8sLabel label AND the value belongs to a supported DSP Version +func HasSupportedDSPVersionLabel(labels map[string]string) bool { + version, ok := labels[config.DSPVersionk8sLabel] + if !ok { + return false + } + for _, supportedVersion := range config.GetSupportedDSPAVersions() { + if version == supportedVersion { + return true + } + } + return false +} + +func AddLabelTransformer(labelKey, labelValue string) mf.Transformer { + return func(mfObj *unstructured.Unstructured) error { + // Get existing labels + labels := mfObj.GetLabels() + if labels == nil { + labels = make(map[string]string) + } + // Add or override the label + labels[labelKey] = labelValue + // Set the labels back on the object + mfObj.SetLabels(labels) + return nil + } +} + +func AddDeploymentPodLabelTransformer(labelKey, labelValue string) mf.Transformer { + return func(mfObj *unstructured.Unstructured) error { + // Check if the resource is a Deployment + if mfObj.GetKind() == "Deployment" { + // Get the spec.template.metadata.labels (which are the Pod labels) + podLabels, found, err := unstructured.NestedStringMap(mfObj.Object, "spec", "template", "metadata", "labels") + if err != nil { + return err + } + if !found { + podLabels = make(map[string]string) + } + // Add or override the pod label + podLabels[labelKey] = labelValue + // Set the updated labels back to spec.template.metadata.labels + err = unstructured.SetNestedStringMap(mfObj.Object, podLabels, "spec", "template", "metadata", "labels") + if err != nil { + return fmt.Errorf("failed to set pod labels: %w", err) + } + } + return nil + } +}