Skip to content

Commit

Permalink
fix(override): failed to override finalizers
Browse files Browse the repository at this point in the history
  • Loading branch information
JackZxj committed Jun 11, 2024
1 parent 20c90a8 commit 3da4604
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 2 deletions.
26 changes: 26 additions & 0 deletions pkg/controllers/sync/dispatch/managed.go
Original file line number Diff line number Diff line change
Expand Up @@ -194,6 +194,9 @@ func (d *managedDispatcherImpl) Create(ctx context.Context, clusterName string)
return result
}

// Initialize finalizers to an empty list to avoid missing-path-error of JSONPatch.
obj.SetFinalizers([]string{})

err = d.fedResource.ApplyOverrides(obj, clusterName)
if err != nil {
result = d.recordOperationError(ctx, fedcorev1a1.ApplyOverridesFailed, clusterName, op, err)
Expand Down Expand Up @@ -316,12 +319,35 @@ func (d *managedDispatcherImpl) Update(ctx context.Context, clusterName string,
return result
}

// Retain finalizers since they will typically be set by
// controllers in a member cluster. It is still possible to set the fields
// via overrides.
if fs := clusterObj.GetFinalizers(); len(fs) > 0 {
obj.SetFinalizers(fs)
} else {
// Initialize finalizers to an empty list to avoid missing-path-error of JSONPatch.
obj.SetFinalizers([]string{})
}

err = d.fedResource.ApplyOverrides(obj, clusterName)
if err != nil {
result = d.recordOperationError(ctx, fedcorev1a1.ApplyOverridesFailed, clusterName, op, err)
return result
}

// make finalizers unique
if fs := obj.GetFinalizers(); len(fs) > 0 {
i := 0
fSet := sets.NewString()
for _, v := range fs {
if fSet.Len() != fSet.Insert(v).Len() {
fs[i] = v
i++
}
}
obj.SetFinalizers(fs[:i])
}

recordPropagatedLabelsAndAnnotations(obj)

err = RetainOrMergeClusterFields(d.fedResource.TargetGVK(), obj, clusterObj)
Expand Down
3 changes: 1 addition & 2 deletions pkg/controllers/sync/dispatch/retain.go
Original file line number Diff line number Diff line change
Expand Up @@ -48,10 +48,9 @@ func RetainOrMergeClusterFields(
// Pass the same ResourceVersion as in the cluster object for update operation, otherwise operation will fail.
desiredObj.SetResourceVersion(clusterObj.GetResourceVersion())

// Retain finalizers and merge annotations since they will typically be set by
// Merge annotations since they will typically be set by
// controllers in a member cluster. It is still possible to set the fields
// via overrides.
desiredObj.SetFinalizers(clusterObj.GetFinalizers())
mergeAnnotations(desiredObj, clusterObj)
mergeLabels(desiredObj, clusterObj)

Expand Down

0 comments on commit 3da4604

Please sign in to comment.