mirror of
				https://github.com/k3s-io/kubernetes.git
				synced 2025-11-03 23:40:03 +00:00 
			
		
		
		
	Under the feature gate DefaultPodTopologySpread, which will disable the legacy DefaultPodTopologySpread plugin from the default algorithm providers. Signed-off-by: Aldo Culquicondor <acondor@google.com>
		
			
				
	
	
		
			1974 lines
		
	
	
		
			65 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			1974 lines
		
	
	
		
			65 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
/*
 | 
						|
Copyright 2015 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 testing
 | 
						|
 | 
						|
import (
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"github.com/google/go-cmp/cmp"
 | 
						|
	"k8s.io/client-go/tools/events"
 | 
						|
	"k8s.io/kubernetes/pkg/scheduler/profile"
 | 
						|
 | 
						|
	v1 "k8s.io/api/core/v1"
 | 
						|
	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
 | 
						|
	utilfeature "k8s.io/apiserver/pkg/util/feature"
 | 
						|
	"k8s.io/client-go/informers"
 | 
						|
	"k8s.io/client-go/kubernetes/fake"
 | 
						|
	"k8s.io/component-base/featuregate"
 | 
						|
	featuregatetesting "k8s.io/component-base/featuregate/testing"
 | 
						|
	_ "k8s.io/kubernetes/pkg/apis/core/install"
 | 
						|
	"k8s.io/kubernetes/pkg/scheduler"
 | 
						|
	"k8s.io/kubernetes/pkg/scheduler/algorithmprovider"
 | 
						|
	"k8s.io/kubernetes/pkg/scheduler/apis/config"
 | 
						|
	"k8s.io/kubernetes/pkg/scheduler/core"
 | 
						|
)
 | 
						|
 | 
						|
type testCase struct {
 | 
						|
	name          string
 | 
						|
	JSON          string
 | 
						|
	featureGates  map[featuregate.Feature]bool
 | 
						|
	wantPlugins   map[string][]config.Plugin
 | 
						|
	wantExtenders []config.Extender
 | 
						|
}
 | 
						|
 | 
						|
func TestCompatibility_v1_Scheduler(t *testing.T) {
 | 
						|
	// Add serialized versions of scheduler config that exercise available options to ensure compatibility between releases
 | 
						|
	testcases := []testCase{
 | 
						|
		// This is a special test for the "composite" predicate "GeneralPredicate". GeneralPredicate is a combination
 | 
						|
		// of predicates, and here we test that if given, it is mapped to the set of plugins that should be executed.
 | 
						|
		{
 | 
						|
			name: "GeneralPredicate",
 | 
						|
			JSON: `{
 | 
						|
		  "kind": "Policy",
 | 
						|
		  "apiVersion": "v1",
 | 
						|
		  "predicates": [
 | 
						|
			{"name": "GeneralPredicates"}
 | 
						|
                  ],
 | 
						|
		  "priorities": [
 | 
						|
                  ]
 | 
						|
		}`,
 | 
						|
			wantPlugins: map[string][]config.Plugin{
 | 
						|
				"QueueSortPlugin": {{Name: "PrioritySort"}},
 | 
						|
				"PreFilterPlugin": {
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "NodePorts"},
 | 
						|
				},
 | 
						|
				"FilterPlugin": {
 | 
						|
					{Name: "NodeUnschedulable"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "NodeName"},
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeAffinity"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
				},
 | 
						|
				"BindPlugin": {{Name: "DefaultBinder"}},
 | 
						|
			},
 | 
						|
		},
 | 
						|
		// This is a special test for the case where a policy is specified without specifying any filters.
 | 
						|
		{
 | 
						|
			name: "MandatoryFilters",
 | 
						|
			JSON: `{
 | 
						|
				"kind": "Policy",
 | 
						|
				"apiVersion": "v1",
 | 
						|
				"predicates": [
 | 
						|
				],
 | 
						|
				"priorities": [
 | 
						|
				]
 | 
						|
			}`,
 | 
						|
			wantPlugins: map[string][]config.Plugin{
 | 
						|
				"QueueSortPlugin": {{Name: "PrioritySort"}},
 | 
						|
				"FilterPlugin": {
 | 
						|
					{Name: "NodeUnschedulable"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
				},
 | 
						|
				"BindPlugin": {{Name: "DefaultBinder"}},
 | 
						|
			},
 | 
						|
		},
 | 
						|
		// Do not change this JSON after the corresponding release has been tagged.
 | 
						|
		// A failure indicates backwards compatibility with the specified release was broken.
 | 
						|
		{
 | 
						|
			name: "1.0",
 | 
						|
			JSON: `{
 | 
						|
  "kind": "Policy",
 | 
						|
  "apiVersion": "v1",
 | 
						|
  "predicates": [
 | 
						|
    {"name": "MatchNodeSelector"},
 | 
						|
    {"name": "PodFitsResources"},
 | 
						|
    {"name": "PodFitsPorts"},
 | 
						|
    {"name": "NoDiskConflict"},
 | 
						|
    {"name": "TestServiceAffinity", "argument": {"serviceAffinity" : {"labels" : ["region"]}}},
 | 
						|
    {"name": "TestLabelsPresence",  "argument": {"labelsPresence"  : {"labels" : ["foo"], "presence":true}}}
 | 
						|
  ],"priorities": [
 | 
						|
    {"name": "LeastRequestedPriority",   "weight": 1},
 | 
						|
    {"name": "ServiceSpreadingPriority", "weight": 2},
 | 
						|
    {"name": "TestServiceAntiAffinity",  "weight": 3, "argument": {"serviceAntiAffinity": {"label": "zone"}}},
 | 
						|
    {"name": "TestLabelPreference",      "weight": 4, "argument": {"labelPreference": {"label": "bar", "presence":true}}}
 | 
						|
  ]
 | 
						|
}`,
 | 
						|
			wantPlugins: map[string][]config.Plugin{
 | 
						|
				"QueueSortPlugin": {{Name: "PrioritySort"}},
 | 
						|
				"PreFilterPlugin": {
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
				},
 | 
						|
				"FilterPlugin": {
 | 
						|
					{Name: "NodeUnschedulable"},
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeAffinity"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "VolumeRestrictions"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
					{Name: "NodeLabel"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
				},
 | 
						|
				"PreScorePlugin": {{Name: "DefaultPodTopologySpread"}},
 | 
						|
				"ScorePlugin": {
 | 
						|
					{Name: "NodeResourcesLeastAllocated", Weight: 1},
 | 
						|
					{Name: "NodeLabel", Weight: 4},
 | 
						|
					{Name: "DefaultPodTopologySpread", Weight: 2},
 | 
						|
					{Name: "ServiceAffinity", Weight: 3},
 | 
						|
				},
 | 
						|
				"BindPlugin": {{Name: "DefaultBinder"}},
 | 
						|
			},
 | 
						|
		},
 | 
						|
 | 
						|
		// Do not change this JSON after the corresponding release has been tagged.
 | 
						|
		// A failure indicates backwards compatibility with the specified release was broken.
 | 
						|
		{
 | 
						|
			name: "1.1",
 | 
						|
			JSON: `{
 | 
						|
		  "kind": "Policy",
 | 
						|
		  "apiVersion": "v1",
 | 
						|
		  "predicates": [
 | 
						|
			{"name": "MatchNodeSelector"},
 | 
						|
			{"name": "PodFitsHostPorts"},
 | 
						|
			{"name": "PodFitsResources"},
 | 
						|
			{"name": "NoDiskConflict"},
 | 
						|
			{"name": "HostName"},
 | 
						|
			{"name": "TestServiceAffinity", "argument": {"serviceAffinity" : {"labels" : ["region"]}}},
 | 
						|
			{"name": "TestLabelsPresence",  "argument": {"labelsPresence"  : {"labels" : ["foo"], "presence":true}}}
 | 
						|
		  ],"priorities": [
 | 
						|
			{"name": "EqualPriority",   "weight": 2},
 | 
						|
			{"name": "LeastRequestedPriority",   "weight": 2},
 | 
						|
			{"name": "BalancedResourceAllocation",   "weight": 2},
 | 
						|
			{"name": "SelectorSpreadPriority",   "weight": 2},
 | 
						|
			{"name": "TestServiceAntiAffinity1",  "weight": 3, "argument": {"serviceAntiAffinity": {"label": "zone"}}},
 | 
						|
			{"name": "TestServiceAntiAffinity2",  "weight": 3, "argument": {"serviceAntiAffinity": {"label": "region"}}},
 | 
						|
			{"name": "TestLabelPreference1",      "weight": 4, "argument": {"labelPreference": {"label": "bar", "presence":true}}},
 | 
						|
			{"name": "TestLabelPreference2",      "weight": 4, "argument": {"labelPreference": {"label": "foo", "presence":false}}}
 | 
						|
		  ]
 | 
						|
		}`,
 | 
						|
			wantPlugins: map[string][]config.Plugin{
 | 
						|
				"QueueSortPlugin": {{Name: "PrioritySort"}},
 | 
						|
				"PreFilterPlugin": {
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
				},
 | 
						|
				"FilterPlugin": {
 | 
						|
					{Name: "NodeUnschedulable"},
 | 
						|
					{Name: "NodeName"},
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeAffinity"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "VolumeRestrictions"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
					{Name: "NodeLabel"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
				},
 | 
						|
				"PreScorePlugin": {{Name: "DefaultPodTopologySpread"}},
 | 
						|
				"ScorePlugin": {
 | 
						|
					{Name: "NodeResourcesBalancedAllocation", Weight: 2},
 | 
						|
					{Name: "NodeResourcesLeastAllocated", Weight: 2},
 | 
						|
					{Name: "NodeLabel", Weight: 8}, // Weight is 4 * number of LabelPreference priorities
 | 
						|
					{Name: "DefaultPodTopologySpread", Weight: 2},
 | 
						|
					{Name: "ServiceAffinity", Weight: 6}, // Weight is the 3 * number of custom ServiceAntiAffinity priorities
 | 
						|
				},
 | 
						|
				"BindPlugin": {{Name: "DefaultBinder"}},
 | 
						|
			},
 | 
						|
		},
 | 
						|
		// Do not change this JSON after the corresponding release has been tagged.
 | 
						|
		// A failure indicates backwards compatibility with the specified release was broken.
 | 
						|
		{
 | 
						|
			name: "1.2",
 | 
						|
			JSON: `{
 | 
						|
		  "kind": "Policy",
 | 
						|
		  "apiVersion": "v1",
 | 
						|
		  "predicates": [
 | 
						|
			{"name": "MatchNodeSelector"},
 | 
						|
			{"name": "PodFitsResources"},
 | 
						|
			{"name": "PodFitsHostPorts"},
 | 
						|
			{"name": "HostName"},
 | 
						|
			{"name": "NoDiskConflict"},
 | 
						|
			{"name": "NoVolumeZoneConflict"},
 | 
						|
			{"name": "MaxEBSVolumeCount"},
 | 
						|
			{"name": "MaxGCEPDVolumeCount"},
 | 
						|
			{"name": "MaxAzureDiskVolumeCount"},
 | 
						|
			{"name": "TestServiceAffinity", "argument": {"serviceAffinity" : {"labels" : ["region"]}}},
 | 
						|
			{"name": "TestLabelsPresence",  "argument": {"labelsPresence"  : {"labels" : ["foo"], "presence":true}}}
 | 
						|
		  ],"priorities": [
 | 
						|
			{"name": "EqualPriority",   "weight": 2},
 | 
						|
			{"name": "NodeAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "ImageLocalityPriority",   "weight": 2},
 | 
						|
			{"name": "LeastRequestedPriority",   "weight": 2},
 | 
						|
			{"name": "BalancedResourceAllocation",   "weight": 2},
 | 
						|
			{"name": "SelectorSpreadPriority",   "weight": 2},
 | 
						|
			{"name": "TestServiceAntiAffinity",  "weight": 3, "argument": {"serviceAntiAffinity": {"label": "zone"}}},
 | 
						|
			{"name": "TestLabelPreference",      "weight": 4, "argument": {"labelPreference": {"label": "bar", "presence":true}}}
 | 
						|
		  ]
 | 
						|
		}`,
 | 
						|
			wantPlugins: map[string][]config.Plugin{
 | 
						|
				"QueueSortPlugin": {{Name: "PrioritySort"}},
 | 
						|
				"PreFilterPlugin": {
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
				},
 | 
						|
				"FilterPlugin": {
 | 
						|
					{Name: "NodeUnschedulable"},
 | 
						|
					{Name: "NodeName"},
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeAffinity"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "VolumeRestrictions"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
					{Name: "NodeLabel"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "EBSLimits"},
 | 
						|
					{Name: "GCEPDLimits"},
 | 
						|
					{Name: "AzureDiskLimits"},
 | 
						|
					{Name: "VolumeZone"},
 | 
						|
				},
 | 
						|
				"PreScorePlugin": {{Name: "DefaultPodTopologySpread"}},
 | 
						|
				"ScorePlugin": {
 | 
						|
					{Name: "NodeResourcesBalancedAllocation", Weight: 2},
 | 
						|
					{Name: "ImageLocality", Weight: 2},
 | 
						|
					{Name: "NodeResourcesLeastAllocated", Weight: 2},
 | 
						|
					{Name: "NodeAffinity", Weight: 2},
 | 
						|
					{Name: "NodeLabel", Weight: 4},
 | 
						|
					{Name: "DefaultPodTopologySpread", Weight: 2},
 | 
						|
					{Name: "ServiceAffinity", Weight: 3},
 | 
						|
				},
 | 
						|
				"BindPlugin": {{Name: "DefaultBinder"}},
 | 
						|
			},
 | 
						|
		},
 | 
						|
 | 
						|
		// Do not change this JSON after the corresponding release has been tagged.
 | 
						|
		// A failure indicates backwards compatibility with the specified release was broken.
 | 
						|
		{
 | 
						|
			name: "1.3",
 | 
						|
			JSON: `{
 | 
						|
		  "kind": "Policy",
 | 
						|
		  "apiVersion": "v1",
 | 
						|
		  "predicates": [
 | 
						|
			{"name": "MatchNodeSelector"},
 | 
						|
			{"name": "PodFitsResources"},
 | 
						|
			{"name": "PodFitsHostPorts"},
 | 
						|
			{"name": "HostName"},
 | 
						|
			{"name": "NoDiskConflict"},
 | 
						|
			{"name": "NoVolumeZoneConflict"},
 | 
						|
			{"name": "PodToleratesNodeTaints"},
 | 
						|
			{"name": "MaxEBSVolumeCount"},
 | 
						|
			{"name": "MaxGCEPDVolumeCount"},
 | 
						|
			{"name": "MaxAzureDiskVolumeCount"},
 | 
						|
			{"name": "MatchInterPodAffinity"},
 | 
						|
			{"name": "TestServiceAffinity", "argument": {"serviceAffinity" : {"labels" : ["region"]}}},
 | 
						|
			{"name": "TestLabelsPresence",  "argument": {"labelsPresence"  : {"labels" : ["foo"], "presence":true}}}
 | 
						|
		  ],"priorities": [
 | 
						|
			{"name": "EqualPriority",   "weight": 2},
 | 
						|
			{"name": "ImageLocalityPriority",   "weight": 2},
 | 
						|
			{"name": "LeastRequestedPriority",   "weight": 2},
 | 
						|
			{"name": "BalancedResourceAllocation",   "weight": 2},
 | 
						|
			{"name": "SelectorSpreadPriority",   "weight": 2},
 | 
						|
			{"name": "NodeAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "TaintTolerationPriority",   "weight": 2},
 | 
						|
			{"name": "InterPodAffinityPriority",   "weight": 2}
 | 
						|
		  ]
 | 
						|
		}`,
 | 
						|
			wantPlugins: map[string][]config.Plugin{
 | 
						|
				"QueueSortPlugin": {{Name: "PrioritySort"}},
 | 
						|
				"PreFilterPlugin": {
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"FilterPlugin": {
 | 
						|
					{Name: "NodeUnschedulable"},
 | 
						|
					{Name: "NodeName"},
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeAffinity"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "VolumeRestrictions"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
					{Name: "NodeLabel"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "EBSLimits"},
 | 
						|
					{Name: "GCEPDLimits"},
 | 
						|
					{Name: "AzureDiskLimits"},
 | 
						|
					{Name: "VolumeZone"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"PreScorePlugin": {
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
					{Name: "DefaultPodTopologySpread"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
				},
 | 
						|
				"ScorePlugin": {
 | 
						|
					{Name: "NodeResourcesBalancedAllocation", Weight: 2},
 | 
						|
					{Name: "ImageLocality", Weight: 2},
 | 
						|
					{Name: "InterPodAffinity", Weight: 2},
 | 
						|
					{Name: "NodeResourcesLeastAllocated", Weight: 2},
 | 
						|
					{Name: "NodeAffinity", Weight: 2},
 | 
						|
					{Name: "DefaultPodTopologySpread", Weight: 2},
 | 
						|
					{Name: "TaintToleration", Weight: 2},
 | 
						|
				},
 | 
						|
				"BindPlugin": {{Name: "DefaultBinder"}},
 | 
						|
			},
 | 
						|
		},
 | 
						|
 | 
						|
		// Do not change this JSON after the corresponding release has been tagged.
 | 
						|
		// A failure indicates backwards compatibility with the specified release was broken.
 | 
						|
		{
 | 
						|
			name: "1.4",
 | 
						|
			JSON: `{
 | 
						|
		  "kind": "Policy",
 | 
						|
		  "apiVersion": "v1",
 | 
						|
		  "predicates": [
 | 
						|
			{"name": "MatchNodeSelector"},
 | 
						|
			{"name": "PodFitsResources"},
 | 
						|
			{"name": "PodFitsHostPorts"},
 | 
						|
			{"name": "HostName"},
 | 
						|
			{"name": "NoDiskConflict"},
 | 
						|
			{"name": "NoVolumeZoneConflict"},
 | 
						|
			{"name": "PodToleratesNodeTaints"},
 | 
						|
			{"name": "MaxEBSVolumeCount"},
 | 
						|
			{"name": "MaxGCEPDVolumeCount"},
 | 
						|
			{"name": "MaxAzureDiskVolumeCount"},
 | 
						|
			{"name": "MatchInterPodAffinity"},
 | 
						|
			{"name": "TestServiceAffinity", "argument": {"serviceAffinity" : {"labels" : ["region"]}}},
 | 
						|
			{"name": "TestLabelsPresence",  "argument": {"labelsPresence"  : {"labels" : ["foo"], "presence":true}}}
 | 
						|
		  ],"priorities": [
 | 
						|
			{"name": "EqualPriority",   "weight": 2},
 | 
						|
			{"name": "ImageLocalityPriority",   "weight": 2},
 | 
						|
			{"name": "LeastRequestedPriority",   "weight": 2},
 | 
						|
			{"name": "BalancedResourceAllocation",   "weight": 2},
 | 
						|
			{"name": "SelectorSpreadPriority",   "weight": 2},
 | 
						|
			{"name": "NodePreferAvoidPodsPriority",   "weight": 2},
 | 
						|
			{"name": "NodeAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "TaintTolerationPriority",   "weight": 2},
 | 
						|
			{"name": "InterPodAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "MostRequestedPriority",   "weight": 2}
 | 
						|
		  ]
 | 
						|
		}`,
 | 
						|
			wantPlugins: map[string][]config.Plugin{
 | 
						|
				"QueueSortPlugin": {{Name: "PrioritySort"}},
 | 
						|
				"PreFilterPlugin": {
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"FilterPlugin": {
 | 
						|
					{Name: "NodeUnschedulable"},
 | 
						|
					{Name: "NodeName"},
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeAffinity"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "VolumeRestrictions"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
					{Name: "NodeLabel"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "EBSLimits"},
 | 
						|
					{Name: "GCEPDLimits"},
 | 
						|
					{Name: "AzureDiskLimits"},
 | 
						|
					{Name: "VolumeZone"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"PreScorePlugin": {
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
					{Name: "DefaultPodTopologySpread"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
				},
 | 
						|
				"ScorePlugin": {
 | 
						|
					{Name: "NodeResourcesBalancedAllocation", Weight: 2},
 | 
						|
					{Name: "ImageLocality", Weight: 2},
 | 
						|
					{Name: "InterPodAffinity", Weight: 2},
 | 
						|
					{Name: "NodeResourcesLeastAllocated", Weight: 2},
 | 
						|
					{Name: "NodeResourcesMostAllocated", Weight: 2},
 | 
						|
					{Name: "NodeAffinity", Weight: 2},
 | 
						|
					{Name: "NodePreferAvoidPods", Weight: 2},
 | 
						|
					{Name: "DefaultPodTopologySpread", Weight: 2},
 | 
						|
					{Name: "TaintToleration", Weight: 2},
 | 
						|
				},
 | 
						|
				"BindPlugin": {{Name: "DefaultBinder"}},
 | 
						|
			},
 | 
						|
		},
 | 
						|
		// Do not change this JSON after the corresponding release has been tagged.
 | 
						|
		// A failure indicates backwards compatibility with the specified release was broken.
 | 
						|
		{
 | 
						|
			name: "1.7",
 | 
						|
			JSON: `{
 | 
						|
		  "kind": "Policy",
 | 
						|
		  "apiVersion": "v1",
 | 
						|
		  "predicates": [
 | 
						|
			{"name": "MatchNodeSelector"},
 | 
						|
			{"name": "PodFitsResources"},
 | 
						|
			{"name": "PodFitsHostPorts"},
 | 
						|
			{"name": "HostName"},
 | 
						|
			{"name": "NoDiskConflict"},
 | 
						|
			{"name": "NoVolumeZoneConflict"},
 | 
						|
			{"name": "PodToleratesNodeTaints"},
 | 
						|
			{"name": "MaxEBSVolumeCount"},
 | 
						|
			{"name": "MaxGCEPDVolumeCount"},
 | 
						|
			{"name": "MaxAzureDiskVolumeCount"},
 | 
						|
			{"name": "MatchInterPodAffinity"},
 | 
						|
			{"name": "TestServiceAffinity", "argument": {"serviceAffinity" : {"labels" : ["region"]}}},
 | 
						|
			{"name": "TestLabelsPresence",  "argument": {"labelsPresence"  : {"labels" : ["foo"], "presence":true}}}
 | 
						|
		  ],"priorities": [
 | 
						|
			{"name": "EqualPriority",   "weight": 2},
 | 
						|
			{"name": "ImageLocalityPriority",   "weight": 2},
 | 
						|
			{"name": "LeastRequestedPriority",   "weight": 2},
 | 
						|
			{"name": "BalancedResourceAllocation",   "weight": 2},
 | 
						|
			{"name": "SelectorSpreadPriority",   "weight": 2},
 | 
						|
			{"name": "NodePreferAvoidPodsPriority",   "weight": 2},
 | 
						|
			{"name": "NodeAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "TaintTolerationPriority",   "weight": 2},
 | 
						|
			{"name": "InterPodAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "MostRequestedPriority",   "weight": 2}
 | 
						|
		  ],"extenders": [{
 | 
						|
			"urlPrefix":        "/prefix",
 | 
						|
			"filterVerb":       "filter",
 | 
						|
			"prioritizeVerb":   "prioritize",
 | 
						|
			"weight":           1,
 | 
						|
			"BindVerb":         "bind",
 | 
						|
			"enableHttps":      true,
 | 
						|
			"tlsConfig":        {"Insecure":true},
 | 
						|
			"httpTimeout":      1,
 | 
						|
			"nodeCacheCapable": true
 | 
						|
		  }]
 | 
						|
		}`,
 | 
						|
			wantPlugins: map[string][]config.Plugin{
 | 
						|
				"QueueSortPlugin": {{Name: "PrioritySort"}},
 | 
						|
				"PreFilterPlugin": {
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"FilterPlugin": {
 | 
						|
					{Name: "NodeUnschedulable"},
 | 
						|
					{Name: "NodeName"},
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeAffinity"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "VolumeRestrictions"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
					{Name: "NodeLabel"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "EBSLimits"},
 | 
						|
					{Name: "GCEPDLimits"},
 | 
						|
					{Name: "AzureDiskLimits"},
 | 
						|
					{Name: "VolumeZone"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"PreScorePlugin": {
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
					{Name: "DefaultPodTopologySpread"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
				},
 | 
						|
				"ScorePlugin": {
 | 
						|
					{Name: "NodeResourcesBalancedAllocation", Weight: 2},
 | 
						|
					{Name: "ImageLocality", Weight: 2},
 | 
						|
					{Name: "InterPodAffinity", Weight: 2},
 | 
						|
					{Name: "NodeResourcesLeastAllocated", Weight: 2},
 | 
						|
					{Name: "NodeResourcesMostAllocated", Weight: 2},
 | 
						|
					{Name: "NodeAffinity", Weight: 2},
 | 
						|
					{Name: "NodePreferAvoidPods", Weight: 2},
 | 
						|
					{Name: "DefaultPodTopologySpread", Weight: 2},
 | 
						|
					{Name: "TaintToleration", Weight: 2},
 | 
						|
				},
 | 
						|
				"BindPlugin": {{Name: "DefaultBinder"}},
 | 
						|
			},
 | 
						|
			wantExtenders: []config.Extender{{
 | 
						|
				URLPrefix:        "/prefix",
 | 
						|
				FilterVerb:       "filter",
 | 
						|
				PrioritizeVerb:   "prioritize",
 | 
						|
				Weight:           1,
 | 
						|
				BindVerb:         "bind", // 1.7 was missing json tags on the BindVerb field and required "BindVerb"
 | 
						|
				EnableHTTPS:      true,
 | 
						|
				TLSConfig:        &config.ExtenderTLSConfig{Insecure: true},
 | 
						|
				HTTPTimeout:      1,
 | 
						|
				NodeCacheCapable: true,
 | 
						|
			}},
 | 
						|
		},
 | 
						|
		// Do not change this JSON after the corresponding release has been tagged.
 | 
						|
		// A failure indicates backwards compatibility with the specified release was broken.
 | 
						|
		{
 | 
						|
			name: "1.8",
 | 
						|
			JSON: `{
 | 
						|
		  "kind": "Policy",
 | 
						|
		  "apiVersion": "v1",
 | 
						|
		  "predicates": [
 | 
						|
			{"name": "MatchNodeSelector"},
 | 
						|
			{"name": "PodFitsResources"},
 | 
						|
			{"name": "PodFitsHostPorts"},
 | 
						|
			{"name": "HostName"},
 | 
						|
			{"name": "NoDiskConflict"},
 | 
						|
			{"name": "NoVolumeZoneConflict"},
 | 
						|
			{"name": "PodToleratesNodeTaints"},
 | 
						|
			{"name": "MaxEBSVolumeCount"},
 | 
						|
			{"name": "MaxGCEPDVolumeCount"},
 | 
						|
			{"name": "MaxAzureDiskVolumeCount"},
 | 
						|
			{"name": "MatchInterPodAffinity"},
 | 
						|
			{"name": "TestServiceAffinity", "argument": {"serviceAffinity" : {"labels" : ["region"]}}},
 | 
						|
			{"name": "TestLabelsPresence",  "argument": {"labelsPresence"  : {"labels" : ["foo"], "presence":true}}}
 | 
						|
		  ],"priorities": [
 | 
						|
			{"name": "EqualPriority",   "weight": 2},
 | 
						|
			{"name": "ImageLocalityPriority",   "weight": 2},
 | 
						|
			{"name": "LeastRequestedPriority",   "weight": 2},
 | 
						|
			{"name": "BalancedResourceAllocation",   "weight": 2},
 | 
						|
			{"name": "SelectorSpreadPriority",   "weight": 2},
 | 
						|
			{"name": "NodePreferAvoidPodsPriority",   "weight": 2},
 | 
						|
			{"name": "NodeAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "TaintTolerationPriority",   "weight": 2},
 | 
						|
			{"name": "InterPodAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "MostRequestedPriority",   "weight": 2}
 | 
						|
		  ],"extenders": [{
 | 
						|
			"urlPrefix":        "/prefix",
 | 
						|
			"filterVerb":       "filter",
 | 
						|
			"prioritizeVerb":   "prioritize",
 | 
						|
			"weight":           1,
 | 
						|
			"bindVerb":         "bind",
 | 
						|
			"enableHttps":      true,
 | 
						|
			"tlsConfig":        {"Insecure":true},
 | 
						|
			"httpTimeout":      1,
 | 
						|
			"nodeCacheCapable": true
 | 
						|
		  }]
 | 
						|
		}`,
 | 
						|
			wantPlugins: map[string][]config.Plugin{
 | 
						|
				"QueueSortPlugin": {{Name: "PrioritySort"}},
 | 
						|
				"PreFilterPlugin": {
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"FilterPlugin": {
 | 
						|
					{Name: "NodeUnschedulable"},
 | 
						|
					{Name: "NodeName"},
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeAffinity"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "VolumeRestrictions"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
					{Name: "NodeLabel"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "EBSLimits"},
 | 
						|
					{Name: "GCEPDLimits"},
 | 
						|
					{Name: "AzureDiskLimits"},
 | 
						|
					{Name: "VolumeZone"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"PreScorePlugin": {
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
					{Name: "DefaultPodTopologySpread"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
				},
 | 
						|
				"ScorePlugin": {
 | 
						|
					{Name: "NodeResourcesBalancedAllocation", Weight: 2},
 | 
						|
					{Name: "ImageLocality", Weight: 2},
 | 
						|
					{Name: "InterPodAffinity", Weight: 2},
 | 
						|
					{Name: "NodeResourcesLeastAllocated", Weight: 2},
 | 
						|
					{Name: "NodeResourcesMostAllocated", Weight: 2},
 | 
						|
					{Name: "NodeAffinity", Weight: 2},
 | 
						|
					{Name: "NodePreferAvoidPods", Weight: 2},
 | 
						|
					{Name: "DefaultPodTopologySpread", Weight: 2},
 | 
						|
					{Name: "TaintToleration", Weight: 2},
 | 
						|
				},
 | 
						|
				"BindPlugin": {{Name: "DefaultBinder"}},
 | 
						|
			},
 | 
						|
			wantExtenders: []config.Extender{{
 | 
						|
				URLPrefix:        "/prefix",
 | 
						|
				FilterVerb:       "filter",
 | 
						|
				PrioritizeVerb:   "prioritize",
 | 
						|
				Weight:           1,
 | 
						|
				BindVerb:         "bind", // 1.8 became case-insensitive and tolerated "bindVerb"
 | 
						|
				EnableHTTPS:      true,
 | 
						|
				TLSConfig:        &config.ExtenderTLSConfig{Insecure: true},
 | 
						|
				HTTPTimeout:      1,
 | 
						|
				NodeCacheCapable: true,
 | 
						|
			}},
 | 
						|
		},
 | 
						|
		// Do not change this JSON after the corresponding release has been tagged.
 | 
						|
		// A failure indicates backwards compatibility with the specified release was broken.
 | 
						|
		{
 | 
						|
			name: "1.9",
 | 
						|
			JSON: `{
 | 
						|
		  "kind": "Policy",
 | 
						|
		  "apiVersion": "v1",
 | 
						|
		  "predicates": [
 | 
						|
			{"name": "MatchNodeSelector"},
 | 
						|
			{"name": "PodFitsResources"},
 | 
						|
			{"name": "PodFitsHostPorts"},
 | 
						|
			{"name": "HostName"},
 | 
						|
			{"name": "NoDiskConflict"},
 | 
						|
			{"name": "NoVolumeZoneConflict"},
 | 
						|
			{"name": "PodToleratesNodeTaints"},
 | 
						|
			{"name": "MaxEBSVolumeCount"},
 | 
						|
			{"name": "MaxGCEPDVolumeCount"},
 | 
						|
			{"name": "MaxAzureDiskVolumeCount"},
 | 
						|
			{"name": "MatchInterPodAffinity"},
 | 
						|
			{"name": "CheckVolumeBinding"},
 | 
						|
			{"name": "TestServiceAffinity", "argument": {"serviceAffinity" : {"labels" : ["region"]}}},
 | 
						|
			{"name": "TestLabelsPresence",  "argument": {"labelsPresence"  : {"labels" : ["foo"], "presence":true}}}
 | 
						|
		  ],"priorities": [
 | 
						|
			{"name": "EqualPriority",   "weight": 2},
 | 
						|
			{"name": "ImageLocalityPriority",   "weight": 2},
 | 
						|
			{"name": "LeastRequestedPriority",   "weight": 2},
 | 
						|
			{"name": "BalancedResourceAllocation",   "weight": 2},
 | 
						|
			{"name": "SelectorSpreadPriority",   "weight": 2},
 | 
						|
			{"name": "NodePreferAvoidPodsPriority",   "weight": 2},
 | 
						|
			{"name": "NodeAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "TaintTolerationPriority",   "weight": 2},
 | 
						|
			{"name": "InterPodAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "MostRequestedPriority",   "weight": 2}
 | 
						|
		  ],"extenders": [{
 | 
						|
			"urlPrefix":        "/prefix",
 | 
						|
			"filterVerb":       "filter",
 | 
						|
			"prioritizeVerb":   "prioritize",
 | 
						|
			"weight":           1,
 | 
						|
			"bindVerb":         "bind",
 | 
						|
			"enableHttps":      true,
 | 
						|
			"tlsConfig":        {"Insecure":true},
 | 
						|
			"httpTimeout":      1,
 | 
						|
			"nodeCacheCapable": true
 | 
						|
		  }]
 | 
						|
		}`,
 | 
						|
			wantPlugins: map[string][]config.Plugin{
 | 
						|
				"QueueSortPlugin": {{Name: "PrioritySort"}},
 | 
						|
				"PreFilterPlugin": {
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"FilterPlugin": {
 | 
						|
					{Name: "NodeUnschedulable"},
 | 
						|
					{Name: "NodeName"},
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeAffinity"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "VolumeRestrictions"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
					{Name: "NodeLabel"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "EBSLimits"},
 | 
						|
					{Name: "GCEPDLimits"},
 | 
						|
					{Name: "AzureDiskLimits"},
 | 
						|
					{Name: "VolumeBinding"},
 | 
						|
					{Name: "VolumeZone"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"PreScorePlugin": {
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
					{Name: "DefaultPodTopologySpread"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
				},
 | 
						|
				"ScorePlugin": {
 | 
						|
					{Name: "NodeResourcesBalancedAllocation", Weight: 2},
 | 
						|
					{Name: "ImageLocality", Weight: 2},
 | 
						|
					{Name: "InterPodAffinity", Weight: 2},
 | 
						|
					{Name: "NodeResourcesLeastAllocated", Weight: 2},
 | 
						|
					{Name: "NodeResourcesMostAllocated", Weight: 2},
 | 
						|
					{Name: "NodeAffinity", Weight: 2},
 | 
						|
					{Name: "NodePreferAvoidPods", Weight: 2},
 | 
						|
					{Name: "DefaultPodTopologySpread", Weight: 2},
 | 
						|
					{Name: "TaintToleration", Weight: 2},
 | 
						|
				},
 | 
						|
				"BindPlugin":      {{Name: "DefaultBinder"}},
 | 
						|
				"ReservePlugin":   {{Name: "VolumeBinding"}},
 | 
						|
				"UnreservePlugin": {{Name: "VolumeBinding"}},
 | 
						|
				"PreBindPlugin":   {{Name: "VolumeBinding"}},
 | 
						|
				"PostBindPlugin":  {{Name: "VolumeBinding"}},
 | 
						|
			},
 | 
						|
			wantExtenders: []config.Extender{{
 | 
						|
				URLPrefix:        "/prefix",
 | 
						|
				FilterVerb:       "filter",
 | 
						|
				PrioritizeVerb:   "prioritize",
 | 
						|
				Weight:           1,
 | 
						|
				BindVerb:         "bind", // 1.9 was case-insensitive and tolerated "bindVerb"
 | 
						|
				EnableHTTPS:      true,
 | 
						|
				TLSConfig:        &config.ExtenderTLSConfig{Insecure: true},
 | 
						|
				HTTPTimeout:      1,
 | 
						|
				NodeCacheCapable: true,
 | 
						|
			}},
 | 
						|
		},
 | 
						|
 | 
						|
		// Do not change this JSON after the corresponding release has been tagged.
 | 
						|
		// A failure indicates backwards compatibility with the specified release was broken.
 | 
						|
		{
 | 
						|
			name: "1.10",
 | 
						|
			JSON: `{
 | 
						|
		  "kind": "Policy",
 | 
						|
		  "apiVersion": "v1",
 | 
						|
		  "predicates": [
 | 
						|
			{"name": "MatchNodeSelector"},
 | 
						|
			{"name": "PodFitsResources"},
 | 
						|
			{"name": "PodFitsHostPorts"},
 | 
						|
			{"name": "HostName"},
 | 
						|
			{"name": "NoDiskConflict"},
 | 
						|
			{"name": "NoVolumeZoneConflict"},
 | 
						|
			{"name": "PodToleratesNodeTaints"},
 | 
						|
			{"name": "MaxEBSVolumeCount"},
 | 
						|
			{"name": "MaxGCEPDVolumeCount"},
 | 
						|
			{"name": "MaxAzureDiskVolumeCount"},
 | 
						|
			{"name": "MatchInterPodAffinity"},
 | 
						|
			{"name": "CheckVolumeBinding"},
 | 
						|
			{"name": "TestServiceAffinity", "argument": {"serviceAffinity" : {"labels" : ["region"]}}},
 | 
						|
			{"name": "TestLabelsPresence",  "argument": {"labelsPresence"  : {"labels" : ["foo"], "presence":true}}}
 | 
						|
		  ],"priorities": [
 | 
						|
			{"name": "EqualPriority",   "weight": 2},
 | 
						|
			{"name": "ImageLocalityPriority",   "weight": 2},
 | 
						|
			{"name": "LeastRequestedPriority",   "weight": 2},
 | 
						|
			{"name": "BalancedResourceAllocation",   "weight": 2},
 | 
						|
			{"name": "SelectorSpreadPriority",   "weight": 2},
 | 
						|
			{"name": "NodePreferAvoidPodsPriority",   "weight": 2},
 | 
						|
			{"name": "NodeAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "TaintTolerationPriority",   "weight": 2},
 | 
						|
			{"name": "InterPodAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "MostRequestedPriority",   "weight": 2}
 | 
						|
		  ],"extenders": [{
 | 
						|
			"urlPrefix":        "/prefix",
 | 
						|
			"filterVerb":       "filter",
 | 
						|
			"prioritizeVerb":   "prioritize",
 | 
						|
			"weight":           1,
 | 
						|
			"bindVerb":         "bind",
 | 
						|
			"enableHttps":      true,
 | 
						|
			"tlsConfig":        {"Insecure":true},
 | 
						|
			"httpTimeout":      1,
 | 
						|
			"nodeCacheCapable": true,
 | 
						|
			"managedResources": [{"name":"example.com/foo","ignoredByScheduler":true}],
 | 
						|
			"ignorable":true
 | 
						|
		  }]
 | 
						|
		}`,
 | 
						|
			wantPlugins: map[string][]config.Plugin{
 | 
						|
				"QueueSortPlugin": {{Name: "PrioritySort"}},
 | 
						|
				"PreFilterPlugin": {
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"FilterPlugin": {
 | 
						|
					{Name: "NodeUnschedulable"},
 | 
						|
					{Name: "NodeName"},
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeAffinity"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "VolumeRestrictions"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
					{Name: "NodeLabel"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "EBSLimits"},
 | 
						|
					{Name: "GCEPDLimits"},
 | 
						|
					{Name: "AzureDiskLimits"},
 | 
						|
					{Name: "VolumeBinding"},
 | 
						|
					{Name: "VolumeZone"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"PreScorePlugin": {
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
					{Name: "DefaultPodTopologySpread"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
				},
 | 
						|
				"ScorePlugin": {
 | 
						|
					{Name: "NodeResourcesBalancedAllocation", Weight: 2},
 | 
						|
					{Name: "ImageLocality", Weight: 2},
 | 
						|
					{Name: "InterPodAffinity", Weight: 2},
 | 
						|
					{Name: "NodeResourcesLeastAllocated", Weight: 2},
 | 
						|
					{Name: "NodeResourcesMostAllocated", Weight: 2},
 | 
						|
					{Name: "NodeAffinity", Weight: 2},
 | 
						|
					{Name: "NodePreferAvoidPods", Weight: 2},
 | 
						|
					{Name: "DefaultPodTopologySpread", Weight: 2},
 | 
						|
					{Name: "TaintToleration", Weight: 2},
 | 
						|
				},
 | 
						|
				"BindPlugin":      {{Name: "DefaultBinder"}},
 | 
						|
				"ReservePlugin":   {{Name: "VolumeBinding"}},
 | 
						|
				"UnreservePlugin": {{Name: "VolumeBinding"}},
 | 
						|
				"PreBindPlugin":   {{Name: "VolumeBinding"}},
 | 
						|
				"PostBindPlugin":  {{Name: "VolumeBinding"}},
 | 
						|
			},
 | 
						|
			wantExtenders: []config.Extender{{
 | 
						|
				URLPrefix:        "/prefix",
 | 
						|
				FilterVerb:       "filter",
 | 
						|
				PrioritizeVerb:   "prioritize",
 | 
						|
				Weight:           1,
 | 
						|
				BindVerb:         "bind", // 1.10 was case-insensitive and tolerated "bindVerb"
 | 
						|
				EnableHTTPS:      true,
 | 
						|
				TLSConfig:        &config.ExtenderTLSConfig{Insecure: true},
 | 
						|
				HTTPTimeout:      1,
 | 
						|
				NodeCacheCapable: true,
 | 
						|
				ManagedResources: []config.ExtenderManagedResource{{Name: "example.com/foo", IgnoredByScheduler: true}},
 | 
						|
				Ignorable:        true,
 | 
						|
			}},
 | 
						|
		},
 | 
						|
		// Do not change this JSON after the corresponding release has been tagged.
 | 
						|
		// A failure indicates backwards compatibility with the specified release was broken.
 | 
						|
		{
 | 
						|
			name: "1.11",
 | 
						|
			JSON: `{
 | 
						|
		  "kind": "Policy",
 | 
						|
		  "apiVersion": "v1",
 | 
						|
		  "predicates": [
 | 
						|
			{"name": "MatchNodeSelector"},
 | 
						|
			{"name": "PodFitsResources"},
 | 
						|
			{"name": "PodFitsHostPorts"},
 | 
						|
			{"name": "HostName"},
 | 
						|
			{"name": "NoDiskConflict"},
 | 
						|
			{"name": "NoVolumeZoneConflict"},
 | 
						|
			{"name": "PodToleratesNodeTaints"},
 | 
						|
			{"name": "MaxEBSVolumeCount"},
 | 
						|
			{"name": "MaxGCEPDVolumeCount"},
 | 
						|
			{"name": "MaxAzureDiskVolumeCount"},
 | 
						|
			{"name": "MatchInterPodAffinity"},
 | 
						|
			{"name": "CheckVolumeBinding"},
 | 
						|
			{"name": "TestServiceAffinity", "argument": {"serviceAffinity" : {"labels" : ["region"]}}},
 | 
						|
			{"name": "TestLabelsPresence",  "argument": {"labelsPresence"  : {"labels" : ["foo"], "presence":true}}}
 | 
						|
		  ],"priorities": [
 | 
						|
			{"name": "EqualPriority",   "weight": 2},
 | 
						|
			{"name": "ImageLocalityPriority",   "weight": 2},
 | 
						|
			{"name": "LeastRequestedPriority",   "weight": 2},
 | 
						|
			{"name": "BalancedResourceAllocation",   "weight": 2},
 | 
						|
			{"name": "SelectorSpreadPriority",   "weight": 2},
 | 
						|
			{"name": "NodePreferAvoidPodsPriority",   "weight": 2},
 | 
						|
			{"name": "NodeAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "TaintTolerationPriority",   "weight": 2},
 | 
						|
			{"name": "InterPodAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "MostRequestedPriority",   "weight": 2},
 | 
						|
			{
 | 
						|
				"name": "RequestedToCapacityRatioPriority",
 | 
						|
				"weight": 2,
 | 
						|
				"argument": {
 | 
						|
				"requestedToCapacityRatioArguments": {
 | 
						|
					"shape": [
 | 
						|
						{"utilization": 0,  "score": 0},
 | 
						|
						{"utilization": 50, "score": 7}
 | 
						|
					]
 | 
						|
				}
 | 
						|
			}}
 | 
						|
		  ],"extenders": [{
 | 
						|
			"urlPrefix":        "/prefix",
 | 
						|
			"filterVerb":       "filter",
 | 
						|
			"prioritizeVerb":   "prioritize",
 | 
						|
			"weight":           1,
 | 
						|
			"bindVerb":         "bind",
 | 
						|
			"enableHttps":      true,
 | 
						|
			"tlsConfig":        {"Insecure":true},
 | 
						|
			"httpTimeout":      1,
 | 
						|
			"nodeCacheCapable": true,
 | 
						|
			"managedResources": [{"name":"example.com/foo","ignoredByScheduler":true}],
 | 
						|
			"ignorable":true
 | 
						|
		  }]
 | 
						|
		}`,
 | 
						|
			wantPlugins: map[string][]config.Plugin{
 | 
						|
				"QueueSortPlugin": {{Name: "PrioritySort"}},
 | 
						|
				"PreFilterPlugin": {
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"FilterPlugin": {
 | 
						|
					{Name: "NodeUnschedulable"},
 | 
						|
					{Name: "NodeName"},
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeAffinity"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "VolumeRestrictions"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
					{Name: "NodeLabel"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "EBSLimits"},
 | 
						|
					{Name: "GCEPDLimits"},
 | 
						|
					{Name: "AzureDiskLimits"},
 | 
						|
					{Name: "VolumeBinding"},
 | 
						|
					{Name: "VolumeZone"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"PreScorePlugin": {
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
					{Name: "DefaultPodTopologySpread"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
				},
 | 
						|
				"ScorePlugin": {
 | 
						|
					{Name: "NodeResourcesBalancedAllocation", Weight: 2},
 | 
						|
					{Name: "ImageLocality", Weight: 2},
 | 
						|
					{Name: "InterPodAffinity", Weight: 2},
 | 
						|
					{Name: "NodeResourcesLeastAllocated", Weight: 2},
 | 
						|
					{Name: "NodeResourcesMostAllocated", Weight: 2},
 | 
						|
					{Name: "NodeAffinity", Weight: 2},
 | 
						|
					{Name: "NodePreferAvoidPods", Weight: 2},
 | 
						|
					{Name: "RequestedToCapacityRatio", Weight: 2},
 | 
						|
					{Name: "DefaultPodTopologySpread", Weight: 2},
 | 
						|
					{Name: "TaintToleration", Weight: 2},
 | 
						|
				},
 | 
						|
				"BindPlugin":      {{Name: "DefaultBinder"}},
 | 
						|
				"ReservePlugin":   {{Name: "VolumeBinding"}},
 | 
						|
				"UnreservePlugin": {{Name: "VolumeBinding"}},
 | 
						|
				"PreBindPlugin":   {{Name: "VolumeBinding"}},
 | 
						|
				"PostBindPlugin":  {{Name: "VolumeBinding"}},
 | 
						|
			},
 | 
						|
			wantExtenders: []config.Extender{{
 | 
						|
				URLPrefix:        "/prefix",
 | 
						|
				FilterVerb:       "filter",
 | 
						|
				PrioritizeVerb:   "prioritize",
 | 
						|
				Weight:           1,
 | 
						|
				BindVerb:         "bind", // 1.11 restored case-sensitivity, but allowed either "BindVerb" or "bindVerb"
 | 
						|
				EnableHTTPS:      true,
 | 
						|
				TLSConfig:        &config.ExtenderTLSConfig{Insecure: true},
 | 
						|
				HTTPTimeout:      1,
 | 
						|
				NodeCacheCapable: true,
 | 
						|
				ManagedResources: []config.ExtenderManagedResource{{Name: "example.com/foo", IgnoredByScheduler: true}},
 | 
						|
				Ignorable:        true,
 | 
						|
			}},
 | 
						|
		},
 | 
						|
		// Do not change this JSON after the corresponding release has been tagged.
 | 
						|
		// A failure indicates backwards compatibility with the specified release was broken.
 | 
						|
		{
 | 
						|
			name: "1.12",
 | 
						|
			JSON: `{
 | 
						|
		  "kind": "Policy",
 | 
						|
		  "apiVersion": "v1",
 | 
						|
		  "predicates": [
 | 
						|
			{"name": "MatchNodeSelector"},
 | 
						|
			{"name": "PodFitsResources"},
 | 
						|
			{"name": "PodFitsHostPorts"},
 | 
						|
			{"name": "HostName"},
 | 
						|
			{"name": "NoDiskConflict"},
 | 
						|
			{"name": "NoVolumeZoneConflict"},
 | 
						|
			{"name": "PodToleratesNodeTaints"},
 | 
						|
			{"name": "MaxEBSVolumeCount"},
 | 
						|
			{"name": "MaxGCEPDVolumeCount"},
 | 
						|
			{"name": "MaxAzureDiskVolumeCount"},
 | 
						|
			{"name": "MaxCSIVolumeCountPred"},
 | 
						|
			{"name": "MatchInterPodAffinity"},
 | 
						|
			{"name": "CheckVolumeBinding"},
 | 
						|
			{"name": "TestServiceAffinity", "argument": {"serviceAffinity" : {"labels" : ["region"]}}},
 | 
						|
			{"name": "TestLabelsPresence",  "argument": {"labelsPresence"  : {"labels" : ["foo"], "presence":true}}}
 | 
						|
		  ],"priorities": [
 | 
						|
			{"name": "EqualPriority",   "weight": 2},
 | 
						|
			{"name": "ImageLocalityPriority",   "weight": 2},
 | 
						|
			{"name": "LeastRequestedPriority",   "weight": 2},
 | 
						|
			{"name": "BalancedResourceAllocation",   "weight": 2},
 | 
						|
			{"name": "SelectorSpreadPriority",   "weight": 2},
 | 
						|
			{"name": "NodePreferAvoidPodsPriority",   "weight": 2},
 | 
						|
			{"name": "NodeAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "TaintTolerationPriority",   "weight": 2},
 | 
						|
			{"name": "InterPodAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "MostRequestedPriority",   "weight": 2},
 | 
						|
			{
 | 
						|
				"name": "RequestedToCapacityRatioPriority",
 | 
						|
				"weight": 2,
 | 
						|
				"argument": {
 | 
						|
				"requestedToCapacityRatioArguments": {
 | 
						|
					"shape": [
 | 
						|
						{"utilization": 0,  "score": 0},
 | 
						|
						{"utilization": 50, "score": 7}
 | 
						|
					]
 | 
						|
				}
 | 
						|
			}}
 | 
						|
		  ],"extenders": [{
 | 
						|
			"urlPrefix":        "/prefix",
 | 
						|
			"filterVerb":       "filter",
 | 
						|
			"prioritizeVerb":   "prioritize",
 | 
						|
			"weight":           1,
 | 
						|
			"bindVerb":         "bind",
 | 
						|
			"enableHttps":      true,
 | 
						|
			"tlsConfig":        {"Insecure":true},
 | 
						|
			"httpTimeout":      1,
 | 
						|
			"nodeCacheCapable": true,
 | 
						|
			"managedResources": [{"name":"example.com/foo","ignoredByScheduler":true}],
 | 
						|
			"ignorable":true
 | 
						|
		  }]
 | 
						|
		}`,
 | 
						|
			wantPlugins: map[string][]config.Plugin{
 | 
						|
				"QueueSortPlugin": {{Name: "PrioritySort"}},
 | 
						|
				"PreFilterPlugin": {
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"FilterPlugin": {
 | 
						|
					{Name: "NodeUnschedulable"},
 | 
						|
					{Name: "NodeName"},
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeAffinity"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "VolumeRestrictions"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
					{Name: "NodeLabel"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "EBSLimits"},
 | 
						|
					{Name: "GCEPDLimits"},
 | 
						|
					{Name: "NodeVolumeLimits"},
 | 
						|
					{Name: "AzureDiskLimits"},
 | 
						|
					{Name: "VolumeBinding"},
 | 
						|
					{Name: "VolumeZone"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"PreScorePlugin": {
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
					{Name: "DefaultPodTopologySpread"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
				},
 | 
						|
				"ScorePlugin": {
 | 
						|
					{Name: "NodeResourcesBalancedAllocation", Weight: 2},
 | 
						|
					{Name: "ImageLocality", Weight: 2},
 | 
						|
					{Name: "InterPodAffinity", Weight: 2},
 | 
						|
					{Name: "NodeResourcesLeastAllocated", Weight: 2},
 | 
						|
					{Name: "NodeResourcesMostAllocated", Weight: 2},
 | 
						|
					{Name: "NodeAffinity", Weight: 2},
 | 
						|
					{Name: "NodePreferAvoidPods", Weight: 2},
 | 
						|
					{Name: "RequestedToCapacityRatio", Weight: 2},
 | 
						|
					{Name: "DefaultPodTopologySpread", Weight: 2},
 | 
						|
					{Name: "TaintToleration", Weight: 2},
 | 
						|
				},
 | 
						|
				"BindPlugin":      {{Name: "DefaultBinder"}},
 | 
						|
				"ReservePlugin":   {{Name: "VolumeBinding"}},
 | 
						|
				"UnreservePlugin": {{Name: "VolumeBinding"}},
 | 
						|
				"PreBindPlugin":   {{Name: "VolumeBinding"}},
 | 
						|
				"PostBindPlugin":  {{Name: "VolumeBinding"}},
 | 
						|
			},
 | 
						|
			wantExtenders: []config.Extender{{
 | 
						|
				URLPrefix:        "/prefix",
 | 
						|
				FilterVerb:       "filter",
 | 
						|
				PrioritizeVerb:   "prioritize",
 | 
						|
				Weight:           1,
 | 
						|
				BindVerb:         "bind", // 1.11 restored case-sensitivity, but allowed either "BindVerb" or "bindVerb"
 | 
						|
				EnableHTTPS:      true,
 | 
						|
				TLSConfig:        &config.ExtenderTLSConfig{Insecure: true},
 | 
						|
				HTTPTimeout:      1,
 | 
						|
				NodeCacheCapable: true,
 | 
						|
				ManagedResources: []config.ExtenderManagedResource{{Name: "example.com/foo", IgnoredByScheduler: true}},
 | 
						|
				Ignorable:        true,
 | 
						|
			}},
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name: "1.14",
 | 
						|
			JSON: `{
 | 
						|
		  "kind": "Policy",
 | 
						|
		  "apiVersion": "v1",
 | 
						|
		  "predicates": [
 | 
						|
			{"name": "MatchNodeSelector"},
 | 
						|
			{"name": "PodFitsResources"},
 | 
						|
			{"name": "PodFitsHostPorts"},
 | 
						|
			{"name": "HostName"},
 | 
						|
			{"name": "NoDiskConflict"},
 | 
						|
			{"name": "NoVolumeZoneConflict"},
 | 
						|
			{"name": "PodToleratesNodeTaints"},
 | 
						|
			{"name": "MaxEBSVolumeCount"},
 | 
						|
			{"name": "MaxGCEPDVolumeCount"},
 | 
						|
			{"name": "MaxAzureDiskVolumeCount"},
 | 
						|
			{"name": "MaxCSIVolumeCountPred"},
 | 
						|
                        {"name": "MaxCinderVolumeCount"},
 | 
						|
			{"name": "MatchInterPodAffinity"},
 | 
						|
			{"name": "CheckVolumeBinding"},
 | 
						|
			{"name": "TestServiceAffinity", "argument": {"serviceAffinity" : {"labels" : ["region"]}}},
 | 
						|
			{"name": "TestLabelsPresence",  "argument": {"labelsPresence"  : {"labels" : ["foo"], "presence":true}}}
 | 
						|
		  ],"priorities": [
 | 
						|
			{"name": "EqualPriority",   "weight": 2},
 | 
						|
			{"name": "ImageLocalityPriority",   "weight": 2},
 | 
						|
			{"name": "LeastRequestedPriority",   "weight": 2},
 | 
						|
			{"name": "BalancedResourceAllocation",   "weight": 2},
 | 
						|
			{"name": "SelectorSpreadPriority",   "weight": 2},
 | 
						|
			{"name": "NodePreferAvoidPodsPriority",   "weight": 2},
 | 
						|
			{"name": "NodeAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "TaintTolerationPriority",   "weight": 2},
 | 
						|
			{"name": "InterPodAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "MostRequestedPriority",   "weight": 2},
 | 
						|
			{
 | 
						|
				"name": "RequestedToCapacityRatioPriority",
 | 
						|
				"weight": 2,
 | 
						|
				"argument": {
 | 
						|
				"requestedToCapacityRatioArguments": {
 | 
						|
					"shape": [
 | 
						|
						{"utilization": 0,  "score": 0},
 | 
						|
						{"utilization": 50, "score": 7}
 | 
						|
					]
 | 
						|
				}
 | 
						|
			}}
 | 
						|
		  ],"extenders": [{
 | 
						|
			"urlPrefix":        "/prefix",
 | 
						|
			"filterVerb":       "filter",
 | 
						|
			"prioritizeVerb":   "prioritize",
 | 
						|
			"weight":           1,
 | 
						|
			"bindVerb":         "bind",
 | 
						|
			"enableHttps":      true,
 | 
						|
			"tlsConfig":        {"Insecure":true},
 | 
						|
			"httpTimeout":      1,
 | 
						|
			"nodeCacheCapable": true,
 | 
						|
			"managedResources": [{"name":"example.com/foo","ignoredByScheduler":true}],
 | 
						|
			"ignorable":true
 | 
						|
		  }]
 | 
						|
		}`,
 | 
						|
			wantPlugins: map[string][]config.Plugin{
 | 
						|
				"QueueSortPlugin": {{Name: "PrioritySort"}},
 | 
						|
				"PreFilterPlugin": {
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"FilterPlugin": {
 | 
						|
					{Name: "NodeUnschedulable"},
 | 
						|
					{Name: "NodeName"},
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeAffinity"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "VolumeRestrictions"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
					{Name: "NodeLabel"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "EBSLimits"},
 | 
						|
					{Name: "GCEPDLimits"},
 | 
						|
					{Name: "NodeVolumeLimits"},
 | 
						|
					{Name: "AzureDiskLimits"},
 | 
						|
					{Name: "CinderLimits"},
 | 
						|
					{Name: "VolumeBinding"},
 | 
						|
					{Name: "VolumeZone"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"PreScorePlugin": {
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
					{Name: "DefaultPodTopologySpread"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
				},
 | 
						|
				"ScorePlugin": {
 | 
						|
					{Name: "NodeResourcesBalancedAllocation", Weight: 2},
 | 
						|
					{Name: "ImageLocality", Weight: 2},
 | 
						|
					{Name: "InterPodAffinity", Weight: 2},
 | 
						|
					{Name: "NodeResourcesLeastAllocated", Weight: 2},
 | 
						|
					{Name: "NodeResourcesMostAllocated", Weight: 2},
 | 
						|
					{Name: "NodeAffinity", Weight: 2},
 | 
						|
					{Name: "NodePreferAvoidPods", Weight: 2},
 | 
						|
					{Name: "RequestedToCapacityRatio", Weight: 2},
 | 
						|
					{Name: "DefaultPodTopologySpread", Weight: 2},
 | 
						|
					{Name: "TaintToleration", Weight: 2},
 | 
						|
				},
 | 
						|
				"BindPlugin":      {{Name: "DefaultBinder"}},
 | 
						|
				"ReservePlugin":   {{Name: "VolumeBinding"}},
 | 
						|
				"UnreservePlugin": {{Name: "VolumeBinding"}},
 | 
						|
				"PreBindPlugin":   {{Name: "VolumeBinding"}},
 | 
						|
				"PostBindPlugin":  {{Name: "VolumeBinding"}},
 | 
						|
			},
 | 
						|
			wantExtenders: []config.Extender{{
 | 
						|
				URLPrefix:        "/prefix",
 | 
						|
				FilterVerb:       "filter",
 | 
						|
				PrioritizeVerb:   "prioritize",
 | 
						|
				Weight:           1,
 | 
						|
				BindVerb:         "bind", // 1.11 restored case-sensitivity, but allowed either "BindVerb" or "bindVerb"
 | 
						|
				EnableHTTPS:      true,
 | 
						|
				TLSConfig:        &config.ExtenderTLSConfig{Insecure: true},
 | 
						|
				HTTPTimeout:      1,
 | 
						|
				NodeCacheCapable: true,
 | 
						|
				ManagedResources: []config.ExtenderManagedResource{{Name: "example.com/foo", IgnoredByScheduler: true}},
 | 
						|
				Ignorable:        true,
 | 
						|
			}},
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name: "1.16",
 | 
						|
			JSON: `{
 | 
						|
		  "kind": "Policy",
 | 
						|
		  "apiVersion": "v1",
 | 
						|
		  "predicates": [
 | 
						|
			{"name": "MatchNodeSelector"},
 | 
						|
			{"name": "PodFitsResources"},
 | 
						|
			{"name": "PodFitsHostPorts"},
 | 
						|
			{"name": "HostName"},
 | 
						|
			{"name": "NoDiskConflict"},
 | 
						|
			{"name": "NoVolumeZoneConflict"},
 | 
						|
			{"name": "PodToleratesNodeTaints"},
 | 
						|
			{"name": "MaxEBSVolumeCount"},
 | 
						|
			{"name": "MaxGCEPDVolumeCount"},
 | 
						|
			{"name": "MaxAzureDiskVolumeCount"},
 | 
						|
			{"name": "MaxCSIVolumeCountPred"},
 | 
						|
                        {"name": "MaxCinderVolumeCount"},
 | 
						|
			{"name": "MatchInterPodAffinity"},
 | 
						|
			{"name": "CheckVolumeBinding"},
 | 
						|
			{"name": "TestServiceAffinity", "argument": {"serviceAffinity" : {"labels" : ["region"]}}},
 | 
						|
			{"name": "TestLabelsPresence",  "argument": {"labelsPresence"  : {"labels" : ["foo"], "presence":true}}}
 | 
						|
		  ],"priorities": [
 | 
						|
			{"name": "EqualPriority",   "weight": 2},
 | 
						|
			{"name": "ImageLocalityPriority",   "weight": 2},
 | 
						|
			{"name": "LeastRequestedPriority",   "weight": 2},
 | 
						|
			{"name": "BalancedResourceAllocation",   "weight": 2},
 | 
						|
			{"name": "SelectorSpreadPriority",   "weight": 2},
 | 
						|
			{"name": "NodePreferAvoidPodsPriority",   "weight": 2},
 | 
						|
			{"name": "NodeAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "TaintTolerationPriority",   "weight": 2},
 | 
						|
			{"name": "InterPodAffinityPriority",   "weight": 2},
 | 
						|
			{"name": "MostRequestedPriority",   "weight": 2},
 | 
						|
			{
 | 
						|
				"name": "RequestedToCapacityRatioPriority",
 | 
						|
				"weight": 2,
 | 
						|
				"argument": {
 | 
						|
				"requestedToCapacityRatioArguments": {
 | 
						|
					"shape": [
 | 
						|
						{"utilization": 0,  "score": 0},
 | 
						|
						{"utilization": 50, "score": 7}
 | 
						|
					],
 | 
						|
					"resources": [
 | 
						|
						{"name": "intel.com/foo", "weight": 3},
 | 
						|
						{"name": "intel.com/bar", "weight": 5}
 | 
						|
					]
 | 
						|
				}
 | 
						|
			}}
 | 
						|
		  ],"extenders": [{
 | 
						|
			"urlPrefix":        "/prefix",
 | 
						|
			"filterVerb":       "filter",
 | 
						|
			"prioritizeVerb":   "prioritize",
 | 
						|
			"weight":           1,
 | 
						|
			"bindVerb":         "bind",
 | 
						|
			"enableHttps":      true,
 | 
						|
			"tlsConfig":        {"Insecure":true},
 | 
						|
			"httpTimeout":      1,
 | 
						|
			"nodeCacheCapable": true,
 | 
						|
			"managedResources": [{"name":"example.com/foo","ignoredByScheduler":true}],
 | 
						|
			"ignorable":true
 | 
						|
		  }]
 | 
						|
		}`,
 | 
						|
			wantPlugins: map[string][]config.Plugin{
 | 
						|
				"QueueSortPlugin": {{Name: "PrioritySort"}},
 | 
						|
				"PreFilterPlugin": {
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"FilterPlugin": {
 | 
						|
					{Name: "NodeUnschedulable"},
 | 
						|
					{Name: "NodeName"},
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeAffinity"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "VolumeRestrictions"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
					{Name: "NodeLabel"},
 | 
						|
					{Name: "ServiceAffinity"},
 | 
						|
					{Name: "EBSLimits"},
 | 
						|
					{Name: "GCEPDLimits"},
 | 
						|
					{Name: "NodeVolumeLimits"},
 | 
						|
					{Name: "AzureDiskLimits"},
 | 
						|
					{Name: "CinderLimits"},
 | 
						|
					{Name: "VolumeBinding"},
 | 
						|
					{Name: "VolumeZone"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"PreScorePlugin": {
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
					{Name: "DefaultPodTopologySpread"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
				},
 | 
						|
				"ScorePlugin": {
 | 
						|
					{Name: "NodeResourcesBalancedAllocation", Weight: 2},
 | 
						|
					{Name: "ImageLocality", Weight: 2},
 | 
						|
					{Name: "InterPodAffinity", Weight: 2},
 | 
						|
					{Name: "NodeResourcesLeastAllocated", Weight: 2},
 | 
						|
					{Name: "NodeResourcesMostAllocated", Weight: 2},
 | 
						|
					{Name: "NodeAffinity", Weight: 2},
 | 
						|
					{Name: "NodePreferAvoidPods", Weight: 2},
 | 
						|
					{Name: "RequestedToCapacityRatio", Weight: 2},
 | 
						|
					{Name: "DefaultPodTopologySpread", Weight: 2},
 | 
						|
					{Name: "TaintToleration", Weight: 2},
 | 
						|
				},
 | 
						|
				"BindPlugin":      {{Name: "DefaultBinder"}},
 | 
						|
				"ReservePlugin":   {{Name: "VolumeBinding"}},
 | 
						|
				"UnreservePlugin": {{Name: "VolumeBinding"}},
 | 
						|
				"PreBindPlugin":   {{Name: "VolumeBinding"}},
 | 
						|
				"PostBindPlugin":  {{Name: "VolumeBinding"}},
 | 
						|
			},
 | 
						|
			wantExtenders: []config.Extender{{
 | 
						|
				URLPrefix:        "/prefix",
 | 
						|
				FilterVerb:       "filter",
 | 
						|
				PrioritizeVerb:   "prioritize",
 | 
						|
				Weight:           1,
 | 
						|
				BindVerb:         "bind", // 1.11 restored case-sensitivity, but allowed either "BindVerb" or "bindVerb"
 | 
						|
				EnableHTTPS:      true,
 | 
						|
				TLSConfig:        &config.ExtenderTLSConfig{Insecure: true},
 | 
						|
				HTTPTimeout:      1,
 | 
						|
				NodeCacheCapable: true,
 | 
						|
				ManagedResources: []config.ExtenderManagedResource{{Name: "example.com/foo", IgnoredByScheduler: true}},
 | 
						|
				Ignorable:        true,
 | 
						|
			}},
 | 
						|
		},
 | 
						|
	}
 | 
						|
	for _, tc := range testcases {
 | 
						|
		t.Run(tc.name, func(t *testing.T) {
 | 
						|
			for feature, value := range tc.featureGates {
 | 
						|
				defer featuregatetesting.SetFeatureGateDuringTest(t, utilfeature.DefaultFeatureGate, feature, value)()
 | 
						|
			}
 | 
						|
 | 
						|
			policyConfigMap := v1.ConfigMap{
 | 
						|
				ObjectMeta: metav1.ObjectMeta{Namespace: metav1.NamespaceSystem, Name: "scheduler-custom-policy-config"},
 | 
						|
				Data:       map[string]string{config.SchedulerPolicyConfigMapKey: tc.JSON},
 | 
						|
			}
 | 
						|
			client := fake.NewSimpleClientset(&policyConfigMap)
 | 
						|
			algorithmSrc := config.SchedulerAlgorithmSource{
 | 
						|
				Policy: &config.SchedulerPolicySource{
 | 
						|
					ConfigMap: &config.SchedulerPolicyConfigMapSource{
 | 
						|
						Namespace: policyConfigMap.Namespace,
 | 
						|
						Name:      policyConfigMap.Name,
 | 
						|
					},
 | 
						|
				},
 | 
						|
			}
 | 
						|
			informerFactory := informers.NewSharedInformerFactory(client, 0)
 | 
						|
			recorderFactory := profile.NewRecorderFactory(events.NewBroadcaster(&events.EventSinkImpl{Interface: client.EventsV1beta1().Events("")}))
 | 
						|
 | 
						|
			sched, err := scheduler.New(
 | 
						|
				client,
 | 
						|
				informerFactory,
 | 
						|
				informerFactory.Core().V1().Pods(),
 | 
						|
				recorderFactory,
 | 
						|
				make(chan struct{}),
 | 
						|
				scheduler.WithAlgorithmSource(algorithmSrc),
 | 
						|
			)
 | 
						|
 | 
						|
			if err != nil {
 | 
						|
				t.Fatalf("Error constructing: %v", err)
 | 
						|
			}
 | 
						|
 | 
						|
			defProf := sched.Profiles["default-scheduler"]
 | 
						|
			gotPlugins := defProf.Framework.ListPlugins()
 | 
						|
			if diff := cmp.Diff(tc.wantPlugins, gotPlugins); diff != "" {
 | 
						|
				t.Errorf("unexpected plugins diff (-want, +got): %s", diff)
 | 
						|
			}
 | 
						|
 | 
						|
			gotExtenders := sched.Algorithm.Extenders()
 | 
						|
			var wantExtenders []*core.HTTPExtender
 | 
						|
			for _, e := range tc.wantExtenders {
 | 
						|
				extender, err := core.NewHTTPExtender(&e)
 | 
						|
				if err != nil {
 | 
						|
					t.Errorf("Error transforming extender: %+v", e)
 | 
						|
				}
 | 
						|
				wantExtenders = append(wantExtenders, extender.(*core.HTTPExtender))
 | 
						|
			}
 | 
						|
			for i := range gotExtenders {
 | 
						|
				if !core.Equal(wantExtenders[i], gotExtenders[i].(*core.HTTPExtender)) {
 | 
						|
					t.Errorf("Got extender #%d %+v, want %+v", i, gotExtenders[i], wantExtenders[i])
 | 
						|
				}
 | 
						|
			}
 | 
						|
		})
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestAlgorithmProviderCompatibility(t *testing.T) {
 | 
						|
	// Add serialized versions of scheduler config that exercise available options to ensure compatibility between releases
 | 
						|
	defaultPlugins := map[string][]config.Plugin{
 | 
						|
		"QueueSortPlugin": {
 | 
						|
			{Name: "PrioritySort"},
 | 
						|
		},
 | 
						|
		"PreFilterPlugin": {
 | 
						|
			{Name: "NodeResourcesFit"},
 | 
						|
			{Name: "NodePorts"},
 | 
						|
			{Name: "PodTopologySpread"},
 | 
						|
			{Name: "InterPodAffinity"},
 | 
						|
		},
 | 
						|
		"FilterPlugin": {
 | 
						|
			{Name: "NodeUnschedulable"},
 | 
						|
			{Name: "NodeResourcesFit"},
 | 
						|
			{Name: "NodeName"},
 | 
						|
			{Name: "NodePorts"},
 | 
						|
			{Name: "NodeAffinity"},
 | 
						|
			{Name: "VolumeRestrictions"},
 | 
						|
			{Name: "TaintToleration"},
 | 
						|
			{Name: "EBSLimits"},
 | 
						|
			{Name: "GCEPDLimits"},
 | 
						|
			{Name: "NodeVolumeLimits"},
 | 
						|
			{Name: "AzureDiskLimits"},
 | 
						|
			{Name: "VolumeBinding"},
 | 
						|
			{Name: "VolumeZone"},
 | 
						|
			{Name: "PodTopologySpread"},
 | 
						|
			{Name: "InterPodAffinity"},
 | 
						|
		},
 | 
						|
		"PreScorePlugin": {
 | 
						|
			{Name: "InterPodAffinity"},
 | 
						|
			{Name: "PodTopologySpread"},
 | 
						|
			{Name: "TaintToleration"},
 | 
						|
			{Name: "DefaultPodTopologySpread"},
 | 
						|
		},
 | 
						|
		"ScorePlugin": {
 | 
						|
			{Name: "NodeResourcesBalancedAllocation", Weight: 1},
 | 
						|
			{Name: "ImageLocality", Weight: 1},
 | 
						|
			{Name: "InterPodAffinity", Weight: 1},
 | 
						|
			{Name: "NodeResourcesLeastAllocated", Weight: 1},
 | 
						|
			{Name: "NodeAffinity", Weight: 1},
 | 
						|
			{Name: "NodePreferAvoidPods", Weight: 10000},
 | 
						|
			{Name: "PodTopologySpread", Weight: 2},
 | 
						|
			{Name: "TaintToleration", Weight: 1},
 | 
						|
			{Name: "DefaultPodTopologySpread", Weight: 1},
 | 
						|
		},
 | 
						|
		"BindPlugin":      {{Name: "DefaultBinder"}},
 | 
						|
		"ReservePlugin":   {{Name: "VolumeBinding"}},
 | 
						|
		"UnreservePlugin": {{Name: "VolumeBinding"}},
 | 
						|
		"PreBindPlugin":   {{Name: "VolumeBinding"}},
 | 
						|
		"PostBindPlugin":  {{Name: "VolumeBinding"}},
 | 
						|
	}
 | 
						|
 | 
						|
	testcases := []struct {
 | 
						|
		name        string
 | 
						|
		provider    string
 | 
						|
		wantPlugins map[string][]config.Plugin
 | 
						|
	}{
 | 
						|
		{
 | 
						|
			name:        "No Provider specified",
 | 
						|
			wantPlugins: defaultPlugins,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name:        "DefaultProvider",
 | 
						|
			provider:    config.SchedulerDefaultProviderName,
 | 
						|
			wantPlugins: defaultPlugins,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name:     "ClusterAutoscalerProvider",
 | 
						|
			provider: algorithmprovider.ClusterAutoscalerProvider,
 | 
						|
			wantPlugins: map[string][]config.Plugin{
 | 
						|
				"QueueSortPlugin": {
 | 
						|
					{Name: "PrioritySort"},
 | 
						|
				},
 | 
						|
				"PreFilterPlugin": {
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "PodTopologySpread"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"FilterPlugin": {
 | 
						|
					{Name: "NodeUnschedulable"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "NodeName"},
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeAffinity"},
 | 
						|
					{Name: "VolumeRestrictions"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
					{Name: "EBSLimits"},
 | 
						|
					{Name: "GCEPDLimits"},
 | 
						|
					{Name: "NodeVolumeLimits"},
 | 
						|
					{Name: "AzureDiskLimits"},
 | 
						|
					{Name: "VolumeBinding"},
 | 
						|
					{Name: "VolumeZone"},
 | 
						|
					{Name: "PodTopologySpread"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"PreScorePlugin": {
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
					{Name: "PodTopologySpread"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
					{Name: "DefaultPodTopologySpread"},
 | 
						|
				},
 | 
						|
				"ScorePlugin": {
 | 
						|
					{Name: "NodeResourcesBalancedAllocation", Weight: 1},
 | 
						|
					{Name: "ImageLocality", Weight: 1},
 | 
						|
					{Name: "InterPodAffinity", Weight: 1},
 | 
						|
					{Name: "NodeResourcesMostAllocated", Weight: 1},
 | 
						|
					{Name: "NodeAffinity", Weight: 1},
 | 
						|
					{Name: "NodePreferAvoidPods", Weight: 10000},
 | 
						|
					{Name: "PodTopologySpread", Weight: 2},
 | 
						|
					{Name: "TaintToleration", Weight: 1},
 | 
						|
					{Name: "DefaultPodTopologySpread", Weight: 1},
 | 
						|
				},
 | 
						|
				"ReservePlugin":   {{Name: "VolumeBinding"}},
 | 
						|
				"UnreservePlugin": {{Name: "VolumeBinding"}},
 | 
						|
				"PreBindPlugin":   {{Name: "VolumeBinding"}},
 | 
						|
				"BindPlugin":      {{Name: "DefaultBinder"}},
 | 
						|
				"PostBindPlugin":  {{Name: "VolumeBinding"}},
 | 
						|
			},
 | 
						|
		},
 | 
						|
	}
 | 
						|
	for _, tc := range testcases {
 | 
						|
		t.Run(tc.name, func(t *testing.T) {
 | 
						|
			var opts []scheduler.Option
 | 
						|
			if len(tc.provider) != 0 {
 | 
						|
				opts = append(opts, scheduler.WithAlgorithmSource(config.SchedulerAlgorithmSource{
 | 
						|
					Provider: &tc.provider,
 | 
						|
				}))
 | 
						|
			}
 | 
						|
 | 
						|
			client := fake.NewSimpleClientset()
 | 
						|
			informerFactory := informers.NewSharedInformerFactory(client, 0)
 | 
						|
			recorderFactory := profile.NewRecorderFactory(events.NewBroadcaster(&events.EventSinkImpl{Interface: client.EventsV1beta1().Events("")}))
 | 
						|
 | 
						|
			sched, err := scheduler.New(
 | 
						|
				client,
 | 
						|
				informerFactory,
 | 
						|
				informerFactory.Core().V1().Pods(),
 | 
						|
				recorderFactory,
 | 
						|
				make(chan struct{}),
 | 
						|
				opts...,
 | 
						|
			)
 | 
						|
 | 
						|
			if err != nil {
 | 
						|
				t.Fatalf("Error constructing: %v", err)
 | 
						|
			}
 | 
						|
 | 
						|
			defProf := sched.Profiles["default-scheduler"]
 | 
						|
			gotPlugins := defProf.ListPlugins()
 | 
						|
			if diff := cmp.Diff(tc.wantPlugins, gotPlugins); diff != "" {
 | 
						|
				t.Errorf("unexpected plugins diff (-want, +got): %s", diff)
 | 
						|
			}
 | 
						|
		})
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestPluginsConfigurationCompatibility(t *testing.T) {
 | 
						|
	defaultPlugins := map[string][]config.Plugin{
 | 
						|
		"QueueSortPlugin": {
 | 
						|
			{Name: "PrioritySort"},
 | 
						|
		},
 | 
						|
		"PreFilterPlugin": {
 | 
						|
			{Name: "NodeResourcesFit"},
 | 
						|
			{Name: "NodePorts"},
 | 
						|
			{Name: "PodTopologySpread"},
 | 
						|
			{Name: "InterPodAffinity"},
 | 
						|
		},
 | 
						|
		"FilterPlugin": {
 | 
						|
			{Name: "NodeUnschedulable"},
 | 
						|
			{Name: "NodeResourcesFit"},
 | 
						|
			{Name: "NodeName"},
 | 
						|
			{Name: "NodePorts"},
 | 
						|
			{Name: "NodeAffinity"},
 | 
						|
			{Name: "VolumeRestrictions"},
 | 
						|
			{Name: "TaintToleration"},
 | 
						|
			{Name: "EBSLimits"},
 | 
						|
			{Name: "GCEPDLimits"},
 | 
						|
			{Name: "NodeVolumeLimits"},
 | 
						|
			{Name: "AzureDiskLimits"},
 | 
						|
			{Name: "VolumeBinding"},
 | 
						|
			{Name: "VolumeZone"},
 | 
						|
			{Name: "PodTopologySpread"},
 | 
						|
			{Name: "InterPodAffinity"},
 | 
						|
		},
 | 
						|
		"PreScorePlugin": {
 | 
						|
			{Name: "InterPodAffinity"},
 | 
						|
			{Name: "PodTopologySpread"},
 | 
						|
			{Name: "TaintToleration"},
 | 
						|
			{Name: "DefaultPodTopologySpread"},
 | 
						|
		},
 | 
						|
		"ScorePlugin": {
 | 
						|
			{Name: "NodeResourcesBalancedAllocation", Weight: 1},
 | 
						|
			{Name: "ImageLocality", Weight: 1},
 | 
						|
			{Name: "InterPodAffinity", Weight: 1},
 | 
						|
			{Name: "NodeResourcesLeastAllocated", Weight: 1},
 | 
						|
			{Name: "NodeAffinity", Weight: 1},
 | 
						|
			{Name: "NodePreferAvoidPods", Weight: 10000},
 | 
						|
			{Name: "PodTopologySpread", Weight: 2},
 | 
						|
			{Name: "TaintToleration", Weight: 1},
 | 
						|
			{Name: "DefaultPodTopologySpread", Weight: 1},
 | 
						|
		},
 | 
						|
		"ReservePlugin":   {{Name: "VolumeBinding"}},
 | 
						|
		"UnreservePlugin": {{Name: "VolumeBinding"}},
 | 
						|
		"PreBindPlugin":   {{Name: "VolumeBinding"}},
 | 
						|
		"BindPlugin":      {{Name: "DefaultBinder"}},
 | 
						|
		"PostBindPlugin":  {{Name: "VolumeBinding"}},
 | 
						|
	}
 | 
						|
 | 
						|
	testcases := []struct {
 | 
						|
		name             string
 | 
						|
		plugins          config.Plugins
 | 
						|
		wantPlugins      map[string][]config.Plugin
 | 
						|
		pluginConfig     []config.PluginConfig
 | 
						|
		wantPluginConfig []config.PluginConfig
 | 
						|
	}{
 | 
						|
		{
 | 
						|
			name:             "default plugins",
 | 
						|
			wantPlugins:      defaultPlugins,
 | 
						|
			wantPluginConfig: nil,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name:        "default plugins with customized plugin config",
 | 
						|
			wantPlugins: defaultPlugins,
 | 
						|
			pluginConfig: []config.PluginConfig{
 | 
						|
				{
 | 
						|
					Name: "NodeResourcesFit",
 | 
						|
					Args: &config.NodeResourcesFitArgs{
 | 
						|
						IgnoredResources: []string{"foo", "bar"},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				{
 | 
						|
					Name: "PodTopologySpread",
 | 
						|
					Args: &config.PodTopologySpreadArgs{
 | 
						|
						DefaultConstraints: []v1.TopologySpreadConstraint{
 | 
						|
							{
 | 
						|
								MaxSkew:           1,
 | 
						|
								TopologyKey:       "foo",
 | 
						|
								WhenUnsatisfiable: v1.DoNotSchedule,
 | 
						|
							},
 | 
						|
							{
 | 
						|
								MaxSkew:           10,
 | 
						|
								TopologyKey:       "bar",
 | 
						|
								WhenUnsatisfiable: v1.ScheduleAnyway,
 | 
						|
							},
 | 
						|
						},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				{
 | 
						|
					Name: "RequestedToCapacityRatio",
 | 
						|
					Args: &config.RequestedToCapacityRatioArgs{
 | 
						|
						Shape: []config.UtilizationShapePoint{
 | 
						|
							{Utilization: 5, Score: 5},
 | 
						|
						},
 | 
						|
						Resources: []config.ResourceSpec{
 | 
						|
							{Name: "cpu", Weight: 10},
 | 
						|
						},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				{
 | 
						|
					Name: "InterPodAffinity",
 | 
						|
					Args: &config.InterPodAffinityArgs{
 | 
						|
						HardPodAffinityWeight: 100,
 | 
						|
					},
 | 
						|
				},
 | 
						|
				{
 | 
						|
					Name: "NodeLabel",
 | 
						|
					Args: &config.NodeLabelArgs{
 | 
						|
						PresentLabels:           []string{"foo", "bar"},
 | 
						|
						AbsentLabels:            []string{"apple"},
 | 
						|
						PresentLabelsPreference: []string{"dog"},
 | 
						|
						AbsentLabelsPreference:  []string{"cat"},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				{
 | 
						|
					Name: "ServiceAffinity",
 | 
						|
					Args: &config.ServiceAffinityArgs{
 | 
						|
						AffinityLabels:               []string{"foo", "bar"},
 | 
						|
						AntiAffinityLabelsPreference: []string{"disk", "flash"},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				{
 | 
						|
					Name: "VolumeBinding",
 | 
						|
					Args: &config.VolumeBindingArgs{
 | 
						|
						BindTimeoutSeconds: 300,
 | 
						|
					},
 | 
						|
				},
 | 
						|
			},
 | 
						|
			wantPluginConfig: []config.PluginConfig{
 | 
						|
				{
 | 
						|
					Name: "NodeResourcesFit",
 | 
						|
					Args: &config.NodeResourcesFitArgs{
 | 
						|
						IgnoredResources: []string{"foo", "bar"},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				{
 | 
						|
					Name: "PodTopologySpread",
 | 
						|
					Args: &config.PodTopologySpreadArgs{
 | 
						|
						DefaultConstraints: []v1.TopologySpreadConstraint{
 | 
						|
							{
 | 
						|
								MaxSkew:           1,
 | 
						|
								TopologyKey:       "foo",
 | 
						|
								WhenUnsatisfiable: v1.DoNotSchedule,
 | 
						|
							},
 | 
						|
							{
 | 
						|
								MaxSkew:           10,
 | 
						|
								TopologyKey:       "bar",
 | 
						|
								WhenUnsatisfiable: v1.ScheduleAnyway,
 | 
						|
							},
 | 
						|
						},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				{
 | 
						|
					Name: "RequestedToCapacityRatio",
 | 
						|
					Args: &config.RequestedToCapacityRatioArgs{
 | 
						|
						Shape: []config.UtilizationShapePoint{
 | 
						|
							{Utilization: 5, Score: 5},
 | 
						|
						},
 | 
						|
						Resources: []config.ResourceSpec{
 | 
						|
							{Name: "cpu", Weight: 10},
 | 
						|
						},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				{
 | 
						|
					Name: "InterPodAffinity",
 | 
						|
					Args: &config.InterPodAffinityArgs{
 | 
						|
						HardPodAffinityWeight: 100,
 | 
						|
					},
 | 
						|
				},
 | 
						|
				{
 | 
						|
					Name: "NodeLabel",
 | 
						|
					Args: &config.NodeLabelArgs{
 | 
						|
						PresentLabels:           []string{"foo", "bar"},
 | 
						|
						AbsentLabels:            []string{"apple"},
 | 
						|
						PresentLabelsPreference: []string{"dog"},
 | 
						|
						AbsentLabelsPreference:  []string{"cat"},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				{
 | 
						|
					Name: "ServiceAffinity",
 | 
						|
					Args: &config.ServiceAffinityArgs{
 | 
						|
						AffinityLabels:               []string{"foo", "bar"},
 | 
						|
						AntiAffinityLabelsPreference: []string{"disk", "flash"},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				{
 | 
						|
					Name: "VolumeBinding",
 | 
						|
					Args: &config.VolumeBindingArgs{
 | 
						|
						BindTimeoutSeconds: 300,
 | 
						|
					},
 | 
						|
				},
 | 
						|
			},
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name: "disable some default plugins",
 | 
						|
			plugins: config.Plugins{
 | 
						|
				PreFilter: &config.PluginSet{
 | 
						|
					Disabled: []config.Plugin{
 | 
						|
						{Name: "NodeResourcesFit"},
 | 
						|
						{Name: "NodePorts"},
 | 
						|
						{Name: "InterPodAffinity"},
 | 
						|
						{Name: "PodTopologySpread"},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				Filter: &config.PluginSet{
 | 
						|
					Disabled: []config.Plugin{
 | 
						|
						{Name: "NodeUnschedulable"},
 | 
						|
						{Name: "NodeResourcesFit"},
 | 
						|
						{Name: "NodeName"},
 | 
						|
						{Name: "NodePorts"},
 | 
						|
						{Name: "NodeAffinity"},
 | 
						|
						{Name: "VolumeRestrictions"},
 | 
						|
						{Name: "TaintToleration"},
 | 
						|
						{Name: "EBSLimits"},
 | 
						|
						{Name: "GCEPDLimits"},
 | 
						|
						{Name: "NodeVolumeLimits"},
 | 
						|
						{Name: "AzureDiskLimits"},
 | 
						|
						{Name: "VolumeBinding"},
 | 
						|
						{Name: "VolumeZone"},
 | 
						|
						{Name: "InterPodAffinity"},
 | 
						|
						{Name: "PodTopologySpread"},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				PreScore: &config.PluginSet{
 | 
						|
					Disabled: []config.Plugin{
 | 
						|
						{Name: "InterPodAffinity"},
 | 
						|
						{Name: "DefaultPodTopologySpread"},
 | 
						|
						{Name: "TaintToleration"},
 | 
						|
						{Name: "PodTopologySpread"},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				Score: &config.PluginSet{
 | 
						|
					Disabled: []config.Plugin{
 | 
						|
						{Name: "NodeResourcesBalancedAllocation"},
 | 
						|
						{Name: "ImageLocality"},
 | 
						|
						{Name: "InterPodAffinity"},
 | 
						|
						{Name: "NodeResourcesLeastAllocated"},
 | 
						|
						{Name: "NodeAffinity"},
 | 
						|
						{Name: "NodePreferAvoidPods"},
 | 
						|
						{Name: "DefaultPodTopologySpread"},
 | 
						|
						{Name: "TaintToleration"},
 | 
						|
						{Name: "PodTopologySpread"},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				PreBind: &config.PluginSet{
 | 
						|
					Disabled: []config.Plugin{
 | 
						|
						{Name: "VolumeBinding"},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				PostBind: &config.PluginSet{
 | 
						|
					Disabled: []config.Plugin{
 | 
						|
						{Name: "VolumeBinding"},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				Reserve: &config.PluginSet{
 | 
						|
					Disabled: []config.Plugin{
 | 
						|
						{Name: "VolumeBinding"},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				Unreserve: &config.PluginSet{
 | 
						|
					Disabled: []config.Plugin{
 | 
						|
						{Name: "VolumeBinding"},
 | 
						|
					},
 | 
						|
				},
 | 
						|
			},
 | 
						|
			wantPlugins: map[string][]config.Plugin{
 | 
						|
				"QueueSortPlugin": {
 | 
						|
					{Name: "PrioritySort"},
 | 
						|
				},
 | 
						|
				"BindPlugin": {{Name: "DefaultBinder"}},
 | 
						|
			},
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name: "reverse default plugins order with changing score weight",
 | 
						|
			plugins: config.Plugins{
 | 
						|
				QueueSort: &config.PluginSet{
 | 
						|
					Enabled: []config.Plugin{
 | 
						|
						{Name: "PrioritySort"},
 | 
						|
					},
 | 
						|
					Disabled: []config.Plugin{
 | 
						|
						{Name: "*"},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				PreFilter: &config.PluginSet{
 | 
						|
					Enabled: []config.Plugin{
 | 
						|
						{Name: "InterPodAffinity"},
 | 
						|
						{Name: "NodePorts"},
 | 
						|
						{Name: "NodeResourcesFit"},
 | 
						|
					},
 | 
						|
					Disabled: []config.Plugin{
 | 
						|
						{Name: "*"},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				Filter: &config.PluginSet{
 | 
						|
					Enabled: []config.Plugin{
 | 
						|
						{Name: "InterPodAffinity"},
 | 
						|
						{Name: "VolumeZone"},
 | 
						|
						{Name: "VolumeBinding"},
 | 
						|
						{Name: "AzureDiskLimits"},
 | 
						|
						{Name: "NodeVolumeLimits"},
 | 
						|
						{Name: "GCEPDLimits"},
 | 
						|
						{Name: "EBSLimits"},
 | 
						|
						{Name: "TaintToleration"},
 | 
						|
						{Name: "VolumeRestrictions"},
 | 
						|
						{Name: "NodeAffinity"},
 | 
						|
						{Name: "NodePorts"},
 | 
						|
						{Name: "NodeName"},
 | 
						|
						{Name: "NodeResourcesFit"},
 | 
						|
						{Name: "NodeUnschedulable"},
 | 
						|
					},
 | 
						|
					Disabled: []config.Plugin{
 | 
						|
						{Name: "*"},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				PreScore: &config.PluginSet{
 | 
						|
					Enabled: []config.Plugin{
 | 
						|
						{Name: "TaintToleration"},
 | 
						|
						{Name: "DefaultPodTopologySpread"},
 | 
						|
						{Name: "InterPodAffinity"},
 | 
						|
					},
 | 
						|
					Disabled: []config.Plugin{
 | 
						|
						{Name: "*"},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				Score: &config.PluginSet{
 | 
						|
					Enabled: []config.Plugin{
 | 
						|
						{Name: "TaintToleration", Weight: 24},
 | 
						|
						{Name: "DefaultPodTopologySpread", Weight: 24},
 | 
						|
						{Name: "NodePreferAvoidPods", Weight: 24},
 | 
						|
						{Name: "NodeAffinity", Weight: 24},
 | 
						|
						{Name: "NodeResourcesLeastAllocated", Weight: 24},
 | 
						|
						{Name: "InterPodAffinity", Weight: 24},
 | 
						|
						{Name: "ImageLocality", Weight: 24},
 | 
						|
						{Name: "NodeResourcesBalancedAllocation", Weight: 24},
 | 
						|
					},
 | 
						|
					Disabled: []config.Plugin{
 | 
						|
						{Name: "*"},
 | 
						|
					},
 | 
						|
				},
 | 
						|
				Bind: &config.PluginSet{
 | 
						|
					Enabled:  []config.Plugin{{Name: "DefaultBinder"}},
 | 
						|
					Disabled: []config.Plugin{{Name: "*"}},
 | 
						|
				},
 | 
						|
			},
 | 
						|
			wantPlugins: map[string][]config.Plugin{
 | 
						|
				"QueueSortPlugin": {
 | 
						|
					{Name: "PrioritySort"},
 | 
						|
				},
 | 
						|
				"PreFilterPlugin": {
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
				},
 | 
						|
				"FilterPlugin": {
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
					{Name: "VolumeZone"},
 | 
						|
					{Name: "VolumeBinding"},
 | 
						|
					{Name: "AzureDiskLimits"},
 | 
						|
					{Name: "NodeVolumeLimits"},
 | 
						|
					{Name: "GCEPDLimits"},
 | 
						|
					{Name: "EBSLimits"},
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
					{Name: "VolumeRestrictions"},
 | 
						|
					{Name: "NodeAffinity"},
 | 
						|
					{Name: "NodePorts"},
 | 
						|
					{Name: "NodeName"},
 | 
						|
					{Name: "NodeResourcesFit"},
 | 
						|
					{Name: "NodeUnschedulable"},
 | 
						|
				},
 | 
						|
				"PreScorePlugin": {
 | 
						|
					{Name: "TaintToleration"},
 | 
						|
					{Name: "DefaultPodTopologySpread"},
 | 
						|
					{Name: "InterPodAffinity"},
 | 
						|
				},
 | 
						|
				"ScorePlugin": {
 | 
						|
					{Name: "TaintToleration", Weight: 24},
 | 
						|
					{Name: "DefaultPodTopologySpread", Weight: 24},
 | 
						|
					{Name: "NodePreferAvoidPods", Weight: 24},
 | 
						|
					{Name: "NodeAffinity", Weight: 24},
 | 
						|
					{Name: "NodeResourcesLeastAllocated", Weight: 24},
 | 
						|
					{Name: "InterPodAffinity", Weight: 24},
 | 
						|
					{Name: "ImageLocality", Weight: 24},
 | 
						|
					{Name: "NodeResourcesBalancedAllocation", Weight: 24},
 | 
						|
				},
 | 
						|
				"ReservePlugin":   {{Name: "VolumeBinding"}},
 | 
						|
				"UnreservePlugin": {{Name: "VolumeBinding"}},
 | 
						|
				"PreBindPlugin":   {{Name: "VolumeBinding"}},
 | 
						|
				"BindPlugin":      {{Name: "DefaultBinder"}},
 | 
						|
				"PostBindPlugin":  {{Name: "VolumeBinding"}},
 | 
						|
			},
 | 
						|
			wantPluginConfig: nil,
 | 
						|
		},
 | 
						|
	}
 | 
						|
	for _, tc := range testcases {
 | 
						|
		t.Run(tc.name, func(t *testing.T) {
 | 
						|
 | 
						|
			client := fake.NewSimpleClientset()
 | 
						|
			informerFactory := informers.NewSharedInformerFactory(client, 0)
 | 
						|
			recorderFactory := profile.NewRecorderFactory(events.NewBroadcaster(&events.EventSinkImpl{Interface: client.EventsV1beta1().Events("")}))
 | 
						|
 | 
						|
			sched, err := scheduler.New(
 | 
						|
				client,
 | 
						|
				informerFactory,
 | 
						|
				informerFactory.Core().V1().Pods(),
 | 
						|
				recorderFactory,
 | 
						|
				make(chan struct{}),
 | 
						|
				scheduler.WithProfiles(config.KubeSchedulerProfile{
 | 
						|
					SchedulerName: v1.DefaultSchedulerName,
 | 
						|
					Plugins:       &tc.plugins,
 | 
						|
					PluginConfig:  tc.pluginConfig,
 | 
						|
				}),
 | 
						|
				scheduler.WithBuildFrameworkCapturer(func(p config.KubeSchedulerProfile) {
 | 
						|
					if p.SchedulerName != v1.DefaultSchedulerName {
 | 
						|
						t.Errorf("unexpected scheduler name (want %q, got %q)", v1.DefaultSchedulerName, p.SchedulerName)
 | 
						|
					}
 | 
						|
					if diff := cmp.Diff(tc.wantPluginConfig, p.PluginConfig); diff != "" {
 | 
						|
						t.Errorf("unexpected plugins diff (-want, +got): %s", diff)
 | 
						|
					}
 | 
						|
				}),
 | 
						|
			)
 | 
						|
 | 
						|
			if err != nil {
 | 
						|
				t.Fatalf("Error constructing: %v", err)
 | 
						|
			}
 | 
						|
 | 
						|
			defProf := sched.Profiles[v1.DefaultSchedulerName]
 | 
						|
			gotPlugins := defProf.ListPlugins()
 | 
						|
			if diff := cmp.Diff(tc.wantPlugins, gotPlugins); diff != "" {
 | 
						|
				t.Errorf("unexpected plugins diff (-want, +got): %s", diff)
 | 
						|
			}
 | 
						|
		})
 | 
						|
	}
 | 
						|
}
 |