mirror of
				https://github.com/siderolabs/talos.git
				synced 2025-11-04 02:11:12 +01:00 
			
		
		
		
	Fix all discovered issues. Signed-off-by: Dmitriy Matrenichev <dmitry.matrenichev@siderolabs.com>
		
			
				
	
	
		
			65 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
		
			1.7 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 (
 | 
						|
	"fmt"
 | 
						|
	"regexp"
 | 
						|
	"strings"
 | 
						|
 | 
						|
	"github.com/siderolabs/talos/internal/integration/base"
 | 
						|
)
 | 
						|
 | 
						|
// LogsSuite verifies logs command.
 | 
						|
type LogsSuite struct {
 | 
						|
	base.CLISuite
 | 
						|
}
 | 
						|
 | 
						|
// SuiteName ...
 | 
						|
func (suite *LogsSuite) SuiteName() string {
 | 
						|
	return "cli.LogsSuite"
 | 
						|
}
 | 
						|
 | 
						|
// TestServiceLogs verifies that logs are displayed.
 | 
						|
func (suite *LogsSuite) TestServiceLogs() {
 | 
						|
	suite.RunCLI([]string{"logs", "kubelet", "--nodes", suite.RandomDiscoveredNodeInternalIP()}) // default checks for stdout not empty
 | 
						|
}
 | 
						|
 | 
						|
// TestTailLogs verifies that logs can be displayed with tail lines.
 | 
						|
func (suite *LogsSuite) TestTailLogs() {
 | 
						|
	node := suite.RandomDiscoveredNodeInternalIP()
 | 
						|
 | 
						|
	// run some machined API calls to produce enough log lines
 | 
						|
	for range 10 {
 | 
						|
		suite.RunCLI([]string{"-n", node, "version"})
 | 
						|
	}
 | 
						|
 | 
						|
	suite.RunCLI([]string{"logs", "apid", "-n", node, "--tail", "5"},
 | 
						|
		base.StdoutMatchFunc(func(stdout string) error {
 | 
						|
			lines := strings.Count(stdout, "\n")
 | 
						|
			if lines != 5 {
 | 
						|
				return fmt.Errorf("expected %d lines, found %d lines", 5, lines)
 | 
						|
			}
 | 
						|
 | 
						|
			return nil
 | 
						|
		}))
 | 
						|
}
 | 
						|
 | 
						|
// TestServiceNotFound verifies that logs displays an error if service is not found.
 | 
						|
func (suite *LogsSuite) TestServiceNotFound() {
 | 
						|
	suite.RunCLI([]string{"logs", "--nodes", suite.RandomDiscoveredNodeInternalIP(), "servicenotfound"},
 | 
						|
		base.StdoutEmpty(),
 | 
						|
		base.StderrNotEmpty(),
 | 
						|
		base.StderrShouldMatch(regexp.MustCompile(`ERROR:.+ log "servicenotfound" was not registered`)),
 | 
						|
		base.ShouldFail(),
 | 
						|
	)
 | 
						|
}
 | 
						|
 | 
						|
func init() {
 | 
						|
	allSuites = append(allSuites, new(LogsSuite))
 | 
						|
}
 |