2023-01-27 21:37:20 +00:00
|
|
|
// Copyright (c) Tailscale Inc & AUTHORS
|
|
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
2021-04-29 22:43:02 +01:00
|
|
|
|
|
|
|
// Package tstest provides utilities for use in unit tests.
|
|
|
|
package tstest
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"tailscale.com/logtail/backoff"
|
|
|
|
"tailscale.com/types/logger"
|
|
|
|
)
|
|
|
|
|
|
|
|
// WaitFor retries try for up to maxWait.
|
|
|
|
// It returns nil once try returns nil the first time.
|
|
|
|
// If maxWait passes without success, it returns try's last error.
|
|
|
|
func WaitFor(maxWait time.Duration, try func() error) error {
|
|
|
|
bo := backoff.NewBackoff("wait-for", logger.Discard, maxWait/4)
|
|
|
|
deadline := time.Now().Add(maxWait)
|
|
|
|
var err error
|
|
|
|
for time.Now().Before(deadline) {
|
|
|
|
err = try()
|
|
|
|
if err == nil {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
bo.BackOff(context.Background(), err)
|
|
|
|
}
|
|
|
|
return err
|
|
|
|
}
|