From 496247dbb5b0178514c649be0deae0ae829014cc Mon Sep 17 00:00:00 2001 From: Ben Blattberg Date: Fri, 8 Nov 2024 11:41:37 -0600 Subject: [PATCH 1/4] Add default container annotation Since K8s 1.21, the kubectl.kubernetes.io/default-container annotation can be added to set a default container, removing the need for a -c flag or eliminating the mesage about defaulting Issues: [PGO-1941] --- internal/controller/pgupgrade/jobs.go | 13 +++++++++++-- internal/controller/pgupgrade/jobs_test.go | 8 ++++++++ .../controller/postgrescluster/instance.go | 3 +++ .../controller/postgrescluster/pgadmin.go | 6 +++++- .../controller/postgrescluster/pgbackrest.go | 19 +++++++++++++++++-- .../controller/postgrescluster/pgbouncer.go | 6 +++++- .../controller/postgrescluster/volumes.go | 12 +++++++++--- .../standalone_pgadmin/statefulset.go | 7 ++++++- internal/naming/annotations.go | 4 ++++ 9 files changed, 68 insertions(+), 10 deletions(-) diff --git a/internal/controller/pgupgrade/jobs.go b/internal/controller/pgupgrade/jobs.go index a1722dfc1..545a8b2db 100644 --- a/internal/controller/pgupgrade/jobs.go +++ b/internal/controller/pgupgrade/jobs.go @@ -16,6 +16,7 @@ import ( "k8s.io/apimachinery/pkg/labels" "github.com/crunchydata/postgres-operator/internal/initialize" + "github.com/crunchydata/postgres-operator/internal/naming" "github.com/crunchydata/postgres-operator/pkg/apis/postgres-operator.crunchydata.com/v1beta1" ) @@ -129,7 +130,6 @@ func (r *PGUpgradeReconciler) generateUpgradeJob( job.Namespace = upgrade.Namespace job.Name = pgUpgradeJob(upgrade).Name - job.Annotations = upgrade.Spec.Metadata.GetAnnotationsOrNil() job.Labels = Merge(upgrade.Spec.Metadata.GetLabelsOrNil(), commonLabels(pgUpgrade, upgrade), //FIXME role pgupgrade map[string]string{ @@ -145,6 +145,11 @@ func (r *PGUpgradeReconciler) generateUpgradeJob( } } + job.Annotations = Merge(upgrade.Spec.Metadata.GetAnnotationsOrNil(), + map[string]string{ + naming.DefaultContainerLabel: database.Name, + }) + // Copy the pod template from the startup instance StatefulSet. This includes // the service account, volumes, DNS policies, and scheduling constraints. startup.Spec.Template.DeepCopyInto(&job.Spec.Template) @@ -241,7 +246,6 @@ func (r *PGUpgradeReconciler) generateRemoveDataJob( job.Namespace = upgrade.Namespace job.Name = upgrade.Name + "-" + sts.Name - job.Annotations = upgrade.Spec.Metadata.GetAnnotationsOrNil() job.Labels = labels.Merge(upgrade.Spec.Metadata.GetLabelsOrNil(), commonLabels(removeData, upgrade)) //FIXME role removedata @@ -254,6 +258,11 @@ func (r *PGUpgradeReconciler) generateRemoveDataJob( } } + job.Annotations = Merge(upgrade.Spec.Metadata.GetAnnotationsOrNil(), + map[string]string{ + naming.DefaultContainerLabel: database.Name, + }) + // Copy the pod template from the sts instance StatefulSet. This includes // the service account, volumes, DNS policies, and scheduling constraints. sts.Spec.Template.DeepCopyInto(&job.Spec.Template) diff --git a/internal/controller/pgupgrade/jobs_test.go b/internal/controller/pgupgrade/jobs_test.go index 8dfc4731a..1132e6b6e 100644 --- a/internal/controller/pgupgrade/jobs_test.go +++ b/internal/controller/pgupgrade/jobs_test.go @@ -62,6 +62,8 @@ func TestGenerateUpgradeJob(t *testing.T) { apiVersion: batch/v1 kind: Job metadata: + annotations: + kubectl.kubernetes.io/default-container: database creationTimestamp: null labels: postgres-operator.crunchydata.com/cluster: pg5 @@ -81,6 +83,8 @@ spec: backoffLimit: 0 template: metadata: + annotations: + kubectl.kubernetes.io/default-container: database creationTimestamp: null labels: postgres-operator.crunchydata.com/cluster: pg5 @@ -193,6 +197,8 @@ func TestGenerateRemoveDataJob(t *testing.T) { apiVersion: batch/v1 kind: Job metadata: + annotations: + kubectl.kubernetes.io/default-container: database creationTimestamp: null labels: postgres-operator.crunchydata.com/cluster: pg5 @@ -211,6 +217,8 @@ spec: backoffLimit: 0 template: metadata: + annotations: + kubectl.kubernetes.io/default-container: database creationTimestamp: null labels: postgres-operator.crunchydata.com/cluster: pg5 diff --git a/internal/controller/postgrescluster/instance.go b/internal/controller/postgrescluster/instance.go index 66321cc73..63503f37a 100644 --- a/internal/controller/postgrescluster/instance.go +++ b/internal/controller/postgrescluster/instance.go @@ -1268,6 +1268,9 @@ func generateInstanceStatefulSetIntent(_ context.Context, sts.Spec.Template.Annotations = naming.Merge( cluster.Spec.Metadata.GetAnnotationsOrNil(), spec.Metadata.GetAnnotationsOrNil(), + map[string]string{ + naming.DefaultContainerLabel: naming.ContainerDatabase, + }, ) sts.Spec.Template.Labels = naming.Merge( cluster.Spec.Metadata.GetLabelsOrNil(), diff --git a/internal/controller/postgrescluster/pgadmin.go b/internal/controller/postgrescluster/pgadmin.go index c0a936ba1..88f8498e9 100644 --- a/internal/controller/postgrescluster/pgadmin.go +++ b/internal/controller/postgrescluster/pgadmin.go @@ -258,7 +258,11 @@ func (r *Reconciler) reconcilePGAdminStatefulSet( } sts.Spec.Template.Annotations = naming.Merge( cluster.Spec.Metadata.GetAnnotationsOrNil(), - cluster.Spec.UserInterface.PGAdmin.Metadata.GetAnnotationsOrNil()) + cluster.Spec.UserInterface.PGAdmin.Metadata.GetAnnotationsOrNil(), + map[string]string{ + naming.DefaultContainerLabel: naming.ContainerPGAdmin, + }, + ) sts.Spec.Template.Labels = naming.Merge( cluster.Spec.Metadata.GetLabelsOrNil(), cluster.Spec.UserInterface.PGAdmin.Metadata.GetLabelsOrNil(), diff --git a/internal/controller/postgrescluster/pgbackrest.go b/internal/controller/postgrescluster/pgbackrest.go index 836df047f..7263c6416 100644 --- a/internal/controller/postgrescluster/pgbackrest.go +++ b/internal/controller/postgrescluster/pgbackrest.go @@ -583,7 +583,11 @@ func (r *Reconciler) generateRepoHostIntent(ctx context.Context, postgresCluster annotations := naming.Merge( postgresCluster.Spec.Metadata.GetAnnotationsOrNil(), - postgresCluster.Spec.Backups.PGBackRest.Metadata.GetAnnotationsOrNil()) + postgresCluster.Spec.Backups.PGBackRest.Metadata.GetAnnotationsOrNil(), + map[string]string{ + naming.DefaultContainerLabel: naming.PGBackRestRepoContainerName, + }, + ) labels := naming.Merge( postgresCluster.Spec.Metadata.GetLabelsOrNil(), postgresCluster.Spec.Backups.PGBackRest.Metadata.GetLabelsOrNil(), @@ -805,6 +809,14 @@ func generateBackupJobSpecIntent(ctx context.Context, postgresCluster *v1beta1.P container.Resources = postgresCluster.Spec.Backups.PGBackRest.Jobs.Resources } + if annotations != nil { + annotations[naming.DefaultContainerLabel] = naming.PGBackRestRepoContainerName + } else { + annotations = map[string]string{ + naming.DefaultContainerLabel: naming.PGBackRestRepoContainerName, + } + } + jobSpec := &batchv1.JobSpec{ Template: corev1.PodTemplateSpec{ ObjectMeta: metav1.ObjectMeta{Labels: labels, Annotations: annotations}, @@ -1272,7 +1284,10 @@ func (r *Reconciler) generateRestoreJobIntent(cluster *v1beta1.PostgresCluster, annotations := naming.Merge( cluster.Spec.Metadata.GetAnnotationsOrNil(), cluster.Spec.Backups.PGBackRest.Metadata.GetAnnotationsOrNil(), - map[string]string{naming.PGBackRestConfigHash: configHash}) + map[string]string{ + naming.PGBackRestConfigHash: configHash, + naming.DefaultContainerLabel: naming.PGBackRestRestoreContainerName, + }) labels := naming.Merge( cluster.Spec.Metadata.GetLabelsOrNil(), cluster.Spec.Backups.PGBackRest.Metadata.GetLabelsOrNil(), diff --git a/internal/controller/postgrescluster/pgbouncer.go b/internal/controller/postgrescluster/pgbouncer.go index 76207fac0..14a8be44b 100644 --- a/internal/controller/postgrescluster/pgbouncer.go +++ b/internal/controller/postgrescluster/pgbouncer.go @@ -371,7 +371,11 @@ func (r *Reconciler) generatePGBouncerDeployment( } deploy.Spec.Template.Annotations = naming.Merge( cluster.Spec.Metadata.GetAnnotationsOrNil(), - cluster.Spec.Proxy.PGBouncer.Metadata.GetAnnotationsOrNil()) + cluster.Spec.Proxy.PGBouncer.Metadata.GetAnnotationsOrNil(), + map[string]string{ + naming.DefaultContainerLabel: naming.ContainerPGBouncer, + }, + ) deploy.Spec.Template.Labels = naming.Merge( cluster.Spec.Metadata.GetLabelsOrNil(), cluster.Spec.Proxy.PGBouncer.Metadata.GetLabelsOrNil(), diff --git a/internal/controller/postgrescluster/volumes.go b/internal/controller/postgrescluster/volumes.go index e40710d4f..3ab733104 100644 --- a/internal/controller/postgrescluster/volumes.go +++ b/internal/controller/postgrescluster/volumes.go @@ -469,7 +469,9 @@ func (r *Reconciler) reconcileMovePGDataDir(ctx context.Context, jobSpec := &batchv1.JobSpec{ Template: corev1.PodTemplateSpec{ - ObjectMeta: metav1.ObjectMeta{Labels: labels}, + ObjectMeta: metav1.ObjectMeta{Labels: labels, Annotations: map[string]string{ + naming.DefaultContainerLabel: naming.ContainerJobMovePGDataDir, + }}, Spec: corev1.PodSpec{ // Set the image pull secrets, if any exist. // This is set here rather than using the service account due to the lack @@ -586,7 +588,9 @@ func (r *Reconciler) reconcileMoveWALDir(ctx context.Context, jobSpec := &batchv1.JobSpec{ Template: corev1.PodTemplateSpec{ - ObjectMeta: metav1.ObjectMeta{Labels: labels}, + ObjectMeta: metav1.ObjectMeta{Labels: labels, Annotations: map[string]string{ + naming.DefaultContainerLabel: naming.ContainerJobMovePGWALDir, + }}, Spec: corev1.PodSpec{ // Set the image pull secrets, if any exist. // This is set here rather than using the service account due to the lack @@ -708,7 +712,9 @@ func (r *Reconciler) reconcileMoveRepoDir(ctx context.Context, jobSpec := &batchv1.JobSpec{ Template: corev1.PodTemplateSpec{ - ObjectMeta: metav1.ObjectMeta{Labels: labels}, + ObjectMeta: metav1.ObjectMeta{Labels: labels, Annotations: map[string]string{ + naming.DefaultContainerLabel: naming.ContainerJobMovePGBackRestRepoDir, + }}, Spec: corev1.PodSpec{ // Set the image pull secrets, if any exist. // This is set here rather than using the service account due to the lack diff --git a/internal/controller/standalone_pgadmin/statefulset.go b/internal/controller/standalone_pgadmin/statefulset.go index e086e333f..6d424be53 100644 --- a/internal/controller/standalone_pgadmin/statefulset.go +++ b/internal/controller/standalone_pgadmin/statefulset.go @@ -74,7 +74,12 @@ func statefulset( sts.Spec.Selector = &metav1.LabelSelector{ MatchLabels: naming.StandalonePGAdminLabels(pgadmin.Name), } - sts.Spec.Template.Annotations = pgadmin.Spec.Metadata.GetAnnotationsOrNil() + sts.Spec.Template.Annotations = naming.Merge( + pgadmin.Spec.Metadata.GetAnnotationsOrNil(), + map[string]string{ + naming.DefaultContainerLabel: naming.ContainerPGAdmin, + }, + ) sts.Spec.Template.Labels = naming.Merge( pgadmin.Spec.Metadata.GetLabelsOrNil(), naming.StandalonePGAdminDataLabels(pgadmin.Name), diff --git a/internal/naming/annotations.go b/internal/naming/annotations.go index 2179a5f08..aa77e6b08 100644 --- a/internal/naming/annotations.go +++ b/internal/naming/annotations.go @@ -68,4 +68,8 @@ const ( // to a cluster without backups. As usual with the operator, we do not // touch cloud-based backups. AuthorizeBackupRemovalAnnotation = annotationPrefix + "authorizeBackupRemoval" + + // Used from Kubernetes v1.21+ to define a default container used when the + // `-c` flag is not passed + DefaultContainerLabel = "kubectl.kubernetes.io/default-container" ) From ea35ac4117945754cd6c45089f0a48fff7248fa8 Mon Sep 17 00:00:00 2001 From: Ben Blattberg Date: Fri, 8 Nov 2024 15:44:29 -0600 Subject: [PATCH 2/4] PR feedback, v1 --- internal/controller/pgupgrade/jobs.go | 4 ++-- internal/controller/postgrescluster/instance.go | 2 +- internal/controller/postgrescluster/pgadmin.go | 2 +- internal/controller/postgrescluster/pgbackrest.go | 10 +++++----- internal/controller/postgrescluster/pgbouncer.go | 2 +- internal/controller/postgrescluster/volumes.go | 6 +++--- internal/controller/standalone_pgadmin/statefulset.go | 2 +- internal/naming/annotations.go | 5 +++-- 8 files changed, 17 insertions(+), 16 deletions(-) diff --git a/internal/controller/pgupgrade/jobs.go b/internal/controller/pgupgrade/jobs.go index 545a8b2db..59a9bb5d7 100644 --- a/internal/controller/pgupgrade/jobs.go +++ b/internal/controller/pgupgrade/jobs.go @@ -147,7 +147,7 @@ func (r *PGUpgradeReconciler) generateUpgradeJob( job.Annotations = Merge(upgrade.Spec.Metadata.GetAnnotationsOrNil(), map[string]string{ - naming.DefaultContainerLabel: database.Name, + naming.DefaultContainerAnnotation: database.Name, }) // Copy the pod template from the startup instance StatefulSet. This includes @@ -260,7 +260,7 @@ func (r *PGUpgradeReconciler) generateRemoveDataJob( job.Annotations = Merge(upgrade.Spec.Metadata.GetAnnotationsOrNil(), map[string]string{ - naming.DefaultContainerLabel: database.Name, + naming.DefaultContainerAnnotation: database.Name, }) // Copy the pod template from the sts instance StatefulSet. This includes diff --git a/internal/controller/postgrescluster/instance.go b/internal/controller/postgrescluster/instance.go index 63503f37a..93fd99934 100644 --- a/internal/controller/postgrescluster/instance.go +++ b/internal/controller/postgrescluster/instance.go @@ -1269,7 +1269,7 @@ func generateInstanceStatefulSetIntent(_ context.Context, cluster.Spec.Metadata.GetAnnotationsOrNil(), spec.Metadata.GetAnnotationsOrNil(), map[string]string{ - naming.DefaultContainerLabel: naming.ContainerDatabase, + naming.DefaultContainerAnnotation: naming.ContainerDatabase, }, ) sts.Spec.Template.Labels = naming.Merge( diff --git a/internal/controller/postgrescluster/pgadmin.go b/internal/controller/postgrescluster/pgadmin.go index 88f8498e9..b3ea2ab40 100644 --- a/internal/controller/postgrescluster/pgadmin.go +++ b/internal/controller/postgrescluster/pgadmin.go @@ -260,7 +260,7 @@ func (r *Reconciler) reconcilePGAdminStatefulSet( cluster.Spec.Metadata.GetAnnotationsOrNil(), cluster.Spec.UserInterface.PGAdmin.Metadata.GetAnnotationsOrNil(), map[string]string{ - naming.DefaultContainerLabel: naming.ContainerPGAdmin, + naming.DefaultContainerAnnotation: naming.ContainerPGAdmin, }, ) sts.Spec.Template.Labels = naming.Merge( diff --git a/internal/controller/postgrescluster/pgbackrest.go b/internal/controller/postgrescluster/pgbackrest.go index 7263c6416..7e02e63c0 100644 --- a/internal/controller/postgrescluster/pgbackrest.go +++ b/internal/controller/postgrescluster/pgbackrest.go @@ -585,7 +585,7 @@ func (r *Reconciler) generateRepoHostIntent(ctx context.Context, postgresCluster postgresCluster.Spec.Metadata.GetAnnotationsOrNil(), postgresCluster.Spec.Backups.PGBackRest.Metadata.GetAnnotationsOrNil(), map[string]string{ - naming.DefaultContainerLabel: naming.PGBackRestRepoContainerName, + naming.DefaultContainerAnnotation: naming.PGBackRestRepoContainerName, }, ) labels := naming.Merge( @@ -810,10 +810,10 @@ func generateBackupJobSpecIntent(ctx context.Context, postgresCluster *v1beta1.P } if annotations != nil { - annotations[naming.DefaultContainerLabel] = naming.PGBackRestRepoContainerName + annotations[naming.DefaultContainerAnnotation] = naming.PGBackRestRepoContainerName } else { annotations = map[string]string{ - naming.DefaultContainerLabel: naming.PGBackRestRepoContainerName, + naming.DefaultContainerAnnotation: naming.PGBackRestRepoContainerName, } } @@ -1285,8 +1285,8 @@ func (r *Reconciler) generateRestoreJobIntent(cluster *v1beta1.PostgresCluster, cluster.Spec.Metadata.GetAnnotationsOrNil(), cluster.Spec.Backups.PGBackRest.Metadata.GetAnnotationsOrNil(), map[string]string{ - naming.PGBackRestConfigHash: configHash, - naming.DefaultContainerLabel: naming.PGBackRestRestoreContainerName, + naming.PGBackRestConfigHash: configHash, + naming.DefaultContainerAnnotation: naming.PGBackRestRestoreContainerName, }) labels := naming.Merge( cluster.Spec.Metadata.GetLabelsOrNil(), diff --git a/internal/controller/postgrescluster/pgbouncer.go b/internal/controller/postgrescluster/pgbouncer.go index 14a8be44b..acb827630 100644 --- a/internal/controller/postgrescluster/pgbouncer.go +++ b/internal/controller/postgrescluster/pgbouncer.go @@ -373,7 +373,7 @@ func (r *Reconciler) generatePGBouncerDeployment( cluster.Spec.Metadata.GetAnnotationsOrNil(), cluster.Spec.Proxy.PGBouncer.Metadata.GetAnnotationsOrNil(), map[string]string{ - naming.DefaultContainerLabel: naming.ContainerPGBouncer, + naming.DefaultContainerAnnotation: naming.ContainerPGBouncer, }, ) deploy.Spec.Template.Labels = naming.Merge( diff --git a/internal/controller/postgrescluster/volumes.go b/internal/controller/postgrescluster/volumes.go index 3ab733104..f11747600 100644 --- a/internal/controller/postgrescluster/volumes.go +++ b/internal/controller/postgrescluster/volumes.go @@ -470,7 +470,7 @@ func (r *Reconciler) reconcileMovePGDataDir(ctx context.Context, jobSpec := &batchv1.JobSpec{ Template: corev1.PodTemplateSpec{ ObjectMeta: metav1.ObjectMeta{Labels: labels, Annotations: map[string]string{ - naming.DefaultContainerLabel: naming.ContainerJobMovePGDataDir, + naming.DefaultContainerAnnotation: naming.ContainerJobMovePGDataDir, }}, Spec: corev1.PodSpec{ // Set the image pull secrets, if any exist. @@ -589,7 +589,7 @@ func (r *Reconciler) reconcileMoveWALDir(ctx context.Context, jobSpec := &batchv1.JobSpec{ Template: corev1.PodTemplateSpec{ ObjectMeta: metav1.ObjectMeta{Labels: labels, Annotations: map[string]string{ - naming.DefaultContainerLabel: naming.ContainerJobMovePGWALDir, + naming.DefaultContainerAnnotation: naming.ContainerJobMovePGWALDir, }}, Spec: corev1.PodSpec{ // Set the image pull secrets, if any exist. @@ -713,7 +713,7 @@ func (r *Reconciler) reconcileMoveRepoDir(ctx context.Context, jobSpec := &batchv1.JobSpec{ Template: corev1.PodTemplateSpec{ ObjectMeta: metav1.ObjectMeta{Labels: labels, Annotations: map[string]string{ - naming.DefaultContainerLabel: naming.ContainerJobMovePGBackRestRepoDir, + naming.DefaultContainerAnnotation: naming.ContainerJobMovePGBackRestRepoDir, }}, Spec: corev1.PodSpec{ // Set the image pull secrets, if any exist. diff --git a/internal/controller/standalone_pgadmin/statefulset.go b/internal/controller/standalone_pgadmin/statefulset.go index 6d424be53..39e434f18 100644 --- a/internal/controller/standalone_pgadmin/statefulset.go +++ b/internal/controller/standalone_pgadmin/statefulset.go @@ -77,7 +77,7 @@ func statefulset( sts.Spec.Template.Annotations = naming.Merge( pgadmin.Spec.Metadata.GetAnnotationsOrNil(), map[string]string{ - naming.DefaultContainerLabel: naming.ContainerPGAdmin, + naming.DefaultContainerAnnotation: naming.ContainerPGAdmin, }, ) sts.Spec.Template.Labels = naming.Merge( diff --git a/internal/naming/annotations.go b/internal/naming/annotations.go index aa77e6b08..3dcabc26e 100644 --- a/internal/naming/annotations.go +++ b/internal/naming/annotations.go @@ -70,6 +70,7 @@ const ( AuthorizeBackupRemovalAnnotation = annotationPrefix + "authorizeBackupRemoval" // Used from Kubernetes v1.21+ to define a default container used when the - // `-c` flag is not passed - DefaultContainerLabel = "kubectl.kubernetes.io/default-container" + // `-c` flag is not passed. + // --https://kubernetes.io/docs/reference/labels-annotations-taints/#kubectl-kubernetes-io-default-container + DefaultContainerAnnotation = "kubectl.kubernetes.io/default-container" ) From 8e893805f2a9efa07a1ff957bced5df181b03acb Mon Sep 17 00:00:00 2001 From: Ben Blattberg Date: Mon, 18 Nov 2024 12:41:58 -0600 Subject: [PATCH 3/4] test update --- internal/controller/postgrescluster/pgadmin_test.go | 3 +++ internal/controller/postgrescluster/pgbouncer_test.go | 1 + 2 files changed, 4 insertions(+) diff --git a/internal/controller/postgrescluster/pgadmin_test.go b/internal/controller/postgrescluster/pgadmin_test.go index 92ec6f42f..359f56b0e 100644 --- a/internal/controller/postgrescluster/pgadmin_test.go +++ b/internal/controller/postgrescluster/pgadmin_test.go @@ -500,6 +500,8 @@ func TestReconcilePGAdminStatefulSet(t *testing.T) { template.Spec.Volumes = nil assert.Assert(t, cmp.MarshalMatches(template.ObjectMeta, ` +annotations: + kubectl.kubernetes.io/default-container: pgadmin creationTimestamp: null labels: postgres-operator.crunchydata.com/cluster: test-cluster @@ -613,6 +615,7 @@ terminationGracePeriodSeconds: 30 assert.Assert(t, cmp.MarshalMatches(template.ObjectMeta, ` annotations: annotation1: annotationvalue + kubectl.kubernetes.io/default-container: pgadmin creationTimestamp: null labels: label1: labelvalue diff --git a/internal/controller/postgrescluster/pgbouncer_test.go b/internal/controller/postgrescluster/pgbouncer_test.go index 9bbced524..100262a18 100644 --- a/internal/controller/postgrescluster/pgbouncer_test.go +++ b/internal/controller/postgrescluster/pgbouncer_test.go @@ -443,6 +443,7 @@ namespace: ns3 // Annotations present in the pod template. assert.DeepEqual(t, deploy.Spec.Template.Annotations, map[string]string{ "a": "v1", + "kubectl.kubernetes.io/default-container": "pgbouncer", }) // Labels present in the pod template. From 2fd4ef084ce48da087a211cffd5942a2a30852f4 Mon Sep 17 00:00:00 2001 From: Ben Blattberg Date: Mon, 18 Nov 2024 13:22:00 -0600 Subject: [PATCH 4/4] test update --- internal/controller/standalone_pgadmin/statefulset_test.go | 3 +++ 1 file changed, 3 insertions(+) diff --git a/internal/controller/standalone_pgadmin/statefulset_test.go b/internal/controller/standalone_pgadmin/statefulset_test.go index 52c501b35..34a346e80 100644 --- a/internal/controller/standalone_pgadmin/statefulset_test.go +++ b/internal/controller/standalone_pgadmin/statefulset_test.go @@ -73,6 +73,8 @@ func TestReconcilePGAdminStatefulSet(t *testing.T) { template.Spec.Volumes = nil assert.Assert(t, cmp.MarshalMatches(template.ObjectMeta, ` +annotations: + kubectl.kubernetes.io/default-container: pgadmin creationTimestamp: null labels: postgres-operator.crunchydata.com/data: pgadmin @@ -170,6 +172,7 @@ terminationGracePeriodSeconds: 30 assert.Assert(t, cmp.MarshalMatches(template.ObjectMeta, ` annotations: annotation1: annotationvalue + kubectl.kubernetes.io/default-container: pgadmin creationTimestamp: null labels: label1: labelvalue