From d74425156179c20555b2aae96f809de0713b13e0 Mon Sep 17 00:00:00 2001 From: David Eads Date: Fri, 18 Oct 2024 11:35:24 -0400 Subject: [PATCH] problems with MOMification --- pkg/operator/workload/sync_openshift_oauth_apiserver.go | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/pkg/operator/workload/sync_openshift_oauth_apiserver.go b/pkg/operator/workload/sync_openshift_oauth_apiserver.go index b9b173821..9941a79e3 100644 --- a/pkg/operator/workload/sync_openshift_oauth_apiserver.go +++ b/pkg/operator/workload/sync_openshift_oauth_apiserver.go @@ -232,6 +232,11 @@ func (c *OAuthAPIServerWorkload) syncDeployment(ctx context.Context, operatorSpe } required.Spec.Replicas = masterNodeCount + // TODO MOM this call here is the one that fails. Using the return value of ApplyDeployment to make decisions doesn't work in a MOM world. + // TODO MOM workload.NewController needs to (somehow) use the data read *after* this write, without using data *in* this write. + // TODO MOM this may be possible by storing a hash of the desired content. If the hash of the desired content matches + // TODO MOM then there is no new deployment required. This would not prevent rapid writes to fields we aren't controlling. + // TODO MOM perhaps we actually need to find a way to request MOM inject a generation after a write? It is an operator standard. deployment, _, err := resourceapply.ApplyDeployment(ctx, c.kubeClient.AppsV1(), eventRecorder, required, resourcemerge.ExpectedDeploymentGeneration(required, operatorStatus.Generations)) return deployment, err }