Skip to content

Commit

Permalink
Add nil check and add unit test
Browse files Browse the repository at this point in the history
  • Loading branch information
payall4u committed Nov 29, 2023
1 parent 7be30c9 commit 008474b
Show file tree
Hide file tree
Showing 3 changed files with 44 additions and 19 deletions.
3 changes: 1 addition & 2 deletions pkg/ensurance/analyzer/analyzer.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,6 @@ import (
"strings"
"time"

"github.com/gocrane/crane/pkg/ensurance/util"

v1 "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/labels"
Expand All @@ -29,6 +27,7 @@ import (
ecache "github.com/gocrane/crane/pkg/ensurance/cache"
"github.com/gocrane/crane/pkg/ensurance/executor"
"github.com/gocrane/crane/pkg/ensurance/executor/podinfo"
"github.com/gocrane/crane/pkg/ensurance/util"
"github.com/gocrane/crane/pkg/known"
"github.com/gocrane/crane/pkg/metrics"
"github.com/gocrane/crane/pkg/utils"
Expand Down
20 changes: 12 additions & 8 deletions pkg/webhooks/pod/mutating.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,17 +4,17 @@ import (
"context"
"fmt"

"github.com/gocrane/crane/pkg/ensurance/util"
"github.com/pkg/errors"
corev1 "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/labels"

corev1 "k8s.io/api/core/v1"
"k8s.io/apimachinery/pkg/runtime"
"k8s.io/klog/v2"

"github.com/gocrane/api/ensurance/v1alpha1"

"github.com/gocrane/crane/pkg/ensurance/config"
"github.com/gocrane/crane/pkg/ensurance/util"
)

type MutatingAdmission struct {
Expand All @@ -38,11 +38,7 @@ func (m *MutatingAdmission) Default(ctx context.Context, obj runtime.Object) err

klog.V(2).Infof("Mutating started for pod %s/%s", pod.Namespace, pod.Name)

if m.Config == nil || !m.Config.QOSInitializer.Enable {
return nil
}

if pod.Labels == nil {
if !m.available() {
return nil
}

Expand Down Expand Up @@ -76,6 +72,7 @@ func (m *MutatingAdmission) Default(ctx context.Context, obj runtime.Object) err
klog.V(2).Infof("Injection skipped: not a low CPUPriority pod, qos %s", qos.Name)
return nil
}

for _, container := range pod.Spec.InitContainers {
if container.Name == m.Config.QOSInitializer.InitContainerTemplate.Name {
klog.V(2).Infof("Injection skipped: pod has initializerContainer already")
Expand All @@ -102,3 +99,10 @@ func (m *MutatingAdmission) Default(ctx context.Context, obj runtime.Object) err

return nil
}

func (m *MutatingAdmission) available() bool {
return m.Config != nil &&
m.Config.QOSInitializer.Enable &&
m.Config.QOSInitializer.InitContainerTemplate != nil &&
m.Config.QOSInitializer.VolumeTemplate != nil
}
40 changes: 31 additions & 9 deletions pkg/webhooks/pod/mutating_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,14 +4,14 @@ import (
"context"
"testing"

"github.com/gocrane/api/ensurance/v1alpha1"
"github.com/stretchr/testify/assert"
"k8s.io/utils/pointer"

v1 "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/utils/pointer"
"sigs.k8s.io/yaml"

"github.com/gocrane/api/ensurance/v1alpha1"

"github.com/gocrane/crane/pkg/ensurance/config"
)

Expand Down Expand Up @@ -47,6 +47,21 @@ func TestDefaultingPodQOSInitializer(t *testing.T) {
}
}

func TestPrecheck(t *testing.T) {
configYaml := "apiVersion: ensurance.crane.io/v1alpha1\nkind: QOSConfig\nqosInitializer:\n enable: true\n selector: \n matchLabels:\n app: nginx\n"

config := &config.QOSConfig{}
err := yaml.Unmarshal([]byte(configYaml), config)
if err != nil {
t.Errorf("unmarshal config failed:%v", err)
}
m := MutatingAdmission{
Config: config,
listPodQOS: MockListPodQOSFunc,
}
assert.False(t, m.available())
}

func MockListPodQOSFunc() ([]*v1alpha1.PodQOS, error) {
return []*v1alpha1.PodQOS{
{
Expand Down Expand Up @@ -90,14 +105,21 @@ func MockListPodQOSFunc() ([]*v1alpha1.PodQOS, error) {
}

func MockPod(name string, labels ...string) *v1.Pod {
labelmap := map[string]string{}
for i := 0; i < len(labels)-1; i += 2 {
labelmap[labels[i]] = labels[i+1]
}
return &v1.Pod{
pod := &v1.Pod{
ObjectMeta: metav1.ObjectMeta{
Name: name,
Labels: labelmap,
Labels: nil,
},
}

if len(labels) < 2 {
return pod
}

labelmap := map[string]string{}
for i := 0; i < len(labels)-1; i += 2 {
labelmap[labels[i]] = labels[i+1]
}
pod.Labels = labelmap
return pod
}

0 comments on commit 008474b

Please sign in to comment.