From 47caf62fb93ee2c3f18d661154aff0c662fbf6c2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?muvaffak=20onu=C5=9F?= Date: Fri, 7 Jan 2022 10:30:04 +0300 Subject: [PATCH] controller: set ongoing operation condition correctly so that it is included in a status update (#194) Signed-off-by: Muvaffak Onus --- pkg/controller/external.go | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/pkg/controller/external.go b/pkg/controller/external.go index b85e18a2..d89eb950 100644 --- a/pkg/controller/external.go +++ b/pkg/controller/external.go @@ -126,6 +126,7 @@ func (e *external) Observe(ctx context.Context, mg xpresource.Managed) (managed. } switch { case res.IsApplying, res.IsDestroying: + mg.SetConditions(resource.AsyncOperationOngoingCondition()) return managed.ExternalObservation{ ResourceExists: true, ResourceUpToDate: true, @@ -135,6 +136,10 @@ func (e *external) Observe(ctx context.Context, mg xpresource.Managed) (managed. ResourceExists: false, }, nil } + // There might be a case where async operation is finished and the status + // update marking it as finished didn't go through. At this point, we are + // sure that there is no ongoing operation. + tr.SetConditions(resource.AsyncOperationFinishedCondition()) // No operation was in progress, our observation completed successfully, and // we have an observation to consume. @@ -189,7 +194,6 @@ func (e *external) Observe(ctx context.Context, mg xpresource.Managed) (managed. func (e *external) Create(ctx context.Context, mg xpresource.Managed) (managed.ExternalCreation, error) { if e.config.UseAsync { - mg.SetConditions(resource.AsyncOperationOngoingCondition()) return managed.ExternalCreation{}, errors.Wrap(e.workspace.ApplyAsync(e.callback.Apply(mg.GetName())), errStartAsyncApply) } tr, ok := mg.(resource.Terraformed) @@ -217,7 +221,6 @@ func (e *external) Create(ctx context.Context, mg xpresource.Managed) (managed.E func (e *external) Update(ctx context.Context, mg xpresource.Managed) (managed.ExternalUpdate, error) { if e.config.UseAsync { - mg.SetConditions(resource.AsyncOperationOngoingCondition()) return managed.ExternalUpdate{}, errors.Wrap(e.workspace.ApplyAsync(e.callback.Apply(mg.GetName())), errStartAsyncApply) } tr, ok := mg.(resource.Terraformed)