mirror of
				https://github.com/k3s-io/kubernetes.git
				synced 2025-10-31 05:40:42 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			224 lines
		
	
	
		
			7.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			224 lines
		
	
	
		
			7.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| /*
 | |
| Copyright 2019 The Kubernetes Authors.
 | |
| 
 | |
| Licensed under the Apache License, Version 2.0 (the "License");
 | |
| you may not use this file except in compliance with the License.
 | |
| You may obtain a copy of the License at
 | |
| 
 | |
|     http://www.apache.org/licenses/LICENSE-2.0
 | |
| 
 | |
| Unless required by applicable law or agreed to in writing, software
 | |
| distributed under the License is distributed on an "AS IS" BASIS,
 | |
| WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| See the License for the specific language governing permissions and
 | |
| limitations under the License.
 | |
| */
 | |
| 
 | |
| package collectors
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"strings"
 | |
| 	"testing"
 | |
| 	"time"
 | |
| 
 | |
| 	"github.com/golang/mock/gomock"
 | |
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
 | |
| 	"k8s.io/component-base/metrics/testutil"
 | |
| 	statsapi "k8s.io/kubelet/pkg/apis/stats/v1alpha1"
 | |
| 	summaryprovidertest "k8s.io/kubernetes/pkg/kubelet/server/stats/testing"
 | |
| )
 | |
| 
 | |
| func TestCollectResourceMetrics(t *testing.T) {
 | |
| 	// a static timestamp: 2021-06-23 05:11:18.302091597 +0800
 | |
| 	staticTimestamp := time.Unix(0, 1624396278302091597)
 | |
| 	testTime := metav1.NewTime(staticTimestamp)
 | |
| 	interestedMetrics := []string{
 | |
| 		"scrape_error",
 | |
| 		"node_cpu_usage_seconds_total",
 | |
| 		"node_memory_working_set_bytes",
 | |
| 		"container_cpu_usage_seconds_total",
 | |
| 		"container_memory_working_set_bytes",
 | |
| 		"container_start_time_seconds",
 | |
| 		"pod_cpu_usage_seconds_total",
 | |
| 		"pod_memory_working_set_bytes",
 | |
| 	}
 | |
| 	mockCtrl := gomock.NewController(t)
 | |
| 	defer mockCtrl.Finish()
 | |
| 
 | |
| 	tests := []struct {
 | |
| 		name            string
 | |
| 		summary         *statsapi.Summary
 | |
| 		summaryErr      error
 | |
| 		expectedMetrics string
 | |
| 	}{
 | |
| 		{
 | |
| 			name:       "error getting summary",
 | |
| 			summary:    nil,
 | |
| 			summaryErr: fmt.Errorf("failed to get summary"),
 | |
| 			expectedMetrics: `
 | |
| 				# HELP scrape_error [ALPHA] 1 if there was an error while getting container metrics, 0 otherwise
 | |
| 				# TYPE scrape_error gauge
 | |
| 				scrape_error 1
 | |
| 			`,
 | |
| 		},
 | |
| 		{
 | |
| 			name: "arbitrary node metrics",
 | |
| 			summary: &statsapi.Summary{
 | |
| 				Node: statsapi.NodeStats{
 | |
| 					CPU: &statsapi.CPUStats{
 | |
| 						Time:                 testTime,
 | |
| 						UsageCoreNanoSeconds: uint64Ptr(10000000000),
 | |
| 					},
 | |
| 					Memory: &statsapi.MemoryStats{
 | |
| 						Time:            testTime,
 | |
| 						WorkingSetBytes: uint64Ptr(1000),
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 			summaryErr: nil,
 | |
| 			expectedMetrics: `
 | |
| 				# HELP node_cpu_usage_seconds_total [ALPHA] Cumulative cpu time consumed by the node in core-seconds
 | |
| 				# TYPE node_cpu_usage_seconds_total counter
 | |
| 				node_cpu_usage_seconds_total 10 1624396278302
 | |
| 				# HELP node_memory_working_set_bytes [ALPHA] Current working set of the node in bytes
 | |
| 				# TYPE node_memory_working_set_bytes gauge
 | |
| 				node_memory_working_set_bytes 1000 1624396278302
 | |
| 				# HELP scrape_error [ALPHA] 1 if there was an error while getting container metrics, 0 otherwise
 | |
| 				# TYPE scrape_error gauge
 | |
| 				scrape_error 0
 | |
| 			`,
 | |
| 		},
 | |
| 		{
 | |
| 			name: "arbitrary container metrics for different container, pods and namespaces",
 | |
| 			summary: &statsapi.Summary{
 | |
| 				Pods: []statsapi.PodStats{
 | |
| 					{
 | |
| 						PodRef: statsapi.PodReference{
 | |
| 							Name:      "pod_a",
 | |
| 							Namespace: "namespace_a",
 | |
| 						},
 | |
| 						Containers: []statsapi.ContainerStats{
 | |
| 							{
 | |
| 								Name:      "container_a",
 | |
| 								StartTime: metav1.NewTime(staticTimestamp.Add(-30 * time.Second)),
 | |
| 								CPU: &statsapi.CPUStats{
 | |
| 									Time:                 testTime,
 | |
| 									UsageCoreNanoSeconds: uint64Ptr(10000000000),
 | |
| 								},
 | |
| 								Memory: &statsapi.MemoryStats{
 | |
| 									Time:            testTime,
 | |
| 									WorkingSetBytes: uint64Ptr(1000),
 | |
| 								},
 | |
| 							},
 | |
| 							{
 | |
| 								Name:      "container_b",
 | |
| 								StartTime: metav1.NewTime(staticTimestamp.Add(-2 * time.Minute)),
 | |
| 								CPU: &statsapi.CPUStats{
 | |
| 									Time:                 testTime,
 | |
| 									UsageCoreNanoSeconds: uint64Ptr(10000000000),
 | |
| 								},
 | |
| 								Memory: &statsapi.MemoryStats{
 | |
| 									Time:            testTime,
 | |
| 									WorkingSetBytes: uint64Ptr(1000),
 | |
| 								},
 | |
| 							},
 | |
| 						},
 | |
| 					},
 | |
| 					{
 | |
| 						PodRef: statsapi.PodReference{
 | |
| 							Name:      "pod_b",
 | |
| 							Namespace: "namespace_b",
 | |
| 						},
 | |
| 						Containers: []statsapi.ContainerStats{
 | |
| 							{
 | |
| 								Name:      "container_a",
 | |
| 								StartTime: metav1.NewTime(staticTimestamp.Add(-10 * time.Minute)),
 | |
| 								CPU: &statsapi.CPUStats{
 | |
| 									Time:                 testTime,
 | |
| 									UsageCoreNanoSeconds: uint64Ptr(10000000000),
 | |
| 								},
 | |
| 								Memory: &statsapi.MemoryStats{
 | |
| 									Time:            testTime,
 | |
| 									WorkingSetBytes: uint64Ptr(1000),
 | |
| 								},
 | |
| 							},
 | |
| 						},
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 			summaryErr: nil,
 | |
| 			expectedMetrics: `
 | |
| 				# HELP scrape_error [ALPHA] 1 if there was an error while getting container metrics, 0 otherwise
 | |
| 				# TYPE scrape_error gauge
 | |
| 				scrape_error 0
 | |
| 				# HELP container_cpu_usage_seconds_total [ALPHA] Cumulative cpu time consumed by the container in core-seconds
 | |
| 				# TYPE container_cpu_usage_seconds_total counter
 | |
| 				container_cpu_usage_seconds_total{container="container_a",namespace="namespace_a",pod="pod_a"} 10 1624396278302
 | |
| 				container_cpu_usage_seconds_total{container="container_a",namespace="namespace_b",pod="pod_b"} 10 1624396278302
 | |
| 				container_cpu_usage_seconds_total{container="container_b",namespace="namespace_a",pod="pod_a"} 10 1624396278302
 | |
| 				# HELP container_memory_working_set_bytes [ALPHA] Current working set of the container in bytes
 | |
| 				# TYPE container_memory_working_set_bytes gauge
 | |
| 				container_memory_working_set_bytes{container="container_a",namespace="namespace_a",pod="pod_a"} 1000 1624396278302
 | |
| 				container_memory_working_set_bytes{container="container_a",namespace="namespace_b",pod="pod_b"} 1000 1624396278302
 | |
| 				container_memory_working_set_bytes{container="container_b",namespace="namespace_a",pod="pod_a"} 1000 1624396278302
 | |
| 				# HELP container_start_time_seconds [ALPHA] Start time of the container since unix epoch in seconds
 | |
| 				# TYPE container_start_time_seconds gauge
 | |
| 				container_start_time_seconds{container="container_a",namespace="namespace_a",pod="pod_a"} 1.6243962483020916e+09 1624396248302
 | |
| 				container_start_time_seconds{container="container_a",namespace="namespace_b",pod="pod_b"} 1.6243956783020916e+09 1624395678302
 | |
| 				container_start_time_seconds{container="container_b",namespace="namespace_a",pod="pod_a"} 1.6243961583020916e+09 1624396158302
 | |
| 			`,
 | |
| 		},
 | |
| 		{
 | |
| 			name: "arbitrary pod metrics",
 | |
| 			summary: &statsapi.Summary{
 | |
| 				Pods: []statsapi.PodStats{
 | |
| 					{
 | |
| 						PodRef: statsapi.PodReference{
 | |
| 							Name:      "pod_a",
 | |
| 							Namespace: "namespace_a",
 | |
| 						},
 | |
| 						CPU: &statsapi.CPUStats{
 | |
| 							Time:                 testTime,
 | |
| 							UsageCoreNanoSeconds: uint64Ptr(10000000000),
 | |
| 						},
 | |
| 						Memory: &statsapi.MemoryStats{
 | |
| 							Time:            testTime,
 | |
| 							WorkingSetBytes: uint64Ptr(1000),
 | |
| 						},
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 			summaryErr: nil,
 | |
| 			expectedMetrics: `
 | |
| 				# HELP scrape_error [ALPHA] 1 if there was an error while getting container metrics, 0 otherwise
 | |
| 				# TYPE scrape_error gauge
 | |
| 				scrape_error 0
 | |
| 				# HELP pod_cpu_usage_seconds_total [ALPHA] Cumulative cpu time consumed by the pod in core-seconds
 | |
| 				# TYPE pod_cpu_usage_seconds_total counter
 | |
| 				pod_cpu_usage_seconds_total{namespace="namespace_a",pod="pod_a"} 10 1624396278302
 | |
| 				# HELP pod_memory_working_set_bytes [ALPHA] Current working set of the pod in bytes
 | |
| 				# TYPE pod_memory_working_set_bytes gauge
 | |
| 				pod_memory_working_set_bytes{namespace="namespace_a",pod="pod_a"} 1000 1624396278302
 | |
| 			`,
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	for _, test := range tests {
 | |
| 		tc := test
 | |
| 		t.Run(tc.name, func(t *testing.T) {
 | |
| 			provider := summaryprovidertest.NewMockSummaryProvider(mockCtrl)
 | |
| 			provider.EXPECT().GetCPUAndMemoryStats().Return(tc.summary, tc.summaryErr).AnyTimes()
 | |
| 			collector := NewResourceMetricsCollector(provider)
 | |
| 
 | |
| 			if err := testutil.CustomCollectAndCompare(collector, strings.NewReader(tc.expectedMetrics), interestedMetrics...); err != nil {
 | |
| 				t.Fatal(err)
 | |
| 			}
 | |
| 		})
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func uint64Ptr(u uint64) *uint64 {
 | |
| 	return &u
 | |
| }
 |