Skip to content

Commit

Permalink
Merge pull request #1439 from googs1025/add_ut
Browse files Browse the repository at this point in the history
add validation ut
  • Loading branch information
k8s-ci-robot committed Jun 18, 2024
2 parents 1c8ae64 + 0e2478a commit 2df11f8
Show file tree
Hide file tree
Showing 3 changed files with 188 additions and 0 deletions.
48 changes: 48 additions & 0 deletions pkg/framework/plugins/removeduplicates/validation_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
package removeduplicates

import (
"testing"

"sigs.k8s.io/descheduler/pkg/api"
)

func TestValidateRemovePodsViolatingNodeTaintsArgs(t *testing.T) {
testCases := []struct {
description string
args *RemoveDuplicatesArgs
expectError bool
}{
{
description: "valid namespace args, no errors",
args: &RemoveDuplicatesArgs{
ExcludeOwnerKinds: []string{"Job"},
Namespaces: &api.Namespaces{
Include: []string{"default"},
},
},
expectError: false,
},
{
description: "invalid namespaces args, expects error",
args: &RemoveDuplicatesArgs{
ExcludeOwnerKinds: []string{"Job"},
Namespaces: &api.Namespaces{
Include: []string{"default"},
Exclude: []string{"kube-system"},
},
},
expectError: true,
},
}

for _, tc := range testCases {
t.Run(tc.description, func(t *testing.T) {
err := ValidateRemoveDuplicatesArgs(tc.args)

hasError := err != nil
if tc.expectError != hasError {
t.Error("unexpected arg validation behavior")
}
})
}
}
72 changes: 72 additions & 0 deletions pkg/framework/plugins/removefailedpods/validation_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
package removefailedpods

import (
"testing"

metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"sigs.k8s.io/descheduler/pkg/api"
)

func TestValidateRemoveFailedPodsArgs(t *testing.T) {
var oneHourPodLifetimeSeconds uint = 3600
testCases := []struct {
description string
args *RemoveFailedPodsArgs
expectError bool
}{
{
description: "valid namespace args, no errors",
args: &RemoveFailedPodsArgs{
Namespaces: &api.Namespaces{
Include: []string{"default"},
},
ExcludeOwnerKinds: []string{"Job"},
Reasons: []string{"ReasonDoesNotMatch"},
MinPodLifetimeSeconds: &oneHourPodLifetimeSeconds,
},
expectError: false,
},
{
description: "invalid namespaces args, expects error",
args: &RemoveFailedPodsArgs{
Namespaces: &api.Namespaces{
Include: []string{"default"},
Exclude: []string{"kube-system"},
},
},
expectError: true,
},
{
description: "valid label selector args, no errors",
args: &RemoveFailedPodsArgs{
LabelSelector: &metav1.LabelSelector{
MatchLabels: map[string]string{"role.kubernetes.io/node": ""},
},
},
expectError: false,
},
{
description: "invalid label selector args, expects errors",
args: &RemoveFailedPodsArgs{
LabelSelector: &metav1.LabelSelector{
MatchExpressions: []metav1.LabelSelectorRequirement{
{
Operator: metav1.LabelSelectorOpIn,
},
},
},
},
expectError: true,
},
}

for _, tc := range testCases {
t.Run(tc.description, func(t *testing.T) {
err := ValidateRemoveFailedPodsArgs(tc.args)
hasError := err != nil
if tc.expectError != hasError {
t.Error("unexpected arg validation behavior")
}
})
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
package removepodsviolatinginterpodantiaffinity

import (
"testing"

metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"sigs.k8s.io/descheduler/pkg/api"
)

func TestValidateRemovePodsViolatingInterPodAntiAffinityArgs(t *testing.T) {
testCases := []struct {
description string
args *RemovePodsViolatingInterPodAntiAffinityArgs
expectError bool
}{
{
description: "valid namespace args, no errors",
args: &RemovePodsViolatingInterPodAntiAffinityArgs{
Namespaces: &api.Namespaces{
Include: []string{"default"},
},
},
expectError: false,
},
{
description: "invalid namespaces args, expects error",
args: &RemovePodsViolatingInterPodAntiAffinityArgs{
Namespaces: &api.Namespaces{
Include: []string{"default"},
Exclude: []string{"kube-system"},
},
},
expectError: true,
},
{
description: "valid label selector args, no errors",
args: &RemovePodsViolatingInterPodAntiAffinityArgs{
LabelSelector: &metav1.LabelSelector{
MatchLabels: map[string]string{"role.kubernetes.io/node": ""},
},
},
expectError: false,
},
{
description: "invalid label selector args, expects errors",
args: &RemovePodsViolatingInterPodAntiAffinityArgs{
LabelSelector: &metav1.LabelSelector{
MatchExpressions: []metav1.LabelSelectorRequirement{
{
Operator: metav1.LabelSelectorOpIn,
},
},
},
},
expectError: true,
},
}

for _, tc := range testCases {
t.Run(tc.description, func(t *testing.T) {
err := ValidateRemovePodsViolatingInterPodAntiAffinityArgs(tc.args)
hasError := err != nil
if tc.expectError != hasError {
t.Error("unexpected arg validation behavior")
}
})
}
}

0 comments on commit 2df11f8

Please sign in to comment.