mirror of
https://github.com/siderolabs/talos.git
synced 2025-08-10 16:47:04 +02:00
For single node clusters, control plane is unstable after reboot, run health check several times to let it settle down to avoid failures in subsequent checks. Signed-off-by: Andrey Smirnov <smirnov.andrey@gmail.com>
38 lines
823 B
Go
38 lines
823 B
Go
// This Source Code Form is subject to the terms of the Mozilla Public
|
|
// License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
// +build integration
|
|
|
|
package base
|
|
|
|
import (
|
|
"errors"
|
|
|
|
"google.golang.org/grpc/codes"
|
|
"google.golang.org/grpc/status"
|
|
)
|
|
|
|
// IgnoreGRPCUnavailable searches through unwrapped errors and ignores the error if it is grpc.Unavailable.
|
|
func IgnoreGRPCUnavailable(err error) error {
|
|
if err == nil {
|
|
return nil
|
|
}
|
|
|
|
unwrappedErr := err
|
|
|
|
for {
|
|
if s, ok := status.FromError(unwrappedErr); ok && s.Code() == codes.Unavailable {
|
|
// ignore errors if reboot happens before response is fully received
|
|
return nil
|
|
}
|
|
|
|
unwrappedErr = errors.Unwrap(unwrappedErr)
|
|
if unwrappedErr == nil {
|
|
break
|
|
}
|
|
}
|
|
|
|
return err
|
|
}
|