mirror of
https://github.com/siderolabs/talos.git
synced 2025-08-08 15:47:04 +02:00
There's a cyclic dependency on siderolink library which imports talos machinery back. We will fix that after we get talos pushed under a new name. Signed-off-by: Andrey Smirnov <andrey.smirnov@talos-systems.com>
53 lines
1.3 KiB
Go
53 lines
1.3 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/.
|
|
|
|
//go:build integration_cli
|
|
|
|
package cli
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"regexp"
|
|
"strings"
|
|
|
|
"github.com/siderolabs/gen/slices"
|
|
|
|
"github.com/siderolabs/talos/internal/integration/base"
|
|
)
|
|
|
|
// DmesgSuite verifies dmesg command.
|
|
type DmesgSuite struct {
|
|
base.CLISuite
|
|
}
|
|
|
|
// SuiteName ...
|
|
func (suite *DmesgSuite) SuiteName() string {
|
|
return "cli.DmesgSuite"
|
|
}
|
|
|
|
// TestHasOutput verifies that dmesg is displayed.
|
|
func (suite *DmesgSuite) TestHasOutput() {
|
|
suite.RunCLI([]string{"dmesg", "--nodes", suite.RandomDiscoveredNodeInternalIP()}) // default checks for stdout not empty
|
|
}
|
|
|
|
// TestClusterHasOutput verifies that each node in the cluster has some output.
|
|
func (suite *DmesgSuite) TestClusterHasOutput() {
|
|
nodes := suite.DiscoverNodeInternalIPs(context.TODO())
|
|
suite.Require().NotEmpty(nodes)
|
|
|
|
matchers := slices.Map(nodes, func(node string) base.RunOption {
|
|
return base.StdoutShouldMatch(
|
|
regexp.MustCompile(fmt.Sprintf(`(?m)^%s:`, regexp.QuoteMeta(node))),
|
|
)
|
|
})
|
|
|
|
suite.RunCLI([]string{"--nodes", strings.Join(nodes, ","), "dmesg"},
|
|
matchers...)
|
|
}
|
|
|
|
func init() {
|
|
allSuites = append(allSuites, new(DmesgSuite))
|
|
}
|