Skip to content

Commit

Permalink
Merge pull request #219 from openshift-kni/knidebug-eph-stor-4.16
Browse files Browse the repository at this point in the history
[KNI][release-4.16] log ephemeral-storage resources
  • Loading branch information
ffromani authored Jun 25, 2024
2 parents 9d468d5 + 49d70b5 commit 1a5f596
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 33 deletions.
16 changes: 12 additions & 4 deletions pkg-kni/knidebug/knidebug.go
Original file line number Diff line number Diff line change
Expand Up @@ -78,14 +78,22 @@ func (kd *KNIDebug) Filter(ctx context.Context, cycleState *framework.CycleState
return nil // must never fail
}

func frameworkResourceToLoggable(pod *corev1.Pod, req *framework.Resource) []interface{} {
func frameworkResourceToLoggable(req *framework.Resource) []interface{} {
items := []interface{}{
"pod", klog.KObj(pod).String(),
"podUID", podGetUID(pod),
"cpu", humanCPU(req.MilliCPU),
"memory", humanMemory(req.Memory),
}

if req.EphemeralStorage > 0 {
items = append(items,
"ephemeral-storage", humanMemory(req.EphemeralStorage),
)
}

if len(req.ScalarResources) == 0 {
return items
}

resNames := []string{}
for resName := range req.ScalarResources {
resNames = append(resNames, string(resName))
Expand Down Expand Up @@ -172,7 +180,7 @@ func checkRequest(lh logr.Logger, pod *corev1.Pod, nodeInfo *framework.NodeInfo)
lh.Info("target resource requests none")
return
}
lh.Info("target resource requests", frameworkResourceToLoggable(pod, req)...)
lh.Info("target resource requests", frameworkResourceToLoggable(req)...)

violations := 0
if availCPU := (nodeInfo.Allocatable.MilliCPU - nodeInfo.Requested.MilliCPU); req.MilliCPU > availCPU {
Expand Down
61 changes: 32 additions & 29 deletions pkg-kni/knidebug/knidebug_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -35,71 +35,61 @@ import (
func TestFrameworkResourceToLoggable(t *testing.T) {
tests := []struct {
name string
pod *corev1.Pod
resources *framework.Resource
expected string
}{
{
name: "empty",
pod: nil,
resources: &framework.Resource{},
expected: ` pod="" podUID="<nil>" cpu="0 (0)" memory="0 (0 B)"`,
},
{
name: "only pod",
pod: makePod("uid0", "namespace0", "name0"),
resources: &framework.Resource{},
expected: ` pod="namespace0/name0" podUID="uid0" cpu="0 (0)" memory="0 (0 B)"`,
expected: ` cpu="0 (0)" memory="0 (0 B)"`,
},
{
name: "only cpus",
pod: makePod("uid1", "namespace1", "name1"),
resources: &framework.Resource{
MilliCPU: 16000,
},
expected: ` pod="namespace1/name1" podUID="uid1" cpu="16000 (16)" memory="0 (0 B)"`,
expected: ` cpu="16000 (16)" memory="0 (0 B)"`,
},
{
name: "only Memory",
pod: makePod("uid2", "namespace2", "name2"),
resources: &framework.Resource{
Memory: 16 * 1024 * 1024 * 1024,
},
expected: ` pod="namespace2/name2" podUID="uid2" cpu="0 (0)" memory="17179869184 (16 GiB)"`,
expected: ` cpu="0 (0)" memory="17179869184 (16 GiB)"`,
},
{
name: "cpus and Memory, no pod",
pod: nil,
name: "cpus and Memory",
resources: &framework.Resource{
MilliCPU: 24000,
Memory: 16 * 1024 * 1024 * 1024,
},
expected: ` pod="" podUID="<nil>" cpu="24000 (24)" memory="17179869184 (16 GiB)"`,
expected: ` cpu="24000 (24)" memory="17179869184 (16 GiB)"`,
},
{
name: "cpus and Memory",
pod: makePod("uid3", "namespace3", "name3"),
name: "cpus, Memory, hugepages-2Mi",
resources: &framework.Resource{
MilliCPU: 24000,
Memory: 16 * 1024 * 1024 * 1024,
ScalarResources: map[corev1.ResourceName]int64{
corev1.ResourceName("hugepages-2Mi"): 1 * 1024 * 1024 * 1024,
},
},
expected: ` pod="namespace3/name3" podUID="uid3" cpu="24000 (24)" memory="17179869184 (16 GiB)"`,
expected: ` cpu="24000 (24)" memory="17179869184 (16 GiB)" hugepages-2Mi="1073741824 (1.0 GiB)"`,
},
{
name: "cpus, Memory, hugepages-2Mi",
pod: makePod("uid4", "namespace4", "name4"),
name: "cpus, Memory, hugepages-2Mi, ephemeral-storage",
resources: &framework.Resource{
MilliCPU: 24000,
Memory: 16 * 1024 * 1024 * 1024,
MilliCPU: 24000,
Memory: 16 * 1024 * 1024 * 1024,
EphemeralStorage: 128 * 1024 * 1204 * 1024,
ScalarResources: map[corev1.ResourceName]int64{
corev1.ResourceName("hugepages-2Mi"): 1 * 1024 * 1024 * 1024,
},
},
expected: ` pod="namespace4/name4" podUID="uid4" cpu="24000 (24)" memory="17179869184 (16 GiB)" hugepages-2Mi="1073741824 (1.0 GiB)"`,
expected: ` cpu="24000 (24)" memory="17179869184 (16 GiB)" ephemeral-storage="161598144512 (150 GiB)" hugepages-2Mi="1073741824 (1.0 GiB)"`,
},
{
name: "cpus, Memory, hugepages-2Mi, hugepages-1Gi",
pod: makePod("uid5", "namespace5", "name5"),
resources: &framework.Resource{
MilliCPU: 24000,
Memory: 16 * 1024 * 1024 * 1024,
Expand All @@ -108,11 +98,10 @@ func TestFrameworkResourceToLoggable(t *testing.T) {
corev1.ResourceName("hugepages-1Gi"): 2 * 1024 * 1024 * 1024,
},
},
expected: ` pod="namespace5/name5" podUID="uid5" cpu="24000 (24)" memory="17179869184 (16 GiB)" hugepages-1Gi="2147483648 (2.0 GiB)" hugepages-2Mi="1073741824 (1.0 GiB)"`,
expected: ` cpu="24000 (24)" memory="17179869184 (16 GiB)" hugepages-1Gi="2147483648 (2.0 GiB)" hugepages-2Mi="1073741824 (1.0 GiB)"`,
},
{
name: "cpus, Memory, hugepages-2Mi, devices",
pod: makePod("uid6", "namespace6", "name6"),
resources: &framework.Resource{
MilliCPU: 24000,
Memory: 16 * 1024 * 1024 * 1024,
Expand All @@ -122,14 +111,28 @@ func TestFrameworkResourceToLoggable(t *testing.T) {
corev1.ResourceName("awesome.net/gpu"): 4,
},
},
expected: ` pod="namespace6/name6" podUID="uid6" cpu="24000 (24)" memory="17179869184 (16 GiB)" awesome.net/gpu="4" example.com/netdevice="16" hugepages-2Mi="1073741824 (1.0 GiB)"`,
expected: ` cpu="24000 (24)" memory="17179869184 (16 GiB)" awesome.net/gpu="4" example.com/netdevice="16" hugepages-2Mi="1073741824 (1.0 GiB)"`,
},
{
name: "cpus, Memory, hugepages-2Mi, devices, ephemeral-storage",
resources: &framework.Resource{
MilliCPU: 24000,
Memory: 16 * 1024 * 1024 * 1024,
EphemeralStorage: 128 * 1024 * 1024 * 1024,
ScalarResources: map[corev1.ResourceName]int64{
corev1.ResourceName("hugepages-2Mi"): 1 * 1024 * 1024 * 1024,
corev1.ResourceName("example.com/netdevice"): 16,
corev1.ResourceName("awesome.net/gpu"): 4,
},
},
expected: ` cpu="24000 (24)" memory="17179869184 (16 GiB)" ephemeral-storage="137438953472 (128 GiB)" awesome.net/gpu="4" example.com/netdevice="16" hugepages-2Mi="1073741824 (1.0 GiB)"`,
},
}

for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
var buf bytes.Buffer
keysAndValues := frameworkResourceToLoggable(tt.pod, tt.resources)
keysAndValues := frameworkResourceToLoggable(tt.resources)
kvListFormat(&buf, keysAndValues...)
got := buf.String()
if got != tt.expected {
Expand Down

0 comments on commit 1a5f596

Please sign in to comment.