talos/pkg/cluster/check/reporter.go
Utku Ozdemir 0b339a9dc5
feat: track progress of action API calls
Track the progress of the long-running actions `reboot`, `reset`, `upgrade` and `shutdown` on the client side by default, unless `--no-wait=true` is specified.

Use the events API to follow the events using the actor ID of the action and display it using an stderr reporter with a spinner.

Closes siderolabs/talos#5499.

Signed-off-by: Utku Ozdemir <utku.ozdemir@siderolabs.com>
2022-08-29 22:54:40 +02:00

58 lines
1.4 KiB
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/.
package check
import (
"fmt"
"strings"
"github.com/talos-systems/talos/pkg/conditions"
"github.com/talos-systems/talos/pkg/reporter"
)
// ConditionReporter is a reporter that reports conditions to a reporter.Reporter.
type ConditionReporter struct {
w *reporter.Reporter
}
// Update reports a condition to the reporter.
func (r *ConditionReporter) Update(condition conditions.Condition) {
r.w.Report(conditionToUpdate(condition))
}
// StderrReporter returns console reporter with stderr output.
func StderrReporter() *ConditionReporter {
return &ConditionReporter{
w: reporter.New(),
}
}
func conditionToUpdate(condition conditions.Condition) reporter.Update {
line := strings.TrimSpace(fmt.Sprintf("waiting for %s", condition.String()))
switch {
case strings.HasSuffix(line, "..."):
return reporter.Update{
Message: line,
Status: reporter.StatusRunning,
}
case strings.HasSuffix(line, conditions.OK):
return reporter.Update{
Message: line,
Status: reporter.StatusSucceeded,
}
case strings.HasSuffix(line, conditions.ErrSkipAssertion.Error()):
return reporter.Update{
Message: line,
Status: reporter.StatusSkip,
}
default:
return reporter.Update{
Message: line,
Status: reporter.StatusError,
}
}
}