From 44f994f462f3d659b67f77061e272cb53d29ad42 Mon Sep 17 00:00:00 2001 From: Bryan Venteicher Date: Thu, 19 Dec 2024 10:44:03 -0600 Subject: [PATCH] Refactor chanErr consumption in VM controller This patch changes the way the error channel from the async create workflow is consumed in the VirtualMachine controller. Previously only a single error was assumed to be returned, but since this is a channel, the consumer should range over it, accounting for the possible vim and k8s error. --- .../virtualmachine/virtualmachine_controller.go | 13 +++++++++++-- .../virtualmachine_controller_unit_test.go | 16 ++++++++++++++++ 2 files changed, 27 insertions(+), 2 deletions(-) diff --git a/controllers/virtualmachine/virtualmachine/virtualmachine_controller.go b/controllers/virtualmachine/virtualmachine/virtualmachine_controller.go index f96e8be1c..75367ebea 100644 --- a/controllers/virtualmachine/virtualmachine/virtualmachine_controller.go +++ b/controllers/virtualmachine/virtualmachine/virtualmachine_controller.go @@ -499,8 +499,17 @@ func (r *Reconciler) ReconcileNormal(ctx *pkgctx.VirtualMachineContext) (reterr } else { // Emit event once goroutine is complete. go func(obj client.Object) { - err := <-chanErr - r.Recorder.EmitEvent(obj, "Create", err, false) + failed := false + for err := range chanErr { + if err != nil { + failed = true + r.Recorder.EmitEvent(obj, "Create", err, false) + } + } + if !failed { + // If no error the channel is just closed. + r.Recorder.EmitEvent(obj, "Create", nil, false) + } }(ctx.VM.DeepCopy()) } } diff --git a/controllers/virtualmachine/virtualmachine/virtualmachine_controller_unit_test.go b/controllers/virtualmachine/virtualmachine/virtualmachine_controller_unit_test.go index cb6d2f236..892827018 100644 --- a/controllers/virtualmachine/virtualmachine/virtualmachine_controller_unit_test.go +++ b/controllers/virtualmachine/virtualmachine/virtualmachine_controller_unit_test.go @@ -251,6 +251,22 @@ func unitTestsReconcile() { Expect(reconciler.ReconcileNormal(vmCtx)).ShouldNot(Succeed()) expectEvents(ctx, "CreateFailure") }) + + It("Should emit CreateFailure events if ReconcileNormal causes a failed VM create that reports multiple errors", func() { + fakeVMProvider.CreateOrUpdateVirtualMachineAsyncFn = func( + ctx context.Context, + vm *vmopv1.VirtualMachine) (<-chan error, error) { + + ctxop.MarkCreate(ctx) + chanErr := make(chan error, 2) + chanErr <- errors.New("error1") + chanErr <- errors.New("error2") + return chanErr, nil + } + + Expect(reconciler.ReconcileNormal(vmCtx)).To(Succeed()) + expectEvents(ctx, "CreateFailure", "CreateFailure") + }) }) It("Should emit UpdateSuccess event if ReconcileNormal causes a successful VM update", func() {