Skip to content

Commit

Permalink
Delete old ControlPlane InfrastructureMachineTemplates on successful …
Browse files Browse the repository at this point in the history
…reconcile

Signed-off-by: killianmuldoon <[email protected]>
  • Loading branch information
killianmuldoon committed Apr 8, 2022
1 parent 17f2a7d commit c804f44
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 0 deletions.
12 changes: 12 additions & 0 deletions internal/controllers/topology/cluster/reconcile_state.go
Original file line number Diff line number Diff line change
Expand Up @@ -230,6 +230,18 @@ func (r *Reconciler) reconcileControlPlane(ctx context.Context, s *scope.Scope)
return err
}

// If the controlPlane has infrastructureMachines and the InfrastructureMachineTemplate has changed on this reconcile
// delete the old template.
// This is a best effort deletion only and may leak templates if an error occurs during reconciliation.
// TODO:(killianmuldoon) Make a more holistic template deletion flow.
if s.Blueprint.HasControlPlaneInfrastructureMachine() && s.Current.ControlPlane.InfrastructureMachineTemplate != nil {
if s.Current.ControlPlane.InfrastructureMachineTemplate.GetName() != s.Desired.ControlPlane.InfrastructureMachineTemplate.GetName() {
if err := r.Client.Delete(ctx, s.Current.ControlPlane.InfrastructureMachineTemplate); err != nil {
return errors.Wrapf(err, "failed to delete old template %s", tlog.KObj{Obj: s.Desired.ControlPlane.Object})
}
}
}

// If the ControlPlane has defined a current or desired MachineHealthCheck attempt to reconcile it.
if s.Desired.ControlPlane.MachineHealthCheck != nil || s.Current.ControlPlane.MachineHealthCheck != nil {
// Set the ControlPlane Object and the Cluster as owners for the MachineHealthCheck to ensure object garbage collection
Expand Down
5 changes: 5 additions & 0 deletions internal/controllers/topology/cluster/reconcile_state_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -734,6 +734,11 @@ func TestReconcileControlPlaneInfrastructureMachineTemplate(t *testing.T) {
for k, v := range tt.want.InfrastructureMachineTemplate.GetLabels() {
g.Expect(gotInfrastructureMachineTemplate.GetLabels()).To(HaveKeyWithValue(k, v))
}

// If the template was rotated during the reconcile we want to make sure the old template was deleted.
if tt.current.InfrastructureMachineTemplate != nil && tt.current.InfrastructureMachineTemplate.GetName() != tt.desired.InfrastructureMachineTemplate.GetName() {
g.Expect(r.Client.Get(ctx, client.ObjectKey{Namespace: tt.current.InfrastructureMachineTemplate.GetNamespace(), Name: tt.current.InfrastructureMachineTemplate.GetName()}, &unstructured.Unstructured{}))
}
})
}
}
Expand Down

0 comments on commit c804f44

Please sign in to comment.