mirror of
				https://github.com/optim-enterprises-bv/kubernetes.git
				synced 2025-10-31 10:18:13 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			133 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			133 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| /*
 | |
| Copyright 2017 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 priorities
 | |
| 
 | |
| import (
 | |
| 	"reflect"
 | |
| 	"testing"
 | |
| 
 | |
| 	"k8s.io/apimachinery/pkg/api/resource"
 | |
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
 | |
| 	"k8s.io/kubernetes/pkg/api/v1"
 | |
| 	priorityutil "k8s.io/kubernetes/plugin/pkg/scheduler/algorithm/priorities/util"
 | |
| 	"k8s.io/kubernetes/plugin/pkg/scheduler/schedulercache"
 | |
| )
 | |
| 
 | |
| func TestPriorityMetadata(t *testing.T) {
 | |
| 	nonZeroReqs := &schedulercache.Resource{}
 | |
| 	nonZeroReqs.MilliCPU = priorityutil.DefaultMilliCpuRequest
 | |
| 	nonZeroReqs.Memory = priorityutil.DefaultMemoryRequest
 | |
| 
 | |
| 	specifiedReqs := &schedulercache.Resource{}
 | |
| 	specifiedReqs.MilliCPU = 200
 | |
| 	specifiedReqs.Memory = 2000
 | |
| 
 | |
| 	tolerations := []v1.Toleration{{
 | |
| 		Key:      "foo",
 | |
| 		Operator: v1.TolerationOpEqual,
 | |
| 		Value:    "bar",
 | |
| 		Effect:   v1.TaintEffectPreferNoSchedule,
 | |
| 	}}
 | |
| 	podAffinity := &v1.Affinity{
 | |
| 		PodAffinity: &v1.PodAffinity{
 | |
| 			PreferredDuringSchedulingIgnoredDuringExecution: []v1.WeightedPodAffinityTerm{
 | |
| 				{
 | |
| 					Weight: 5,
 | |
| 					PodAffinityTerm: v1.PodAffinityTerm{
 | |
| 						LabelSelector: &metav1.LabelSelector{
 | |
| 							MatchExpressions: []metav1.LabelSelectorRequirement{
 | |
| 								{
 | |
| 									Key:      "security",
 | |
| 									Operator: metav1.LabelSelectorOpIn,
 | |
| 									Values:   []string{"S1"},
 | |
| 								},
 | |
| 							},
 | |
| 						},
 | |
| 						TopologyKey: "region",
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| 	podWithTolerationsAndAffinity := &v1.Pod{
 | |
| 		Spec: v1.PodSpec{
 | |
| 			Containers: []v1.Container{
 | |
| 				{
 | |
| 					Name:            "container",
 | |
| 					Image:           "image",
 | |
| 					ImagePullPolicy: "Always",
 | |
| 				},
 | |
| 			},
 | |
| 			Affinity:    podAffinity,
 | |
| 			Tolerations: tolerations,
 | |
| 		},
 | |
| 	}
 | |
| 	podWithTolerationsAndRequests := &v1.Pod{
 | |
| 		Spec: v1.PodSpec{
 | |
| 			Containers: []v1.Container{
 | |
| 				{
 | |
| 					Name:            "container",
 | |
| 					Image:           "image",
 | |
| 					ImagePullPolicy: "Always",
 | |
| 					Resources: v1.ResourceRequirements{
 | |
| 						Requests: v1.ResourceList{
 | |
| 							"cpu":    resource.MustParse("200m"),
 | |
| 							"memory": resource.MustParse("2000"),
 | |
| 						},
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 			Tolerations: tolerations,
 | |
| 		},
 | |
| 	}
 | |
| 	tests := []struct {
 | |
| 		pod      *v1.Pod
 | |
| 		test     string
 | |
| 		expected interface{}
 | |
| 	}{
 | |
| 		{
 | |
| 			pod:      nil,
 | |
| 			expected: nil,
 | |
| 			test:     "pod is nil , priorityMetadata is nil",
 | |
| 		},
 | |
| 		{
 | |
| 			pod: podWithTolerationsAndAffinity,
 | |
| 			expected: &priorityMetadata{
 | |
| 				nonZeroRequest: nonZeroReqs,
 | |
| 				podTolerations: tolerations,
 | |
| 				affinity:       podAffinity,
 | |
| 			},
 | |
| 			test: "Produce a priorityMetadata with default requests",
 | |
| 		},
 | |
| 		{
 | |
| 			pod: podWithTolerationsAndRequests,
 | |
| 			expected: &priorityMetadata{
 | |
| 				nonZeroRequest: specifiedReqs,
 | |
| 				podTolerations: tolerations,
 | |
| 				affinity:       nil,
 | |
| 			},
 | |
| 			test: "Produce a priorityMetadata with specified requests",
 | |
| 		},
 | |
| 	}
 | |
| 	for _, test := range tests {
 | |
| 		ptData := PriorityMetadata(test.pod, nil)
 | |
| 		if !reflect.DeepEqual(test.expected, ptData) {
 | |
| 			t.Errorf("%s: expected %#v, got %#v", test.test, test.expected, ptData)
 | |
| 		}
 | |
| 	}
 | |
| }
 | 
