Merge pull request #83652 from Jefftree/taint-tolerations
promote e2e tests for taint-tolerations in predicates
This commit is contained in:
1
test/conformance/testdata/conformance.txt
vendored
1
test/conformance/testdata/conformance.txt
vendored
@@ -267,6 +267,7 @@ test/e2e/node/pre_stop.go: "should call prestop when killing a pod"
|
|||||||
test/e2e/scheduling/predicates.go: "validates resource limits of pods that are allowed to run"
|
test/e2e/scheduling/predicates.go: "validates resource limits of pods that are allowed to run"
|
||||||
test/e2e/scheduling/predicates.go: "validates that NodeSelector is respected if not matching"
|
test/e2e/scheduling/predicates.go: "validates that NodeSelector is respected if not matching"
|
||||||
test/e2e/scheduling/predicates.go: "validates that NodeSelector is respected if matching"
|
test/e2e/scheduling/predicates.go: "validates that NodeSelector is respected if matching"
|
||||||
|
test/e2e/scheduling/predicates.go: "validates that taints-tolerations is respected if matching"
|
||||||
test/e2e/scheduling/predicates.go: "validates that there is no conflict between pods with same hostPort but different hostIP and protocol"
|
test/e2e/scheduling/predicates.go: "validates that there is no conflict between pods with same hostPort but different hostIP and protocol"
|
||||||
test/e2e/scheduling/predicates.go: "validates that there exists conflict between pods with same hostPort and protocol but one using 0.0.0.0 hostIP"
|
test/e2e/scheduling/predicates.go: "validates that there exists conflict between pods with same hostPort and protocol but one using 0.0.0.0 hostIP"
|
||||||
test/e2e/scheduling/taints.go: "removing taint cancels eviction"
|
test/e2e/scheduling/taints.go: "removing taint cancels eviction"
|
||||||
|
@@ -454,11 +454,14 @@ var _ = SIGDescribe("SchedulerPredicates [Serial]", func() {
|
|||||||
framework.ExpectEqual(labelPod.Spec.NodeName, nodeName)
|
framework.ExpectEqual(labelPod.Spec.NodeName, nodeName)
|
||||||
})
|
})
|
||||||
|
|
||||||
// 1. Run a pod to get an available node, then delete the pod
|
/*
|
||||||
// 2. Taint the node with a random taint
|
Release : v1.18
|
||||||
// 3. Try to relaunch the pod with tolerations tolerate the taints on node,
|
Testname: Scheduler, taints-tolerations matching
|
||||||
// and the pod's nodeName specified to the name of node found in step 1
|
Description: Find an available node and taint it with a key with effect NoSchedule. Schedule a pod with a
|
||||||
ginkgo.It("validates that taints-tolerations is respected if matching", func() {
|
corresponding nodeLabel and toleration spec such that it should only be able to run on the selected node.
|
||||||
|
Ensure that the pod is scheduled and running on the node.
|
||||||
|
*/
|
||||||
|
framework.ConformanceIt("validates that taints-tolerations is respected if matching [Disruptive]", func() {
|
||||||
nodeName := getNodeThatCanRunPodWithoutToleration(f)
|
nodeName := getNodeThatCanRunPodWithoutToleration(f)
|
||||||
|
|
||||||
ginkgo.By("Trying to apply a random taint on the found node.")
|
ginkgo.By("Trying to apply a random taint on the found node.")
|
||||||
@@ -486,12 +489,7 @@ var _ = SIGDescribe("SchedulerPredicates [Serial]", func() {
|
|||||||
NodeSelector: map[string]string{labelKey: labelValue},
|
NodeSelector: map[string]string{labelKey: labelValue},
|
||||||
})
|
})
|
||||||
|
|
||||||
// check that pod got scheduled. We intentionally DO NOT check that the
|
framework.ExpectNoError(e2epod.WaitForPodNameRunningInNamespace(cs, ns, tolerationPodName))
|
||||||
// pod is running because this will create a race condition with the
|
|
||||||
// kubelet and the scheduler: the scheduler might have scheduled a pod
|
|
||||||
// already when the kubelet does not know about its new taint yet. The
|
|
||||||
// kubelet will then refuse to launch the pod.
|
|
||||||
framework.ExpectNoError(e2epod.WaitForPodNotPending(cs, ns, tolerationPodName))
|
|
||||||
deployedPod, err := cs.CoreV1().Pods(ns).Get(tolerationPodName, metav1.GetOptions{})
|
deployedPod, err := cs.CoreV1().Pods(ns).Get(tolerationPodName, metav1.GetOptions{})
|
||||||
framework.ExpectNoError(err)
|
framework.ExpectNoError(err)
|
||||||
framework.ExpectEqual(deployedPod.Spec.NodeName, nodeName)
|
framework.ExpectEqual(deployedPod.Spec.NodeName, nodeName)
|
||||||
|
Reference in New Issue
Block a user