talos/internal/integration/cli/time.go
Andrey Smirnov 17c1474881
test: retry talosctl time call in the tests
As `talosctl time` relies on default time server set in the config, and
our nodes start with `pool.ntp.org`, sometimes request to the timeserver
fails failing the tests.

Retry such errors in the tests to avoid spurious failures.

Signed-off-by: Andrey Smirnov <andrey.smirnov@talos-systems.com>
2021-12-17 20:55:06 +03:00

41 lines
985 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/.
//go:build integration_cli
// +build integration_cli
package cli
import (
"regexp"
"time"
"github.com/talos-systems/go-retry/retry"
"github.com/talos-systems/talos/internal/integration/base"
)
// TimeSuite verifies dmesg command.
type TimeSuite struct {
base.CLISuite
}
// SuiteName ...
func (suite *TimeSuite) SuiteName() string {
return "cli.TimeSuite"
}
// TestDefault runs default time check.
func (suite *TimeSuite) TestDefault() {
suite.RunCLI([]string{"time", "--nodes", suite.RandomDiscoveredNode()},
base.StdoutShouldMatch(regexp.MustCompile(`NTP-SERVER`)),
base.StdoutShouldMatch(regexp.MustCompile(`UTC`)),
base.WithRetry(retry.Constant(time.Minute, retry.WithUnits(time.Second))),
)
}
func init() {
allSuites = append(allSuites, new(TimeSuite))
}