From 147df262986790976af21c2e9ecccc24d9f5b0e5 Mon Sep 17 00:00:00 2001 From: Chanwit Kaewkasi Date: Wed, 14 Apr 2021 22:46:48 +0700 Subject: [PATCH] replace redundant indexers code with high-order functions Signed-off-by: Chanwit Kaewkasi --- controllers/kustomization_controller.go | 8 +- controllers/kustomization_indexers.go | 147 ++++++++---------------- 2 files changed, 53 insertions(+), 102 deletions(-) diff --git a/controllers/kustomization_controller.go b/controllers/kustomization_controller.go index 91c9e8eb..5bf8f897 100644 --- a/controllers/kustomization_controller.go +++ b/controllers/kustomization_controller.go @@ -88,13 +88,13 @@ type KustomizationReconcilerOptions struct { func (r *KustomizationReconciler) SetupWithManager(mgr ctrl.Manager, opts KustomizationReconcilerOptions) error { // Index the Kustomizations by the GitRepository references they (may) point at. if err := mgr.GetCache().IndexField(context.TODO(), &kustomizev1.Kustomization{}, kustomizev1.GitRepositoryIndexKey, - r.indexByGitRepository); err != nil { + r.indexBy(sourcev1.GitRepositoryKind)); err != nil { return fmt.Errorf("failed setting index fields: %w", err) } // Index the Kustomizations by the Bucket references they (may) point at. if err := mgr.GetCache().IndexField(context.TODO(), &kustomizev1.Kustomization{}, kustomizev1.BucketIndexKey, - r.indexByBucket); err != nil { + r.indexBy(sourcev1.BucketKind)); err != nil { return fmt.Errorf("failed setting index fields: %w", err) } @@ -115,12 +115,12 @@ func (r *KustomizationReconciler) SetupWithManager(mgr ctrl.Manager, opts Kustom )). Watches( &source.Kind{Type: &sourcev1.GitRepository{}}, - handler.EnqueueRequestsFromMapFunc(r.requestsForGitRepositoryRevisionChange), + handler.EnqueueRequestsFromMapFunc(r.requestsForRevisionChangeOf(kustomizev1.GitRepositoryIndexKey)), builder.WithPredicates(SourceRevisionChangePredicate{}), ). Watches( &source.Kind{Type: &sourcev1.Bucket{}}, - handler.EnqueueRequestsFromMapFunc(r.requestsForBucketRevisionChange), + handler.EnqueueRequestsFromMapFunc(r.requestsForRevisionChangeOf(kustomizev1.BucketIndexKey)), builder.WithPredicates(SourceRevisionChangePredicate{}), ). WithOptions(controller.Options{MaxConcurrentReconciles: opts.MaxConcurrentReconciles}). diff --git a/controllers/kustomization_indexers.go b/controllers/kustomization_indexers.go index be62d759..2ee5eedf 100644 --- a/controllers/kustomization_indexers.go +++ b/controllers/kustomization_indexers.go @@ -28,112 +28,63 @@ import ( sourcev1 "github.com/fluxcd/source-controller/api/v1beta1" ) -func (r *KustomizationReconciler) requestsForGitRepositoryRevisionChange(obj client.Object) []reconcile.Request { - repo, ok := obj.(*sourcev1.GitRepository) - if !ok { - panic(fmt.Sprintf("Expected a GitRepository but got a %T", obj)) - } - // If we do not have an artifact, we have no requests to make - if repo.GetArtifact() == nil { - return nil - } - - ctx := context.Background() - var list kustomizev1.KustomizationList - if err := r.List(ctx, &list, client.MatchingFields{ - kustomizev1.GitRepositoryIndexKey: ObjectKey(obj).String(), - }); err != nil { - return nil - } - var dd []dependency.Dependent - for _, d := range list.Items { - // If the revision of the artifact equals to the last attempted revision, - // we should not make a request for this Kustomization - if repo.GetArtifact().Revision == d.Status.LastAttemptedRevision { - continue +func (r *KustomizationReconciler) requestsForRevisionChangeOf(indexKey string) func(obj client.Object) []reconcile.Request { + return func(obj client.Object) []reconcile.Request { + repo, ok := obj.(interface { + GetArtifact() *sourcev1.Artifact + }) + if !ok { + panic(fmt.Sprintf("Expected an object conformed with GetArtifact() method, but got a %T", obj)) } - dd = append(dd, d) - } - sorted, err := dependency.Sort(dd) - if err != nil { - return nil - } - reqs := make([]reconcile.Request, len(sorted), len(sorted)) - for i := range sorted { - reqs[i].NamespacedName.Name = sorted[i].Name - reqs[i].NamespacedName.Namespace = sorted[i].Namespace - } - return reqs -} - -func (r *KustomizationReconciler) indexByGitRepository(o client.Object) []string { - k, ok := o.(*kustomizev1.Kustomization) - if !ok { - panic(fmt.Sprintf("Expected a Kustomization, got %T", o)) - } - - if k.Spec.SourceRef.Kind == sourcev1.GitRepositoryKind { - namespace := k.GetNamespace() - if k.Spec.SourceRef.Namespace != "" { - namespace = k.Spec.SourceRef.Namespace + // If we do not have an artifact, we have no requests to make + if repo.GetArtifact() == nil { + return nil } - return []string{fmt.Sprintf("%s/%s", namespace, k.Spec.SourceRef.Name)} - } - - return nil -} -func (r *KustomizationReconciler) requestsForBucketRevisionChange(obj client.Object) []reconcile.Request { - bucket, ok := obj.(*sourcev1.Bucket) - if !ok { - panic(fmt.Sprintf("Expected a Bucket but got a %T", obj)) - } - // If we do not have an artifact, we have no requests to make - if bucket.GetArtifact() == nil { - return nil - } - - ctx := context.Background() - var list kustomizev1.KustomizationList - if err := r.List(ctx, &list, client.MatchingFields{ - kustomizev1.BucketIndexKey: ObjectKey(obj).String(), - }); err != nil { - return nil - } - var dd []dependency.Dependent - for _, d := range list.Items { - // If the revision of the artifact equals to the last attempted revision, - // we should not make a request for this Kustomization - if bucket.GetArtifact().Revision == d.Status.LastAttemptedRevision { - continue + ctx := context.Background() + var list kustomizev1.KustomizationList + if err := r.List(ctx, &list, client.MatchingFields{ + indexKey: ObjectKey(obj).String(), + }); err != nil { + return nil } - dd = append(dd, d) - } - sorted, err := dependency.Sort(dd) - if err != nil { - return nil - } - reqs := make([]reconcile.Request, len(sorted), len(sorted)) - for i := range sorted { - reqs[i].NamespacedName.Name = sorted[i].Name - reqs[i].NamespacedName.Namespace = sorted[i].Namespace + var dd []dependency.Dependent + for _, d := range list.Items { + // If the revision of the artifact equals to the last attempted revision, + // we should not make a request for this Kustomization + if repo.GetArtifact().Revision == d.Status.LastAttemptedRevision { + continue + } + dd = append(dd, d) + } + sorted, err := dependency.Sort(dd) + if err != nil { + return nil + } + reqs := make([]reconcile.Request, len(sorted), len(sorted)) + for i := range sorted { + reqs[i].NamespacedName.Name = sorted[i].Name + reqs[i].NamespacedName.Namespace = sorted[i].Namespace + } + return reqs } - return reqs } -func (r *KustomizationReconciler) indexByBucket(o client.Object) []string { - k, ok := o.(*kustomizev1.Kustomization) - if !ok { - panic(fmt.Sprintf("Expected a Kustomization, got %T", o)) - } +func (r *KustomizationReconciler) indexBy(kind string) func(o client.Object) []string { + return func(o client.Object) []string { + k, ok := o.(*kustomizev1.Kustomization) + if !ok { + panic(fmt.Sprintf("Expected a Kustomization, got %T", o)) + } - if k.Spec.SourceRef.Kind == sourcev1.BucketKind { - namespace := k.GetNamespace() - if k.Spec.SourceRef.Namespace != "" { - namespace = k.Spec.SourceRef.Namespace + if k.Spec.SourceRef.Kind == kind { + namespace := k.GetNamespace() + if k.Spec.SourceRef.Namespace != "" { + namespace = k.Spec.SourceRef.Namespace + } + return []string{fmt.Sprintf("%s/%s", namespace, k.Spec.SourceRef.Name)} } - return []string{fmt.Sprintf("%s/%s", namespace, k.Spec.SourceRef.Name)} - } - return nil + return nil + } }