mirror of https://github.com/k3s-io/k3s
143 lines
4.8 KiB
Go
143 lines
4.8 KiB
Go
/*
|
|
Copyright 2016 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 stats
|
|
|
|
import (
|
|
"testing"
|
|
"time"
|
|
|
|
fuzz "github.com/google/gofuzz"
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"k8s.io/api/core/v1"
|
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
|
statsapi "k8s.io/kubernetes/pkg/kubelet/apis/stats/v1alpha1"
|
|
"k8s.io/kubernetes/pkg/kubelet/cm"
|
|
statstest "k8s.io/kubernetes/pkg/kubelet/server/stats/testing"
|
|
)
|
|
|
|
func TestSummaryProvider(t *testing.T) {
|
|
var (
|
|
podStats = []statsapi.PodStats{
|
|
{
|
|
PodRef: statsapi.PodReference{Name: "test-pod", Namespace: "test-namespace", UID: "UID_test-pod"},
|
|
StartTime: metav1.NewTime(time.Now()),
|
|
Containers: []statsapi.ContainerStats{*getContainerStats()},
|
|
Network: getNetworkStats(),
|
|
VolumeStats: []statsapi.VolumeStats{*getVolumeStats()},
|
|
},
|
|
}
|
|
imageFsStats = getFsStats()
|
|
rootFsStats = getFsStats()
|
|
node = &v1.Node{ObjectMeta: metav1.ObjectMeta{Name: "test-node"}}
|
|
nodeConfig = cm.NodeConfig{
|
|
RuntimeCgroupsName: "/runtime",
|
|
SystemCgroupsName: "/system",
|
|
KubeletCgroupsName: "/kubelet",
|
|
}
|
|
cgroupStatsMap = map[string]struct {
|
|
cs *statsapi.ContainerStats
|
|
ns *statsapi.NetworkStats
|
|
}{
|
|
"/": {cs: getContainerStats(), ns: getNetworkStats()},
|
|
"/runtime": {cs: getContainerStats(), ns: getNetworkStats()},
|
|
"/system": {cs: getContainerStats(), ns: getNetworkStats()},
|
|
"/kubelet": {cs: getContainerStats(), ns: getNetworkStats()},
|
|
}
|
|
)
|
|
|
|
assert := assert.New(t)
|
|
|
|
mockStatsProvider := new(statstest.StatsProvider)
|
|
mockStatsProvider.
|
|
On("GetNode").Return(node, nil).
|
|
On("GetNodeConfig").Return(nodeConfig).
|
|
On("ListPodStats").Return(podStats, nil).
|
|
On("ImageFsStats").Return(imageFsStats, nil).
|
|
On("RootFsStats").Return(rootFsStats, nil).
|
|
On("GetCgroupStats", "/").Return(cgroupStatsMap["/"].cs, cgroupStatsMap["/"].ns, nil).
|
|
On("GetCgroupStats", "/runtime").Return(cgroupStatsMap["/runtime"].cs, cgroupStatsMap["/runtime"].ns, nil).
|
|
On("GetCgroupStats", "/system").Return(cgroupStatsMap["/system"].cs, cgroupStatsMap["/system"].ns, nil).
|
|
On("GetCgroupStats", "/kubelet").Return(cgroupStatsMap["/kubelet"].cs, cgroupStatsMap["/kubelet"].ns, nil)
|
|
|
|
provider := NewSummaryProvider(mockStatsProvider)
|
|
summary, err := provider.Get()
|
|
assert.NoError(err)
|
|
|
|
assert.Equal(summary.Node.NodeName, "test-node")
|
|
assert.Equal(summary.Node.StartTime, cgroupStatsMap["/"].cs.StartTime)
|
|
assert.Equal(summary.Node.CPU, cgroupStatsMap["/"].cs.CPU)
|
|
assert.Equal(summary.Node.Memory, cgroupStatsMap["/"].cs.Memory)
|
|
assert.Equal(summary.Node.Network, cgroupStatsMap["/"].ns)
|
|
assert.Equal(summary.Node.Fs, rootFsStats)
|
|
assert.Equal(summary.Node.Runtime, &statsapi.RuntimeStats{ImageFs: imageFsStats})
|
|
|
|
assert.Equal(len(summary.Node.SystemContainers), 3)
|
|
assert.Contains(summary.Node.SystemContainers,
|
|
statsapi.ContainerStats{
|
|
Name: "kubelet",
|
|
StartTime: cgroupStatsMap["/kubelet"].cs.StartTime,
|
|
CPU: cgroupStatsMap["/kubelet"].cs.CPU,
|
|
Memory: cgroupStatsMap["/kubelet"].cs.Memory,
|
|
UserDefinedMetrics: cgroupStatsMap["/kubelet"].cs.UserDefinedMetrics,
|
|
},
|
|
statsapi.ContainerStats{
|
|
Name: "system",
|
|
StartTime: cgroupStatsMap["/system"].cs.StartTime,
|
|
CPU: cgroupStatsMap["/system"].cs.CPU,
|
|
Memory: cgroupStatsMap["/system"].cs.Memory,
|
|
UserDefinedMetrics: cgroupStatsMap["/system"].cs.UserDefinedMetrics,
|
|
},
|
|
statsapi.ContainerStats{
|
|
Name: "runtime",
|
|
StartTime: cgroupStatsMap["/runtime"].cs.StartTime,
|
|
CPU: cgroupStatsMap["/runtime"].cs.CPU,
|
|
Memory: cgroupStatsMap["/runtime"].cs.Memory,
|
|
UserDefinedMetrics: cgroupStatsMap["/runtime"].cs.UserDefinedMetrics,
|
|
},
|
|
)
|
|
assert.Equal(summary.Pods, podStats)
|
|
}
|
|
|
|
func getFsStats() *statsapi.FsStats {
|
|
f := fuzz.New().NilChance(0)
|
|
v := &statsapi.FsStats{}
|
|
f.Fuzz(v)
|
|
return v
|
|
}
|
|
|
|
func getContainerStats() *statsapi.ContainerStats {
|
|
f := fuzz.New().NilChance(0)
|
|
v := &statsapi.ContainerStats{}
|
|
f.Fuzz(v)
|
|
return v
|
|
}
|
|
|
|
func getVolumeStats() *statsapi.VolumeStats {
|
|
f := fuzz.New().NilChance(0)
|
|
v := &statsapi.VolumeStats{}
|
|
f.Fuzz(v)
|
|
return v
|
|
}
|
|
|
|
func getNetworkStats() *statsapi.NetworkStats {
|
|
f := fuzz.New().NilChance(0)
|
|
v := &statsapi.NetworkStats{}
|
|
f.Fuzz(v)
|
|
return v
|
|
}
|