mirror of
				https://github.com/siderolabs/talos.git
				synced 2025-10-31 16:31:13 +01: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>
		
			
				
	
	
		
			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 i := 0; i < 10; i++ {
 | |
| 		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))
 | |
| }
 |