From 02e4ec8ce7e56598906ea3a39ff5c44b9120922e Mon Sep 17 00:00:00 2001 From: Jernej Kos Date: Tue, 2 Jun 2020 09:50:18 +0200 Subject: [PATCH] go/runtime/host/sandbox: Retry Call in case the runtime is not yet ready --- .changelog/2967.bugfix.md | 1 + go/runtime/host/sandbox/sandbox.go | 27 +++++++++++++++++++-------- 2 files changed, 20 insertions(+), 8 deletions(-) create mode 100644 .changelog/2967.bugfix.md diff --git a/.changelog/2967.bugfix.md b/.changelog/2967.bugfix.md new file mode 100644 index 00000000000..2b8b73bdf01 --- /dev/null +++ b/.changelog/2967.bugfix.md @@ -0,0 +1 @@ +go/runtime/host/sandbox: Retry Call in case the runtime is not yet ready diff --git a/go/runtime/host/sandbox/sandbox.go b/go/runtime/host/sandbox/sandbox.go index cd76bda458c..8c578a88095 100644 --- a/go/runtime/host/sandbox/sandbox.go +++ b/go/runtime/host/sandbox/sandbox.go @@ -98,15 +98,26 @@ func (r *sandboxedRuntime) ID() common.Namespace { } // Implements host.Runtime. -func (r *sandboxedRuntime) Call(ctx context.Context, body *protocol.Body) (*protocol.Body, error) { - r.RLock() - conn := r.conn - r.RUnlock() - - if conn == nil { - return nil, fmt.Errorf("runtime is not ready") +func (r *sandboxedRuntime) Call(ctx context.Context, body *protocol.Body) (rsp *protocol.Body, err error) { + callFn := func() error { + r.RLock() + conn := r.conn + r.RUnlock() + + if conn == nil { + return fmt.Errorf("runtime is not ready") + } + rsp, err = r.conn.Call(ctx, body) + if err != nil { + // All protocol-level errors are permanent. + return backoff.Permanent(err) + } + return nil } - return r.conn.Call(ctx, body) + + // Retry call in case the runtime is not yet ready. + err = backoff.Retry(callFn, backoff.WithContext(backoff.NewExponentialBackOff(), ctx)) + return } // Implements host.Runtime.