From ff511643efeffa33c6c73b417564aa4397f2764e Mon Sep 17 00:00:00 2001 From: Matt Toohey Date: Wed, 5 Jun 2024 16:40:26 +1000 Subject: [PATCH] fix: handle async call not being able to be called --- backend/controller/controller.go | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/backend/controller/controller.go b/backend/controller/controller.go index d2c503c6f8..14f5ec7c5f 100644 --- a/backend/controller/controller.go +++ b/backend/controller/controller.go @@ -1219,19 +1219,21 @@ func (s *Service) executeAsyncCalls(ctx context.Context) (time.Duration, error) Body: call.Request, } resp, err := s.callWithRequest(ctx, connect.NewRequest(req), optional.None[model.RequestKey](), s.config.Advertise.String()) - if err != nil { - return 0, fmt.Errorf("async call failed: %w", err) - } var callResult either.Either[[]byte, string] - if perr := resp.Msg.GetError(); perr != nil { + failed := false + if err != nil { + logger.Warnf("Async call could not be called: %v", err) + callResult = either.RightOf[[]byte](err.Error()) + failed = true + } else if perr := resp.Msg.GetError(); perr != nil { logger.Warnf("Async call failed: %s", perr.Message) callResult = either.RightOf[[]byte](perr.Message) + failed = true } else { logger.Debugf("Async call succeeded") callResult = either.LeftOf[string](resp.Msg.GetBody()) } err = s.dal.CompleteAsyncCall(ctx, call, callResult, func(tx *dal.Tx) error { - failed := resp.Msg.GetError() != nil if failed && call.RemainingAttempts > 0 { // Will retry, do not propagate failure yet. return nil