From c437b28512c58a22d87775d714e7aebf8f9cab32 Mon Sep 17 00:00:00 2001 From: Derek Whatley Date: Fri, 26 Mar 2021 14:26:41 -0400 Subject: [PATCH] Move recording of generation to end of reconcile --- .../directimagemigration_controller.go | 5 +++-- .../directimagestreammigration_controller.go | 7 ++++--- .../directvolumemigration_controller.go | 5 +++-- .../directvolumemigrationprogress_controller.go | 7 ++++--- pkg/controller/miganalytic/miganalytics_controller.go | 5 +++-- pkg/controller/migcluster/migcluster_controller.go | 5 +++-- pkg/controller/mighook/mighook_controller.go | 5 +++-- pkg/controller/migmigration/migmigration_controller.go | 5 +++-- pkg/controller/migplan/migplan_controller.go | 5 +++-- pkg/controller/migstorage/migstorage_controller.go | 5 +++-- 10 files changed, 32 insertions(+), 22 deletions(-) diff --git a/pkg/controller/directimagemigration/directimagemigration_controller.go b/pkg/controller/directimagemigration/directimagemigration_controller.go index 7e793f26c..818532da6 100644 --- a/pkg/controller/directimagemigration/directimagemigration_controller.go +++ b/pkg/controller/directimagemigration/directimagemigration_controller.go @@ -133,8 +133,6 @@ func (r *ReconcileDirectImageMigration) Reconcile(request reconcile.Request) (re if r.uidGenerationMap.IsCacheStale(imageMigration.UID, imageMigration.Generation) { return reconcile.Result{Requeue: true}, nil } - // Record reconciled generation - defer r.uidGenerationMap.RecordReconciledGeneration(imageMigration.UID, imageMigration.Generation) // Set up jaeger tracing reconcileSpan := r.initTracer(imageMigration) @@ -185,6 +183,9 @@ func (r *ReconcileDirectImageMigration) Reconcile(request reconcile.Request) (re return reconcile.Result{Requeue: true}, nil } + // Record reconciled generation + r.uidGenerationMap.RecordReconciledGeneration(imageMigration.UID, imageMigration.Generation) + // Requeue if requeueAfter > 0 { return reconcile.Result{RequeueAfter: requeueAfter}, nil diff --git a/pkg/controller/directimagestreammigration/directimagestreammigration_controller.go b/pkg/controller/directimagestreammigration/directimagestreammigration_controller.go index b67bce9b5..3d12ab16f 100644 --- a/pkg/controller/directimagestreammigration/directimagestreammigration_controller.go +++ b/pkg/controller/directimagestreammigration/directimagestreammigration_controller.go @@ -124,9 +124,6 @@ func (r *ReconcileDirectImageStreamMigration) Reconcile(request reconcile.Reques if r.uidGenerationMap.IsCacheStale(imageStreamMigration.UID, imageStreamMigration.Generation) { return reconcile.Result{Requeue: true}, nil } - // Record reconciled generation - defer r.uidGenerationMap.RecordReconciledGeneration( - imageStreamMigration.UID, imageStreamMigration.Generation) // Set up jaeger tracing reconcileSpan, err := r.initTracer(*imageStreamMigration) @@ -177,6 +174,10 @@ func (r *ReconcileDirectImageStreamMigration) Reconcile(request reconcile.Reques return reconcile.Result{Requeue: true}, nil } + // Record reconciled generation + r.uidGenerationMap.RecordReconciledGeneration( + imageStreamMigration.UID, imageStreamMigration.Generation) + // Requeue if requeueAfter > 0 { return reconcile.Result{RequeueAfter: requeueAfter}, nil diff --git a/pkg/controller/directvolumemigration/directvolumemigration_controller.go b/pkg/controller/directvolumemigration/directvolumemigration_controller.go index d8ffba608..14258256c 100644 --- a/pkg/controller/directvolumemigration/directvolumemigration_controller.go +++ b/pkg/controller/directvolumemigration/directvolumemigration_controller.go @@ -117,8 +117,6 @@ func (r *ReconcileDirectVolumeMigration) Reconcile(request reconcile.Request) (r if r.uidGenerationMap.IsCacheStale(direct.UID, direct.Generation) { return reconcile.Result{Requeue: true}, nil } - // Record reconciled generation - defer r.uidGenerationMap.RecordReconciledGeneration(direct.UID, direct.Generation) // Set up jaeger tracing reconcileSpan := r.initTracer(direct) @@ -172,6 +170,9 @@ func (r *ReconcileDirectVolumeMigration) Reconcile(request reconcile.Request) (r return reconcile.Result{Requeue: true}, nil } + // Record reconciled generation + r.uidGenerationMap.RecordReconciledGeneration(direct.UID, direct.Generation) + // Requeue if requeueAfter > 0 { return reconcile.Result{RequeueAfter: requeueAfter}, nil diff --git a/pkg/controller/directvolumemigrationprogress/directvolumemigrationprogress_controller.go b/pkg/controller/directvolumemigrationprogress/directvolumemigrationprogress_controller.go index c2943700a..d363d0ad3 100644 --- a/pkg/controller/directvolumemigrationprogress/directvolumemigrationprogress_controller.go +++ b/pkg/controller/directvolumemigrationprogress/directvolumemigrationprogress_controller.go @@ -147,8 +147,6 @@ func (r *ReconcileDirectVolumeMigrationProgress) Reconcile(request reconcile.Req if r.uidGenerationMap.IsCacheStale(pvProgress.UID, pvProgress.Generation) { return reconcile.Result{Requeue: true}, nil } - // Record reconciled generation - defer r.uidGenerationMap.RecordReconciledGeneration(pvProgress.UID, pvProgress.Generation) // Set up jaeger tracing reconcileSpan, err := r.initTracer(*pvProgress) @@ -191,7 +189,10 @@ func (r *ReconcileDirectVolumeMigrationProgress) Reconcile(request reconcile.Req return reconcile.Result{Requeue: true}, nil } - // we will requeue this every 5 seconds + // Record reconciled generation + r.uidGenerationMap.RecordReconciledGeneration(pvProgress.UID, pvProgress.Generation) + + // Requeue every 5 seconds return reconcile.Result{Requeue: true, RequeueAfter: time.Second * 5}, nil } diff --git a/pkg/controller/miganalytic/miganalytics_controller.go b/pkg/controller/miganalytic/miganalytics_controller.go index 051c416a9..5fd31f7ca 100644 --- a/pkg/controller/miganalytic/miganalytics_controller.go +++ b/pkg/controller/miganalytic/miganalytics_controller.go @@ -149,8 +149,6 @@ func (r *ReconcileMigAnalytic) Reconcile(request reconcile.Request) (reconcile.R if r.uidGenerationMap.IsCacheStale(analytic.UID, analytic.Generation) { return reconcile.Result{Requeue: true}, nil } - // Record reconciled generation - defer r.uidGenerationMap.RecordReconciledGeneration(analytic.UID, analytic.Generation) // Exit early if the MigAnalytic already has a ready condition // and Refresh boolean is unset @@ -224,6 +222,9 @@ func (r *ReconcileMigAnalytic) Reconcile(request reconcile.Request) (reconcile.R return reconcile.Result{Requeue: true}, nil } + // Record reconciled generation + r.uidGenerationMap.RecordReconciledGeneration(analytic.UID, analytic.Generation) + // Done return reconcile.Result{Requeue: false}, nil } diff --git a/pkg/controller/migcluster/migcluster_controller.go b/pkg/controller/migcluster/migcluster_controller.go index dd865942e..a9decc3be 100644 --- a/pkg/controller/migcluster/migcluster_controller.go +++ b/pkg/controller/migcluster/migcluster_controller.go @@ -132,8 +132,6 @@ func (r *ReconcileMigCluster) Reconcile(request reconcile.Request) (reconcile.Re if r.uidGenerationMap.IsCacheStale(cluster.UID, cluster.Generation) { return reconcile.Result{Requeue: true}, nil } - // Record reconciled generation - defer r.uidGenerationMap.RecordReconciledGeneration(cluster.UID, cluster.Generation) // Report reconcile error. defer func() { @@ -193,6 +191,9 @@ func (r *ReconcileMigCluster) Reconcile(request reconcile.Request) (reconcile.Re return reconcile.Result{Requeue: true}, nil } + // Record reconciled generation + r.uidGenerationMap.RecordReconciledGeneration(cluster.UID, cluster.Generation) + // Done return reconcile.Result{Requeue: false}, nil } diff --git a/pkg/controller/mighook/mighook_controller.go b/pkg/controller/mighook/mighook_controller.go index ae8e3d9f9..c95a46dc8 100644 --- a/pkg/controller/mighook/mighook_controller.go +++ b/pkg/controller/mighook/mighook_controller.go @@ -104,8 +104,6 @@ func (r *ReconcileMigHook) Reconcile(request reconcile.Request) (reconcile.Resul if r.uidGenerationMap.IsCacheStale(hook.UID, hook.Generation) { return reconcile.Result{Requeue: true}, nil } - // Record reconciled generation - defer r.uidGenerationMap.RecordReconciledGeneration(hook.UID, hook.Generation) // Report reconcile error. defer func() { @@ -148,6 +146,9 @@ func (r *ReconcileMigHook) Reconcile(request reconcile.Request) (reconcile.Resul return reconcile.Result{Requeue: true}, nil } + // Record reconciled generation + r.uidGenerationMap.RecordReconciledGeneration(hook.UID, hook.Generation) + // Done return reconcile.Result{Requeue: false}, nil } diff --git a/pkg/controller/migmigration/migmigration_controller.go b/pkg/controller/migmigration/migmigration_controller.go index 4525fc850..b6e29d91a 100644 --- a/pkg/controller/migmigration/migmigration_controller.go +++ b/pkg/controller/migmigration/migmigration_controller.go @@ -174,8 +174,6 @@ func (r *ReconcileMigMigration) Reconcile(request reconcile.Request) (reconcile. if r.uidGenerationMap.IsCacheStale(migration.UID, migration.Generation) { return reconcile.Result{Requeue: true}, nil } - // Record reconciled generation - defer r.uidGenerationMap.RecordReconciledGeneration(migration.UID, migration.Generation) // Get jaeger spans for migration and reconcile _, reconcileSpan := r.initTracer(migration) @@ -276,6 +274,9 @@ func (r *ReconcileMigMigration) Reconcile(request reconcile.Request) (reconcile. return reconcile.Result{Requeue: true}, nil } + // Record reconciled generation + r.uidGenerationMap.RecordReconciledGeneration(migration.UID, migration.Generation) + // Requeue if requeueAfter > 0 { return reconcile.Result{RequeueAfter: requeueAfter}, nil diff --git a/pkg/controller/migplan/migplan_controller.go b/pkg/controller/migplan/migplan_controller.go index 65ddde7e5..79a61347c 100644 --- a/pkg/controller/migplan/migplan_controller.go +++ b/pkg/controller/migplan/migplan_controller.go @@ -204,8 +204,6 @@ func (r *ReconcileMigPlan) Reconcile(request reconcile.Request) (reconcile.Resul if r.uidGenerationMap.IsCacheStale(plan.UID, plan.Generation) { return reconcile.Result{Requeue: true}, nil } - // Record reconciled generation - defer r.uidGenerationMap.RecordReconciledGeneration(plan.UID, plan.Generation) // Report reconcile error. defer func() { @@ -332,6 +330,9 @@ func (r *ReconcileMigPlan) Reconcile(request reconcile.Request) (reconcile.Resul return reconcile.Result{Requeue: true}, nil } + // Record reconciled generation + r.uidGenerationMap.RecordReconciledGeneration(plan.UID, plan.Generation) + // Timed requeue on Plan conflict. if plan.Status.HasCondition(PlanConflict) { return reconcile.Result{RequeueAfter: time.Second * 10}, nil diff --git a/pkg/controller/migstorage/migstorage_controller.go b/pkg/controller/migstorage/migstorage_controller.go index c65d05989..817e005f1 100644 --- a/pkg/controller/migstorage/migstorage_controller.go +++ b/pkg/controller/migstorage/migstorage_controller.go @@ -130,8 +130,6 @@ func (r *ReconcileMigStorage) Reconcile(request reconcile.Request) (reconcile.Re if r.uidGenerationMap.IsCacheStale(storage.UID, storage.Generation) { return reconcile.Result{Requeue: true}, nil } - // Record reconciled generation - defer r.uidGenerationMap.RecordReconciledGeneration(storage.UID, storage.Generation) // Report reconcile error. defer func() { @@ -177,6 +175,9 @@ func (r *ReconcileMigStorage) Reconcile(request reconcile.Request) (reconcile.Re return reconcile.Result{Requeue: true}, nil } + // Record reconciled generation + r.uidGenerationMap.RecordReconciledGeneration(storage.UID, storage.Generation) + // Done return reconcile.Result{Requeue: false}, nil }