Revert "Switched watches in tests require ResourceVersion to be passed"
This commit is contained in:
		| @@ -131,10 +131,10 @@ var _ = framework.KubeDescribe("ConfigMap", func() { | |||||||
| 			f.Client.Pods(f.Namespace.Name).Delete(pod.Name, api.NewDeleteOptions(0)) | 			f.Client.Pods(f.Namespace.Name).Delete(pod.Name, api.NewDeleteOptions(0)) | ||||||
| 		}() | 		}() | ||||||
| 		By("Creating the pod") | 		By("Creating the pod") | ||||||
| 		pod, err = f.Client.Pods(f.Namespace.Name).Create(pod) | 		_, err = f.Client.Pods(f.Namespace.Name).Create(pod) | ||||||
| 		Expect(err).NotTo(HaveOccurred()) | 		Expect(err).NotTo(HaveOccurred()) | ||||||
|  |  | ||||||
| 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(f.Client, pod)) | 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(f.Client, pod.Name, f.Namespace.Name)) | ||||||
|  |  | ||||||
| 		pollLogs := func() (string, error) { | 		pollLogs := func() (string, error) { | ||||||
| 			return framework.GetPodLogs(f.Client, f.Namespace.Name, pod.Name, containerName) | 			return framework.GetPodLogs(f.Client, f.Namespace.Name, pod.Name, containerName) | ||||||
|   | |||||||
| @@ -245,8 +245,7 @@ func verifyDNSPodIsRunning(f *framework.Framework) { | |||||||
| 	if len(dnsPods.Items) < 1 { | 	if len(dnsPods.Items) < 1 { | ||||||
| 		framework.Failf("No pods match the label selector %v", dnsServiceLabelSelector.String()) | 		framework.Failf("No pods match the label selector %v", dnsServiceLabelSelector.String()) | ||||||
| 	} | 	} | ||||||
| 	pod := dnsPods.Items[0] | 	framework.ExpectNoError(framework.WaitForPodRunningInNamespace(f.Client, dnsPods.Items[0].Name, api.NamespaceSystem)) | ||||||
| 	framework.ExpectNoError(framework.WaitForPodRunningInNamespace(f.Client, &pod)) |  | ||||||
| } | } | ||||||
|  |  | ||||||
| func createServiceSpec(serviceName string, isHeadless bool, selector map[string]string) *api.Service { | func createServiceSpec(serviceName string, isHeadless bool, selector map[string]string) *api.Service { | ||||||
|   | |||||||
| @@ -70,10 +70,10 @@ var _ = framework.KubeDescribe("Downward API volume", func() { | |||||||
| 			f.Client.Pods(f.Namespace.Name).Delete(pod.Name, api.NewDeleteOptions(0)) | 			f.Client.Pods(f.Namespace.Name).Delete(pod.Name, api.NewDeleteOptions(0)) | ||||||
| 		}() | 		}() | ||||||
| 		By("Creating the pod") | 		By("Creating the pod") | ||||||
| 		pod, err := f.Client.Pods(f.Namespace.Name).Create(pod) | 		_, err := f.Client.Pods(f.Namespace.Name).Create(pod) | ||||||
| 		Expect(err).NotTo(HaveOccurred()) | 		Expect(err).NotTo(HaveOccurred()) | ||||||
|  |  | ||||||
| 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(f.Client, pod)) | 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(f.Client, pod.Name, f.Namespace.Name)) | ||||||
|  |  | ||||||
| 		Eventually(func() (string, error) { | 		Eventually(func() (string, error) { | ||||||
| 			return framework.GetPodLogs(f.Client, f.Namespace.Name, podName, containerName) | 			return framework.GetPodLogs(f.Client, f.Namespace.Name, podName, containerName) | ||||||
| @@ -103,9 +103,9 @@ var _ = framework.KubeDescribe("Downward API volume", func() { | |||||||
| 			f.Client.Pods(f.Namespace.Name).Delete(pod.Name, api.NewDeleteOptions(0)) | 			f.Client.Pods(f.Namespace.Name).Delete(pod.Name, api.NewDeleteOptions(0)) | ||||||
| 		}() | 		}() | ||||||
| 		By("Creating the pod") | 		By("Creating the pod") | ||||||
| 		pod, err := f.Client.Pods(f.Namespace.Name).Create(pod) | 		_, err := f.Client.Pods(f.Namespace.Name).Create(pod) | ||||||
| 		Expect(err).NotTo(HaveOccurred()) | 		Expect(err).NotTo(HaveOccurred()) | ||||||
| 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(f.Client, pod)) | 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(f.Client, pod.Name, f.Namespace.Name)) | ||||||
|  |  | ||||||
| 		pod, err = f.Client.Pods(f.Namespace.Name).Get(pod.Name) | 		pod, err = f.Client.Pods(f.Namespace.Name).Get(pod.Name) | ||||||
| 		Expect(err).NotTo(HaveOccurred()) | 		Expect(err).NotTo(HaveOccurred()) | ||||||
|   | |||||||
| @@ -152,8 +152,7 @@ var _ = framework.KubeDescribe("EmptyDir wrapper volumes", func() { | |||||||
| 			}, | 			}, | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		pod, err = f.Client.Pods(f.Namespace.Name).Create(pod) | 		if pod, err = f.Client.Pods(f.Namespace.Name).Create(pod); err != nil { | ||||||
| 		if err != nil { |  | ||||||
| 			framework.Failf("unable to create pod %v: %v", pod.Name, err) | 			framework.Failf("unable to create pod %v: %v", pod.Name, err) | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| @@ -176,6 +175,6 @@ var _ = framework.KubeDescribe("EmptyDir wrapper volumes", func() { | |||||||
| 			} | 			} | ||||||
| 		}() | 		}() | ||||||
|  |  | ||||||
| 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(f.Client, pod)) | 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(f.Client, pod.Name, f.Namespace.Name)) | ||||||
| 	}) | 	}) | ||||||
| }) | }) | ||||||
|   | |||||||
| @@ -99,7 +99,7 @@ func ClusterLevelLoggingWithElasticsearch(f *framework.Framework) { | |||||||
| 	pods, err := f.Client.Pods(api.NamespaceSystem).List(options) | 	pods, err := f.Client.Pods(api.NamespaceSystem).List(options) | ||||||
| 	Expect(err).NotTo(HaveOccurred()) | 	Expect(err).NotTo(HaveOccurred()) | ||||||
| 	for _, pod := range pods.Items { | 	for _, pod := range pods.Items { | ||||||
| 		err = framework.WaitForPodRunningInNamespace(f.Client, &pod) | 		err = framework.WaitForPodRunningInNamespace(f.Client, pod.Name, api.NamespaceSystem) | ||||||
| 		Expect(err).NotTo(HaveOccurred()) | 		Expect(err).NotTo(HaveOccurred()) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -227,7 +227,7 @@ func ClusterLevelLoggingWithElasticsearch(f *framework.Framework) { | |||||||
| 	Expect(err).NotTo(HaveOccurred()) | 	Expect(err).NotTo(HaveOccurred()) | ||||||
| 	for _, pod := range fluentdPods.Items { | 	for _, pod := range fluentdPods.Items { | ||||||
| 		if nodeInNodeList(pod.Spec.NodeName, nodes) { | 		if nodeInNodeList(pod.Spec.NodeName, nodes) { | ||||||
| 			err = framework.WaitForPodRunningInNamespace(f.Client, &pod) | 			err = framework.WaitForPodRunningInNamespace(f.Client, pod.Name, api.NamespaceSystem) | ||||||
| 			Expect(err).NotTo(HaveOccurred()) | 			Expect(err).NotTo(HaveOccurred()) | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|   | |||||||
| @@ -139,7 +139,7 @@ var _ = framework.KubeDescribe("ClusterDns [Feature:Example]", func() { | |||||||
| 		// wait until the pods have been scheduler, i.e. are not Pending anymore. Remember | 		// wait until the pods have been scheduler, i.e. are not Pending anymore. Remember | ||||||
| 		// that we cannot wait for the pods to be running because our pods terminate by themselves. | 		// that we cannot wait for the pods to be running because our pods terminate by themselves. | ||||||
| 		for _, ns := range namespaces { | 		for _, ns := range namespaces { | ||||||
| 			err := framework.WaitForPodNotPending(c, ns.Name, frontendPodName, "") | 			err := framework.WaitForPodNotPending(c, ns.Name, frontendPodName) | ||||||
| 			framework.ExpectNoError(err) | 			framework.ExpectNoError(err) | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -79,7 +79,7 @@ var _ = framework.KubeDescribe("[Feature:Example]", func() { | |||||||
|  |  | ||||||
| 			By("starting redis bootstrap") | 			By("starting redis bootstrap") | ||||||
| 			framework.RunKubectlOrDie("create", "-f", bootstrapYaml, nsFlag) | 			framework.RunKubectlOrDie("create", "-f", bootstrapYaml, nsFlag) | ||||||
| 			err := framework.WaitForPodNameRunningInNamespace(c, bootstrapPodName, ns) | 			err := framework.WaitForPodRunningInNamespace(c, bootstrapPodName, ns) | ||||||
| 			Expect(err).NotTo(HaveOccurred()) | 			Expect(err).NotTo(HaveOccurred()) | ||||||
|  |  | ||||||
| 			_, err = framework.LookForStringInLog(ns, bootstrapPodName, "master", expectedOnServer, serverStartTimeout) | 			_, err = framework.LookForStringInLog(ns, bootstrapPodName, "master", expectedOnServer, serverStartTimeout) | ||||||
| @@ -308,7 +308,7 @@ var _ = framework.KubeDescribe("[Feature:Example]", func() { | |||||||
| 			By("starting Zookeeper") | 			By("starting Zookeeper") | ||||||
| 			framework.RunKubectlOrDie("create", "-f", zookeeperPodJson, nsFlag) | 			framework.RunKubectlOrDie("create", "-f", zookeeperPodJson, nsFlag) | ||||||
| 			framework.RunKubectlOrDie("create", "-f", zookeeperServiceJson, nsFlag) | 			framework.RunKubectlOrDie("create", "-f", zookeeperServiceJson, nsFlag) | ||||||
| 			err := framework.WaitForPodNameRunningInNamespace(c, zookeeperPod, ns) | 			err := framework.WaitForPodRunningInNamespace(c, zookeeperPod, ns) | ||||||
| 			Expect(err).NotTo(HaveOccurred()) | 			Expect(err).NotTo(HaveOccurred()) | ||||||
|  |  | ||||||
| 			By("checking if zookeeper is up and running") | 			By("checking if zookeeper is up and running") | ||||||
| @@ -320,7 +320,7 @@ var _ = framework.KubeDescribe("[Feature:Example]", func() { | |||||||
| 			By("starting Nimbus") | 			By("starting Nimbus") | ||||||
| 			framework.RunKubectlOrDie("create", "-f", nimbusPodJson, nsFlag) | 			framework.RunKubectlOrDie("create", "-f", nimbusPodJson, nsFlag) | ||||||
| 			framework.RunKubectlOrDie("create", "-f", nimbusServiceJson, nsFlag) | 			framework.RunKubectlOrDie("create", "-f", nimbusServiceJson, nsFlag) | ||||||
| 			err = framework.WaitForPodNameRunningInNamespace(c, "nimbus", ns) | 			err = framework.WaitForPodRunningInNamespace(c, "nimbus", ns) | ||||||
| 			Expect(err).NotTo(HaveOccurred()) | 			Expect(err).NotTo(HaveOccurred()) | ||||||
|  |  | ||||||
| 			err = framework.WaitForEndpoint(c, ns, "nimbus") | 			err = framework.WaitForEndpoint(c, ns, "nimbus") | ||||||
| @@ -365,7 +365,7 @@ var _ = framework.KubeDescribe("[Feature:Example]", func() { | |||||||
| 			var wg sync.WaitGroup | 			var wg sync.WaitGroup | ||||||
| 			passed := true | 			passed := true | ||||||
| 			checkRestart := func(podName string, timeout time.Duration) { | 			checkRestart := func(podName string, timeout time.Duration) { | ||||||
| 				err := framework.WaitForPodNameRunningInNamespace(c, podName, ns) | 				err := framework.WaitForPodRunningInNamespace(c, podName, ns) | ||||||
| 				Expect(err).NotTo(HaveOccurred()) | 				Expect(err).NotTo(HaveOccurred()) | ||||||
| 				for t := time.Now(); time.Since(t) < timeout; time.Sleep(framework.Poll) { | 				for t := time.Now(); time.Since(t) < timeout; time.Sleep(framework.Poll) { | ||||||
| 					pod, err := c.Pods(ns).Get(podName) | 					pod, err := c.Pods(ns).Get(podName) | ||||||
| @@ -412,7 +412,7 @@ var _ = framework.KubeDescribe("[Feature:Example]", func() { | |||||||
| 			By("creating secret and pod") | 			By("creating secret and pod") | ||||||
| 			framework.RunKubectlOrDie("create", "-f", secretYaml, nsFlag) | 			framework.RunKubectlOrDie("create", "-f", secretYaml, nsFlag) | ||||||
| 			framework.RunKubectlOrDie("create", "-f", podYaml, nsFlag) | 			framework.RunKubectlOrDie("create", "-f", podYaml, nsFlag) | ||||||
| 			err := framework.WaitForPodNoLongerRunningInNamespace(c, podName, ns, "") | 			err := framework.WaitForPodNoLongerRunningInNamespace(c, podName, ns) | ||||||
| 			Expect(err).NotTo(HaveOccurred()) | 			Expect(err).NotTo(HaveOccurred()) | ||||||
|  |  | ||||||
| 			By("checking if secret was read correctly") | 			By("checking if secret was read correctly") | ||||||
| @@ -432,7 +432,7 @@ var _ = framework.KubeDescribe("[Feature:Example]", func() { | |||||||
|  |  | ||||||
| 			By("creating the pod") | 			By("creating the pod") | ||||||
| 			framework.RunKubectlOrDie("create", "-f", podYaml, nsFlag) | 			framework.RunKubectlOrDie("create", "-f", podYaml, nsFlag) | ||||||
| 			err := framework.WaitForPodNoLongerRunningInNamespace(c, podName, ns, "") | 			err := framework.WaitForPodNoLongerRunningInNamespace(c, podName, ns) | ||||||
| 			Expect(err).NotTo(HaveOccurred()) | 			Expect(err).NotTo(HaveOccurred()) | ||||||
|  |  | ||||||
| 			By("checking if name and namespace were passed correctly") | 			By("checking if name and namespace were passed correctly") | ||||||
| @@ -477,7 +477,7 @@ var _ = framework.KubeDescribe("[Feature:Example]", func() { | |||||||
| 			By("starting admin") | 			By("starting admin") | ||||||
| 			framework.RunKubectlOrDie("create", "-f", adminServiceYaml, nsFlag) | 			framework.RunKubectlOrDie("create", "-f", adminServiceYaml, nsFlag) | ||||||
| 			framework.RunKubectlOrDie("create", "-f", adminPodYaml, nsFlag) | 			framework.RunKubectlOrDie("create", "-f", adminPodYaml, nsFlag) | ||||||
| 			err = framework.WaitForPodNameRunningInNamespace(c, "rethinkdb-admin", ns) | 			err = framework.WaitForPodRunningInNamespace(c, "rethinkdb-admin", ns) | ||||||
| 			Expect(err).NotTo(HaveOccurred()) | 			Expect(err).NotTo(HaveOccurred()) | ||||||
| 			checkDbInstances() | 			checkDbInstances() | ||||||
| 			content, err := makeHttpRequestToService(c, ns, "rethinkdb-admin", "/", framework.EndpointRegisterTimeout) | 			content, err := makeHttpRequestToService(c, ns, "rethinkdb-admin", "/", framework.EndpointRegisterTimeout) | ||||||
|   | |||||||
| @@ -365,24 +365,24 @@ func (f *Framework) WaitForPodTerminated(podName, reason string) error { | |||||||
|  |  | ||||||
| // WaitForPodRunning waits for the pod to run in the namespace. | // WaitForPodRunning waits for the pod to run in the namespace. | ||||||
| func (f *Framework) WaitForPodRunning(podName string) error { | func (f *Framework) WaitForPodRunning(podName string) error { | ||||||
| 	return WaitForPodNameRunningInNamespace(f.Client, podName, f.Namespace.Name) | 	return WaitForPodRunningInNamespace(f.Client, podName, f.Namespace.Name) | ||||||
| } | } | ||||||
|  |  | ||||||
| // WaitForPodReady waits for the pod to flip to ready in the namespace. | // WaitForPodReady waits for the pod to flip to ready in the namespace. | ||||||
| func (f *Framework) WaitForPodReady(podName string) error { | func (f *Framework) WaitForPodReady(podName string) error { | ||||||
| 	return waitTimeoutForPodReadyInNamespace(f.Client, podName, f.Namespace.Name, "", PodStartTimeout) | 	return waitTimeoutForPodReadyInNamespace(f.Client, podName, f.Namespace.Name, PodStartTimeout) | ||||||
| } | } | ||||||
|  |  | ||||||
| // WaitForPodRunningSlow waits for the pod to run in the namespace. | // WaitForPodRunningSlow waits for the pod to run in the namespace. | ||||||
| // It has a longer timeout then WaitForPodRunning (util.slowPodStartTimeout). | // It has a longer timeout then WaitForPodRunning (util.slowPodStartTimeout). | ||||||
| func (f *Framework) WaitForPodRunningSlow(podName string) error { | func (f *Framework) WaitForPodRunningSlow(podName string) error { | ||||||
| 	return waitForPodRunningInNamespaceSlow(f.Client, podName, f.Namespace.Name, "") | 	return waitForPodRunningInNamespaceSlow(f.Client, podName, f.Namespace.Name) | ||||||
| } | } | ||||||
|  |  | ||||||
| // WaitForPodNoLongerRunning waits for the pod to no longer be running in the namespace, for either | // WaitForPodNoLongerRunning waits for the pod to no longer be running in the namespace, for either | ||||||
| // success or failure. | // success or failure. | ||||||
| func (f *Framework) WaitForPodNoLongerRunning(podName string) error { | func (f *Framework) WaitForPodNoLongerRunning(podName string) error { | ||||||
| 	return WaitForPodNoLongerRunningInNamespace(f.Client, podName, f.Namespace.Name, "") | 	return WaitForPodNoLongerRunningInNamespace(f.Client, podName, f.Namespace.Name) | ||||||
| } | } | ||||||
|  |  | ||||||
| // Runs the given pod and verifies that the output of exact container matches the desired output. | // Runs the given pod and verifies that the output of exact container matches the desired output. | ||||||
|   | |||||||
| @@ -86,7 +86,8 @@ const ( | |||||||
| 	// How long to wait for the pod to be listable | 	// How long to wait for the pod to be listable | ||||||
| 	PodListTimeout = time.Minute | 	PodListTimeout = time.Minute | ||||||
| 	// Initial pod start can be delayed O(minutes) by slow docker pulls | 	// Initial pod start can be delayed O(minutes) by slow docker pulls | ||||||
| 	PodStartTimeout = 30 * time.Second | 	// TODO: Make this 30 seconds once #4566 is resolved. | ||||||
|  | 	PodStartTimeout = 5 * time.Minute | ||||||
|  |  | ||||||
| 	// How long to wait for the pod to no longer be running | 	// How long to wait for the pod to no longer be running | ||||||
| 	podNoLongerRunningTimeout = 30 * time.Second | 	podNoLongerRunningTimeout = 30 * time.Second | ||||||
| @@ -1177,31 +1178,18 @@ func CheckInvariants(events []watch.Event, fns ...InvariantFunc) error { | |||||||
|  |  | ||||||
| // Waits default amount of time (PodStartTimeout) for the specified pod to become running. | // Waits default amount of time (PodStartTimeout) for the specified pod to become running. | ||||||
| // Returns an error if timeout occurs first, or pod goes in to failed state. | // Returns an error if timeout occurs first, or pod goes in to failed state. | ||||||
| func WaitForPodRunningInNamespace(c *client.Client, pod *api.Pod) error { | func WaitForPodRunningInNamespace(c *client.Client, podName string, namespace string) error { | ||||||
| 	// this short-cicuit is needed for cases when we pass a list of pods instead | 	return waitTimeoutForPodRunningInNamespace(c, podName, namespace, PodStartTimeout) | ||||||
| 	// of newly created pod (eg. VerifyPods) which means we are getting already |  | ||||||
| 	// running pod for which waiting does not make sense and will always fail |  | ||||||
| 	if pod.Status.Phase == api.PodRunning { |  | ||||||
| 		return nil |  | ||||||
| 	} |  | ||||||
| 	return waitTimeoutForPodRunningInNamespace(c, pod.Name, pod.Namespace, pod.ResourceVersion, PodStartTimeout) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // Waits default amount of time (PodStartTimeout) for the specified pod to become running. |  | ||||||
| // Returns an error if timeout occurs first, or pod goes in to failed state. |  | ||||||
| func WaitForPodNameRunningInNamespace(c *client.Client, podName, namespace string) error { |  | ||||||
| 	return waitTimeoutForPodRunningInNamespace(c, podName, namespace, "", PodStartTimeout) |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // Waits an extended amount of time (slowPodStartTimeout) for the specified pod to become running. | // Waits an extended amount of time (slowPodStartTimeout) for the specified pod to become running. | ||||||
| // The resourceVersion is used when Watching object changes, it tells since when we care | // Returns an error if timeout occurs first, or pod goes in to failed state. | ||||||
| // about changes to the pod. Returns an error if timeout occurs first, or pod goes in to failed state. | func waitForPodRunningInNamespaceSlow(c *client.Client, podName string, namespace string) error { | ||||||
| func waitForPodRunningInNamespaceSlow(c *client.Client, podName, namespace, resourceVersion string) error { | 	return waitTimeoutForPodRunningInNamespace(c, podName, namespace, slowPodStartTimeout) | ||||||
| 	return waitTimeoutForPodRunningInNamespace(c, podName, namespace, resourceVersion, slowPodStartTimeout) |  | ||||||
| } | } | ||||||
|  |  | ||||||
| func waitTimeoutForPodRunningInNamespace(c *client.Client, podName, namespace, resourceVersion string, timeout time.Duration) error { | func waitTimeoutForPodRunningInNamespace(c *client.Client, podName string, namespace string, timeout time.Duration) error { | ||||||
| 	w, err := c.Pods(namespace).Watch(api.SingleObject(api.ObjectMeta{Name: podName, ResourceVersion: resourceVersion})) | 	w, err := c.Pods(namespace).Watch(api.SingleObject(api.ObjectMeta{Name: podName})) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| @@ -1211,12 +1199,12 @@ func waitTimeoutForPodRunningInNamespace(c *client.Client, podName, namespace, r | |||||||
|  |  | ||||||
| // Waits default amount of time (podNoLongerRunningTimeout) for the specified pod to stop running. | // Waits default amount of time (podNoLongerRunningTimeout) for the specified pod to stop running. | ||||||
| // Returns an error if timeout occurs first. | // Returns an error if timeout occurs first. | ||||||
| func WaitForPodNoLongerRunningInNamespace(c *client.Client, podName, namespace, resourceVersion string) error { | func WaitForPodNoLongerRunningInNamespace(c *client.Client, podName string, namespace string) error { | ||||||
| 	return waitTimeoutForPodNoLongerRunningInNamespace(c, podName, namespace, resourceVersion, podNoLongerRunningTimeout) | 	return waitTimeoutForPodNoLongerRunningInNamespace(c, podName, namespace, podNoLongerRunningTimeout) | ||||||
| } | } | ||||||
|  |  | ||||||
| func waitTimeoutForPodNoLongerRunningInNamespace(c *client.Client, podName, namespace, resourceVersion string, timeout time.Duration) error { | func waitTimeoutForPodNoLongerRunningInNamespace(c *client.Client, podName string, namespace string, timeout time.Duration) error { | ||||||
| 	w, err := c.Pods(namespace).Watch(api.SingleObject(api.ObjectMeta{Name: podName, ResourceVersion: resourceVersion})) | 	w, err := c.Pods(namespace).Watch(api.SingleObject(api.ObjectMeta{Name: podName})) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| @@ -1224,8 +1212,8 @@ func waitTimeoutForPodNoLongerRunningInNamespace(c *client.Client, podName, name | |||||||
| 	return err | 	return err | ||||||
| } | } | ||||||
|  |  | ||||||
| func waitTimeoutForPodReadyInNamespace(c *client.Client, podName, namespace, resourceVersion string, timeout time.Duration) error { | func waitTimeoutForPodReadyInNamespace(c *client.Client, podName string, namespace string, timeout time.Duration) error { | ||||||
| 	w, err := c.Pods(namespace).Watch(api.SingleObject(api.ObjectMeta{Name: podName, ResourceVersion: resourceVersion})) | 	w, err := c.Pods(namespace).Watch(api.SingleObject(api.ObjectMeta{Name: podName})) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| @@ -1234,10 +1222,8 @@ func waitTimeoutForPodReadyInNamespace(c *client.Client, podName, namespace, res | |||||||
| } | } | ||||||
|  |  | ||||||
| // WaitForPodNotPending returns an error if it took too long for the pod to go out of pending state. | // WaitForPodNotPending returns an error if it took too long for the pod to go out of pending state. | ||||||
| // The resourceVersion is used when Watching object changes, it tells since when we care | func WaitForPodNotPending(c *client.Client, ns, podName string) error { | ||||||
| // about changes to the pod. | 	w, err := c.Pods(ns).Watch(api.SingleObject(api.ObjectMeta{Name: podName})) | ||||||
| func WaitForPodNotPending(c *client.Client, ns, podName, resourceVersion string) error { |  | ||||||
| 	w, err := c.Pods(ns).Watch(api.SingleObject(api.ObjectMeta{Name: podName, ResourceVersion: resourceVersion})) |  | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| @@ -1632,7 +1618,7 @@ func podsRunning(c *client.Client, pods *api.PodList) []error { | |||||||
|  |  | ||||||
| 	for _, pod := range pods.Items { | 	for _, pod := range pods.Items { | ||||||
| 		go func(p api.Pod) { | 		go func(p api.Pod) { | ||||||
| 			error_chan <- WaitForPodRunningInNamespace(c, &p) | 			error_chan <- WaitForPodRunningInNamespace(c, p.Name, p.Namespace) | ||||||
| 		}(pod) | 		}(pod) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -3521,7 +3507,7 @@ func LaunchHostExecPod(client *client.Client, ns, name string) *api.Pod { | |||||||
| 	hostExecPod := NewHostExecPodSpec(ns, name) | 	hostExecPod := NewHostExecPodSpec(ns, name) | ||||||
| 	pod, err := client.Pods(ns).Create(hostExecPod) | 	pod, err := client.Pods(ns).Create(hostExecPod) | ||||||
| 	ExpectNoError(err) | 	ExpectNoError(err) | ||||||
| 	err = WaitForPodRunningInNamespace(client, pod) | 	err = WaitForPodRunningInNamespace(client, pod.Name, pod.Namespace) | ||||||
| 	ExpectNoError(err) | 	ExpectNoError(err) | ||||||
| 	return pod | 	return pod | ||||||
| } | } | ||||||
|   | |||||||
| @@ -67,6 +67,6 @@ func runPod(f *framework.Framework, name, image string) *api.Pod { | |||||||
| 	} | 	} | ||||||
| 	createdPod, err := f.Client.Pods(f.Namespace.Name).Create(pod) | 	createdPod, err := f.Client.Pods(f.Namespace.Name).Create(pod) | ||||||
| 	framework.ExpectNoError(err) | 	framework.ExpectNoError(err) | ||||||
| 	framework.ExpectNoError(framework.WaitForPodRunningInNamespace(f.Client, createdPod)) | 	framework.ExpectNoError(framework.WaitForPodRunningInNamespace(f.Client, name, f.Namespace.Name)) | ||||||
| 	return createdPod | 	return createdPod | ||||||
| } | } | ||||||
|   | |||||||
| @@ -73,7 +73,7 @@ func ClusterLevelLoggingWithKibana(f *framework.Framework) { | |||||||
| 	pods, err := f.Client.Pods(api.NamespaceSystem).List(options) | 	pods, err := f.Client.Pods(api.NamespaceSystem).List(options) | ||||||
| 	Expect(err).NotTo(HaveOccurred()) | 	Expect(err).NotTo(HaveOccurred()) | ||||||
| 	for _, pod := range pods.Items { | 	for _, pod := range pods.Items { | ||||||
| 		err = framework.WaitForPodRunningInNamespace(f.Client, &pod) | 		err = framework.WaitForPodRunningInNamespace(f.Client, pod.Name, api.NamespaceSystem) | ||||||
| 		Expect(err).NotTo(HaveOccurred()) | 		Expect(err).NotTo(HaveOccurred()) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -101,7 +101,7 @@ var _ = framework.KubeDescribe("Mesos", func() { | |||||||
| 		}) | 		}) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
|  |  | ||||||
| 		framework.ExpectNoError(framework.WaitForPodNameRunningInNamespace(c, podName, ns)) | 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, podName, ns)) | ||||||
| 		pod, err := c.Pods(ns).Get(podName) | 		pod, err := c.Pods(ns).Get(podName) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -106,7 +106,7 @@ func ensurePodsAreRemovedWhenNamespaceIsDeleted(f *framework.Framework) { | |||||||
| 	Expect(err).NotTo(HaveOccurred()) | 	Expect(err).NotTo(HaveOccurred()) | ||||||
|  |  | ||||||
| 	By("Waiting for the pod to have running status") | 	By("Waiting for the pod to have running status") | ||||||
| 	framework.ExpectNoError(framework.WaitForPodRunningInNamespace(f.Client, pod)) | 	framework.ExpectNoError(framework.WaitForPodRunningInNamespace(f.Client, pod.Name, pod.Namespace)) | ||||||
|  |  | ||||||
| 	By("Deleting the namespace") | 	By("Deleting the namespace") | ||||||
| 	err = f.Client.Namespaces().Delete(namespace.Name) | 	err = f.Client.Namespaces().Delete(namespace.Name) | ||||||
|   | |||||||
| @@ -53,7 +53,7 @@ var ( | |||||||
|  |  | ||||||
| func runLivenessTest(c *client.Client, ns string, podDescr *api.Pod, expectNumRestarts int, timeout time.Duration) { | func runLivenessTest(c *client.Client, ns string, podDescr *api.Pod, expectNumRestarts int, timeout time.Duration) { | ||||||
| 	By(fmt.Sprintf("Creating pod %s in namespace %s", podDescr.Name, ns)) | 	By(fmt.Sprintf("Creating pod %s in namespace %s", podDescr.Name, ns)) | ||||||
| 	podDescr, err := c.Pods(ns).Create(podDescr) | 	_, err := c.Pods(ns).Create(podDescr) | ||||||
| 	framework.ExpectNoError(err, fmt.Sprintf("creating pod %s", podDescr.Name)) | 	framework.ExpectNoError(err, fmt.Sprintf("creating pod %s", podDescr.Name)) | ||||||
|  |  | ||||||
| 	// At the end of the test, clean up by removing the pod. | 	// At the end of the test, clean up by removing the pod. | ||||||
| @@ -65,7 +65,7 @@ func runLivenessTest(c *client.Client, ns string, podDescr *api.Pod, expectNumRe | |||||||
| 	// Wait until the pod is not pending. (Here we need to check for something other than | 	// Wait until the pod is not pending. (Here we need to check for something other than | ||||||
| 	// 'Pending' other than checking for 'Running', since when failures occur, we go to | 	// 'Pending' other than checking for 'Running', since when failures occur, we go to | ||||||
| 	// 'Terminated' which can cause indefinite blocking.) | 	// 'Terminated' which can cause indefinite blocking.) | ||||||
| 	framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, podDescr.Name, podDescr.ResourceVersion), | 	framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, podDescr.Name), | ||||||
| 		fmt.Sprintf("starting pod %s in namespace %s", podDescr.Name, ns)) | 		fmt.Sprintf("starting pod %s in namespace %s", podDescr.Name, ns)) | ||||||
| 	framework.Logf("Started pod %s in namespace %s", podDescr.Name, ns) | 	framework.Logf("Started pod %s in namespace %s", podDescr.Name, ns) | ||||||
|  |  | ||||||
| @@ -114,14 +114,13 @@ func testHostIP(c *client.Client, ns string, pod *api.Pod) { | |||||||
| 	podClient := c.Pods(ns) | 	podClient := c.Pods(ns) | ||||||
| 	By("creating pod") | 	By("creating pod") | ||||||
| 	defer podClient.Delete(pod.Name, api.NewDeleteOptions(0)) | 	defer podClient.Delete(pod.Name, api.NewDeleteOptions(0)) | ||||||
| 	pod, err := podClient.Create(pod) | 	if _, err := podClient.Create(pod); err != nil { | ||||||
| 	if err != nil { |  | ||||||
| 		framework.Failf("Failed to create pod: %v", err) | 		framework.Failf("Failed to create pod: %v", err) | ||||||
| 	} | 	} | ||||||
| 	By("ensuring that pod is running and has a hostIP") | 	By("ensuring that pod is running and has a hostIP") | ||||||
| 	// Wait for the pods to enter the running state. Waiting loops until the pods | 	// Wait for the pods to enter the running state. Waiting loops until the pods | ||||||
| 	// are running so non-running pods cause a timeout for this test. | 	// are running so non-running pods cause a timeout for this test. | ||||||
| 	err = framework.WaitForPodRunningInNamespace(c, pod) | 	err := framework.WaitForPodRunningInNamespace(c, pod.Name, ns) | ||||||
| 	Expect(err).NotTo(HaveOccurred()) | 	Expect(err).NotTo(HaveOccurred()) | ||||||
| 	// Try to make sure we get a hostIP for each pod. | 	// Try to make sure we get a hostIP for each pod. | ||||||
| 	hostIPTimeout := 2 * time.Minute | 	hostIPTimeout := 2 * time.Minute | ||||||
| @@ -816,7 +815,7 @@ var _ = framework.KubeDescribe("Pods", func() { | |||||||
|  |  | ||||||
| 		wr := watch.NewRecorder(w) | 		wr := watch.NewRecorder(w) | ||||||
| 		event, err := watch.Until( | 		event, err := watch.Until( | ||||||
| 			framework.PodReadyBeforeTimeout, wr, | 			framework.PodStartTimeout, wr, | ||||||
| 			// check for the first container to fail at least once | 			// check for the first container to fail at least once | ||||||
| 			func(evt watch.Event) (bool, error) { | 			func(evt watch.Event) (bool, error) { | ||||||
| 				switch t := evt.Object.(type) { | 				switch t := evt.Object.(type) { | ||||||
|   | |||||||
| @@ -51,7 +51,7 @@ func testPreStop(c *client.Client, ns string) { | |||||||
| 		}, | 		}, | ||||||
| 	} | 	} | ||||||
| 	By(fmt.Sprintf("Creating server pod %s in namespace %s", podDescr.Name, ns)) | 	By(fmt.Sprintf("Creating server pod %s in namespace %s", podDescr.Name, ns)) | ||||||
| 	podDescr, err := c.Pods(ns).Create(podDescr) | 	_, err := c.Pods(ns).Create(podDescr) | ||||||
| 	framework.ExpectNoError(err, fmt.Sprintf("creating pod %s", podDescr.Name)) | 	framework.ExpectNoError(err, fmt.Sprintf("creating pod %s", podDescr.Name)) | ||||||
|  |  | ||||||
| 	// At the end of the test, clean up by removing the pod. | 	// At the end of the test, clean up by removing the pod. | ||||||
| @@ -61,7 +61,7 @@ func testPreStop(c *client.Client, ns string) { | |||||||
| 	}() | 	}() | ||||||
|  |  | ||||||
| 	By("Waiting for pods to come up.") | 	By("Waiting for pods to come up.") | ||||||
| 	err = framework.WaitForPodRunningInNamespace(c, podDescr) | 	err = framework.WaitForPodRunningInNamespace(c, podDescr.Name, ns) | ||||||
| 	framework.ExpectNoError(err, "waiting for server pod to start") | 	framework.ExpectNoError(err, "waiting for server pod to start") | ||||||
|  |  | ||||||
| 	val := "{\"Source\": \"prestop\"}" | 	val := "{\"Source\": \"prestop\"}" | ||||||
| @@ -94,7 +94,7 @@ func testPreStop(c *client.Client, ns string) { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	By(fmt.Sprintf("Creating tester pod %s in namespace %s", preStopDescr.Name, ns)) | 	By(fmt.Sprintf("Creating tester pod %s in namespace %s", preStopDescr.Name, ns)) | ||||||
| 	preStopDescr, err = c.Pods(ns).Create(preStopDescr) | 	_, err = c.Pods(ns).Create(preStopDescr) | ||||||
| 	framework.ExpectNoError(err, fmt.Sprintf("creating pod %s", preStopDescr.Name)) | 	framework.ExpectNoError(err, fmt.Sprintf("creating pod %s", preStopDescr.Name)) | ||||||
| 	deletePreStop := true | 	deletePreStop := true | ||||||
|  |  | ||||||
| @@ -106,7 +106,7 @@ func testPreStop(c *client.Client, ns string) { | |||||||
| 		} | 		} | ||||||
| 	}() | 	}() | ||||||
|  |  | ||||||
| 	err = framework.WaitForPodRunningInNamespace(c, preStopDescr) | 	err = framework.WaitForPodRunningInNamespace(c, preStopDescr.Name, ns) | ||||||
| 	framework.ExpectNoError(err, "waiting for tester pod to start") | 	framework.ExpectNoError(err, "waiting for tester pod to start") | ||||||
|  |  | ||||||
| 	// Delete the pod with the preStop handler. | 	// Delete the pod with the preStop handler. | ||||||
|   | |||||||
| @@ -460,7 +460,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 		// scheduled onto it. | 		// scheduled onto it. | ||||||
| 		By("Trying to launch a pod without a label to get a node which can launch it.") | 		By("Trying to launch a pod without a label to get a node which can launch it.") | ||||||
| 		podName := "without-label" | 		podName := "without-label" | ||||||
| 		pod, err := c.Pods(ns).Create(&api.Pod{ | 		_, err := c.Pods(ns).Create(&api.Pod{ | ||||||
| 			TypeMeta: unversioned.TypeMeta{ | 			TypeMeta: unversioned.TypeMeta{ | ||||||
| 				Kind: "Pod", | 				Kind: "Pod", | ||||||
| 			}, | 			}, | ||||||
| @@ -477,8 +477,8 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 			}, | 			}, | ||||||
| 		}) | 		}) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
| 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, pod)) | 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, podName, ns)) | ||||||
| 		pod, err = c.Pods(ns).Get(podName) | 		pod, err := c.Pods(ns).Get(podName) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
|  |  | ||||||
| 		nodeName := pod.Spec.NodeName | 		nodeName := pod.Spec.NodeName | ||||||
| @@ -499,7 +499,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
|  |  | ||||||
| 		By("Trying to relaunch the pod, now with labels.") | 		By("Trying to relaunch the pod, now with labels.") | ||||||
| 		labelPodName := "with-labels" | 		labelPodName := "with-labels" | ||||||
| 		pod, err = c.Pods(ns).Create(&api.Pod{ | 		_, err = c.Pods(ns).Create(&api.Pod{ | ||||||
| 			TypeMeta: unversioned.TypeMeta{ | 			TypeMeta: unversioned.TypeMeta{ | ||||||
| 				Kind: "Pod", | 				Kind: "Pod", | ||||||
| 			}, | 			}, | ||||||
| @@ -527,7 +527,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 		// kubelet and the scheduler: the scheduler might have scheduled a pod | 		// kubelet and the scheduler: the scheduler might have scheduled a pod | ||||||
| 		// already when the kubelet does not know about its new label yet. The | 		// already when the kubelet does not know about its new label yet. The | ||||||
| 		// kubelet will then refuse to launch the pod. | 		// kubelet will then refuse to launch the pod. | ||||||
| 		framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, labelPodName, pod.ResourceVersion)) | 		framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, labelPodName)) | ||||||
| 		labelPod, err := c.Pods(ns).Get(labelPodName) | 		labelPod, err := c.Pods(ns).Get(labelPodName) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
| 		Expect(labelPod.Spec.NodeName).To(Equal(nodeName)) | 		Expect(labelPod.Spec.NodeName).To(Equal(nodeName)) | ||||||
| @@ -598,7 +598,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 		// scheduled onto it. | 		// scheduled onto it. | ||||||
| 		By("Trying to launch a pod without a label to get a node which can launch it.") | 		By("Trying to launch a pod without a label to get a node which can launch it.") | ||||||
| 		podName := "without-label" | 		podName := "without-label" | ||||||
| 		pod, err := c.Pods(ns).Create(&api.Pod{ | 		_, err := c.Pods(ns).Create(&api.Pod{ | ||||||
| 			TypeMeta: unversioned.TypeMeta{ | 			TypeMeta: unversioned.TypeMeta{ | ||||||
| 				Kind: "Pod", | 				Kind: "Pod", | ||||||
| 			}, | 			}, | ||||||
| @@ -615,8 +615,8 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 			}, | 			}, | ||||||
| 		}) | 		}) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
| 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, pod)) | 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, podName, ns)) | ||||||
| 		pod, err = c.Pods(ns).Get(podName) | 		pod, err := c.Pods(ns).Get(podName) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
|  |  | ||||||
| 		nodeName := pod.Spec.NodeName | 		nodeName := pod.Spec.NodeName | ||||||
| @@ -637,7 +637,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
|  |  | ||||||
| 		By("Trying to relaunch the pod, now with labels.") | 		By("Trying to relaunch the pod, now with labels.") | ||||||
| 		labelPodName := "with-labels" | 		labelPodName := "with-labels" | ||||||
| 		pod, err = c.Pods(ns).Create(&api.Pod{ | 		_, err = c.Pods(ns).Create(&api.Pod{ | ||||||
| 			TypeMeta: unversioned.TypeMeta{ | 			TypeMeta: unversioned.TypeMeta{ | ||||||
| 				Kind: "Pod", | 				Kind: "Pod", | ||||||
| 			}, | 			}, | ||||||
| @@ -679,7 +679,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 		// kubelet and the scheduler: the scheduler might have scheduled a pod | 		// kubelet and the scheduler: the scheduler might have scheduled a pod | ||||||
| 		// already when the kubelet does not know about its new label yet. The | 		// already when the kubelet does not know about its new label yet. The | ||||||
| 		// kubelet will then refuse to launch the pod. | 		// kubelet will then refuse to launch the pod. | ||||||
| 		framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, labelPodName, pod.ResourceVersion)) | 		framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, labelPodName)) | ||||||
| 		labelPod, err := c.Pods(ns).Get(labelPodName) | 		labelPod, err := c.Pods(ns).Get(labelPodName) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
| 		Expect(labelPod.Spec.NodeName).To(Equal(nodeName)) | 		Expect(labelPod.Spec.NodeName).To(Equal(nodeName)) | ||||||
| @@ -694,7 +694,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 		// scheduled onto it. | 		// scheduled onto it. | ||||||
| 		By("Trying to launch a pod without a label to get a node which can launch it.") | 		By("Trying to launch a pod without a label to get a node which can launch it.") | ||||||
| 		podName := "without-label" | 		podName := "without-label" | ||||||
| 		pod, err := c.Pods(ns).Create(&api.Pod{ | 		_, err := c.Pods(ns).Create(&api.Pod{ | ||||||
| 			TypeMeta: unversioned.TypeMeta{ | 			TypeMeta: unversioned.TypeMeta{ | ||||||
| 				Kind: "Pod", | 				Kind: "Pod", | ||||||
| 			}, | 			}, | ||||||
| @@ -711,8 +711,8 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 			}, | 			}, | ||||||
| 		}) | 		}) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
| 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, pod)) | 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, podName, ns)) | ||||||
| 		pod, err = c.Pods(ns).Get(podName) | 		pod, err := c.Pods(ns).Get(podName) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
|  |  | ||||||
| 		nodeName := pod.Spec.NodeName | 		nodeName := pod.Spec.NodeName | ||||||
| @@ -743,7 +743,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 		// kubelet and the scheduler: the scheduler might have scheduled a pod | 		// kubelet and the scheduler: the scheduler might have scheduled a pod | ||||||
| 		// already when the kubelet does not know about its new label yet. The | 		// already when the kubelet does not know about its new label yet. The | ||||||
| 		// kubelet will then refuse to launch the pod. | 		// kubelet will then refuse to launch the pod. | ||||||
| 		framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, labelPodName, "")) | 		framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, labelPodName)) | ||||||
| 		labelPod, err := c.Pods(ns).Get(labelPodName) | 		labelPod, err := c.Pods(ns).Get(labelPodName) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
| 		Expect(labelPod.Spec.NodeName).To(Equal(nodeName)) | 		Expect(labelPod.Spec.NodeName).To(Equal(nodeName)) | ||||||
| @@ -859,7 +859,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 		// scheduled onto it. | 		// scheduled onto it. | ||||||
| 		By("Trying to launch a pod with a label to get a node which can launch it.") | 		By("Trying to launch a pod with a label to get a node which can launch it.") | ||||||
| 		podName := "with-label-" + string(util.NewUUID()) | 		podName := "with-label-" + string(util.NewUUID()) | ||||||
| 		pod, err := c.Pods(ns).Create(&api.Pod{ | 		_, err := c.Pods(ns).Create(&api.Pod{ | ||||||
| 			TypeMeta: unversioned.TypeMeta{ | 			TypeMeta: unversioned.TypeMeta{ | ||||||
| 				Kind: "Pod", | 				Kind: "Pod", | ||||||
| 			}, | 			}, | ||||||
| @@ -877,8 +877,8 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 			}, | 			}, | ||||||
| 		}) | 		}) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
| 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, pod)) | 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, podName, ns)) | ||||||
| 		pod, err = c.Pods(ns).Get(podName) | 		pod, err := c.Pods(ns).Get(podName) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
|  |  | ||||||
| 		nodeName := pod.Spec.NodeName | 		nodeName := pod.Spec.NodeName | ||||||
| @@ -898,7 +898,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
|  |  | ||||||
| 		By("Trying to launch the pod, now with podAffinity.") | 		By("Trying to launch the pod, now with podAffinity.") | ||||||
| 		labelPodName := "with-podaffinity-" + string(util.NewUUID()) | 		labelPodName := "with-podaffinity-" + string(util.NewUUID()) | ||||||
| 		pod, err = c.Pods(ns).Create(&api.Pod{ | 		_, err = c.Pods(ns).Create(&api.Pod{ | ||||||
| 			TypeMeta: unversioned.TypeMeta{ | 			TypeMeta: unversioned.TypeMeta{ | ||||||
| 				Kind: "Pod", | 				Kind: "Pod", | ||||||
| 			}, | 			}, | ||||||
| @@ -938,7 +938,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 		// kubelet and the scheduler: the scheduler might have scheduled a pod | 		// kubelet and the scheduler: the scheduler might have scheduled a pod | ||||||
| 		// already when the kubelet does not know about its new label yet. The | 		// already when the kubelet does not know about its new label yet. The | ||||||
| 		// kubelet will then refuse to launch the pod. | 		// kubelet will then refuse to launch the pod. | ||||||
| 		framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, labelPodName, pod.ResourceVersion)) | 		framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, labelPodName)) | ||||||
| 		labelPod, err := c.Pods(ns).Get(labelPodName) | 		labelPod, err := c.Pods(ns).Get(labelPodName) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
| 		Expect(labelPod.Spec.NodeName).To(Equal(nodeName)) | 		Expect(labelPod.Spec.NodeName).To(Equal(nodeName)) | ||||||
| @@ -952,7 +952,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 		// scheduled onto it. | 		// scheduled onto it. | ||||||
| 		By("Trying to launch a pod with a label to get a node which can launch it.") | 		By("Trying to launch a pod with a label to get a node which can launch it.") | ||||||
| 		podName := "with-label-" + string(util.NewUUID()) | 		podName := "with-label-" + string(util.NewUUID()) | ||||||
| 		pod, err := c.Pods(ns).Create(&api.Pod{ | 		_, err := c.Pods(ns).Create(&api.Pod{ | ||||||
| 			TypeMeta: unversioned.TypeMeta{ | 			TypeMeta: unversioned.TypeMeta{ | ||||||
| 				Kind: "Pod", | 				Kind: "Pod", | ||||||
| 			}, | 			}, | ||||||
| @@ -970,8 +970,8 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 			}, | 			}, | ||||||
| 		}) | 		}) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
| 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, pod)) | 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, podName, ns)) | ||||||
| 		pod, err = c.Pods(ns).Get(podName) | 		pod, err := c.Pods(ns).Get(podName) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
|  |  | ||||||
| 		nodeName := pod.Spec.NodeName | 		nodeName := pod.Spec.NodeName | ||||||
| @@ -1041,7 +1041,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 		// scheduled onto it. | 		// scheduled onto it. | ||||||
| 		By("Trying to launch a pod with a label to get a node which can launch it.") | 		By("Trying to launch a pod with a label to get a node which can launch it.") | ||||||
| 		podName := "with-label-" + string(util.NewUUID()) | 		podName := "with-label-" + string(util.NewUUID()) | ||||||
| 		pod, err := c.Pods(ns).Create(&api.Pod{ | 		_, err := c.Pods(ns).Create(&api.Pod{ | ||||||
| 			TypeMeta: unversioned.TypeMeta{ | 			TypeMeta: unversioned.TypeMeta{ | ||||||
| 				Kind: "Pod", | 				Kind: "Pod", | ||||||
| 			}, | 			}, | ||||||
| @@ -1059,8 +1059,8 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 			}, | 			}, | ||||||
| 		}) | 		}) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
| 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, pod)) | 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, podName, ns)) | ||||||
| 		pod, err = c.Pods(ns).Get(podName) | 		pod, err := c.Pods(ns).Get(podName) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
|  |  | ||||||
| 		nodeName := pod.Spec.NodeName | 		nodeName := pod.Spec.NodeName | ||||||
| @@ -1080,7 +1080,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
|  |  | ||||||
| 		By("Trying to launch the pod, now with multiple pod affinities with diff LabelOperators.") | 		By("Trying to launch the pod, now with multiple pod affinities with diff LabelOperators.") | ||||||
| 		labelPodName := "with-podaffinity-" + string(util.NewUUID()) | 		labelPodName := "with-podaffinity-" + string(util.NewUUID()) | ||||||
| 		pod, err = c.Pods(ns).Create(&api.Pod{ | 		_, err = c.Pods(ns).Create(&api.Pod{ | ||||||
| 			TypeMeta: unversioned.TypeMeta{ | 			TypeMeta: unversioned.TypeMeta{ | ||||||
| 				Kind: "Pod", | 				Kind: "Pod", | ||||||
| 			}, | 			}, | ||||||
| @@ -1128,7 +1128,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 		// kubelet and the scheduler: the scheduler might have scheduled a pod | 		// kubelet and the scheduler: the scheduler might have scheduled a pod | ||||||
| 		// already when the kubelet does not know about its new label yet. The | 		// already when the kubelet does not know about its new label yet. The | ||||||
| 		// kubelet will then refuse to launch the pod. | 		// kubelet will then refuse to launch the pod. | ||||||
| 		framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, labelPodName, pod.ResourceVersion)) | 		framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, labelPodName)) | ||||||
| 		labelPod, err := c.Pods(ns).Get(labelPodName) | 		labelPod, err := c.Pods(ns).Get(labelPodName) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
| 		Expect(labelPod.Spec.NodeName).To(Equal(nodeName)) | 		Expect(labelPod.Spec.NodeName).To(Equal(nodeName)) | ||||||
| @@ -1142,7 +1142,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 		// scheduled onto it. | 		// scheduled onto it. | ||||||
| 		By("Trying to launch a pod with a label to get a node which can launch it.") | 		By("Trying to launch a pod with a label to get a node which can launch it.") | ||||||
| 		podName := "with-label-" + string(util.NewUUID()) | 		podName := "with-label-" + string(util.NewUUID()) | ||||||
| 		pod, err := c.Pods(ns).Create(&api.Pod{ | 		_, err := c.Pods(ns).Create(&api.Pod{ | ||||||
| 			TypeMeta: unversioned.TypeMeta{ | 			TypeMeta: unversioned.TypeMeta{ | ||||||
| 				Kind: "Pod", | 				Kind: "Pod", | ||||||
| 			}, | 			}, | ||||||
| @@ -1160,8 +1160,8 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 			}, | 			}, | ||||||
| 		}) | 		}) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
| 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, pod)) | 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, podName, ns)) | ||||||
| 		pod, err = c.Pods(ns).Get(podName) | 		pod, err := c.Pods(ns).Get(podName) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
|  |  | ||||||
| 		nodeName := pod.Spec.NodeName | 		nodeName := pod.Spec.NodeName | ||||||
| @@ -1181,7 +1181,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
|  |  | ||||||
| 		By("Trying to launch the pod, now with Pod affinity and anti affinity.") | 		By("Trying to launch the pod, now with Pod affinity and anti affinity.") | ||||||
| 		labelPodName := "with-podantiaffinity-" + string(util.NewUUID()) | 		labelPodName := "with-podantiaffinity-" + string(util.NewUUID()) | ||||||
| 		pod, err = c.Pods(ns).Create(&api.Pod{ | 		_, err = c.Pods(ns).Create(&api.Pod{ | ||||||
| 			TypeMeta: unversioned.TypeMeta{ | 			TypeMeta: unversioned.TypeMeta{ | ||||||
| 				Kind: "Pod", | 				Kind: "Pod", | ||||||
| 			}, | 			}, | ||||||
| @@ -1232,7 +1232,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 		// kubelet and the scheduler: the scheduler might have scheduled a pod | 		// kubelet and the scheduler: the scheduler might have scheduled a pod | ||||||
| 		// already when the kubelet does not know about its new label yet. The | 		// already when the kubelet does not know about its new label yet. The | ||||||
| 		// kubelet will then refuse to launch the pod. | 		// kubelet will then refuse to launch the pod. | ||||||
| 		framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, labelPodName, pod.ResourceVersion)) | 		framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, labelPodName)) | ||||||
| 		labelPod, err := c.Pods(ns).Get(labelPodName) | 		labelPod, err := c.Pods(ns).Get(labelPodName) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
| 		Expect(labelPod.Spec.NodeName).To(Equal(nodeName)) | 		Expect(labelPod.Spec.NodeName).To(Equal(nodeName)) | ||||||
| @@ -1246,7 +1246,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 		// scheduled onto it. | 		// scheduled onto it. | ||||||
| 		By("Trying to launch a pod with label to get a node which can launch it.") | 		By("Trying to launch a pod with label to get a node which can launch it.") | ||||||
| 		podName := "with-label-" + string(util.NewUUID()) | 		podName := "with-label-" + string(util.NewUUID()) | ||||||
| 		pod, err := c.Pods(ns).Create(&api.Pod{ | 		_, err := c.Pods(ns).Create(&api.Pod{ | ||||||
| 			TypeMeta: unversioned.TypeMeta{ | 			TypeMeta: unversioned.TypeMeta{ | ||||||
| 				Kind: "Pod", | 				Kind: "Pod", | ||||||
| 			}, | 			}, | ||||||
| @@ -1264,8 +1264,8 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 			}, | 			}, | ||||||
| 		}) | 		}) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
| 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, pod)) | 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, podName, ns)) | ||||||
| 		pod, err = c.Pods(ns).Get(podName) | 		pod, err := c.Pods(ns).Get(podName) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
|  |  | ||||||
| 		nodeName := pod.Spec.NodeName | 		nodeName := pod.Spec.NodeName | ||||||
| @@ -1295,7 +1295,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 		// kubelet and the scheduler: the scheduler might have scheduled a pod | 		// kubelet and the scheduler: the scheduler might have scheduled a pod | ||||||
| 		// already when the kubelet does not know about its new label yet. The | 		// already when the kubelet does not know about its new label yet. The | ||||||
| 		// kubelet will then refuse to launch the pod. | 		// kubelet will then refuse to launch the pod. | ||||||
| 		framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, labelPodName, pod.ResourceVersion)) | 		framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, labelPodName)) | ||||||
| 		labelPod, err := c.Pods(ns).Get(labelPodName) | 		labelPod, err := c.Pods(ns).Get(labelPodName) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
| 		Expect(labelPod.Spec.NodeName).To(Equal(nodeName)) | 		Expect(labelPod.Spec.NodeName).To(Equal(nodeName)) | ||||||
| @@ -1312,7 +1312,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 		// scheduled onto it. | 		// scheduled onto it. | ||||||
| 		By("Trying to launch a pod without a toleration to get a node which can launch it.") | 		By("Trying to launch a pod without a toleration to get a node which can launch it.") | ||||||
| 		podName := "without-toleration" | 		podName := "without-toleration" | ||||||
| 		pod, err := c.Pods(ns).Create(&api.Pod{ | 		_, err := c.Pods(ns).Create(&api.Pod{ | ||||||
| 			TypeMeta: unversioned.TypeMeta{ | 			TypeMeta: unversioned.TypeMeta{ | ||||||
| 				Kind: "Pod", | 				Kind: "Pod", | ||||||
| 			}, | 			}, | ||||||
| @@ -1329,8 +1329,8 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 			}, | 			}, | ||||||
| 		}) | 		}) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
| 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, pod)) | 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, podName, ns)) | ||||||
| 		pod, err = c.Pods(ns).Get(podName) | 		pod, err := c.Pods(ns).Get(podName) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
|  |  | ||||||
| 		nodeName := pod.Spec.NodeName | 		nodeName := pod.Spec.NodeName | ||||||
| @@ -1376,7 +1376,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
|  |  | ||||||
| 		By("Trying to relaunch the pod, now with tolerations.") | 		By("Trying to relaunch the pod, now with tolerations.") | ||||||
| 		tolerationPodName := "with-tolerations" | 		tolerationPodName := "with-tolerations" | ||||||
| 		pod, err = c.Pods(ns).Create(&api.Pod{ | 		_, err = c.Pods(ns).Create(&api.Pod{ | ||||||
| 			TypeMeta: unversioned.TypeMeta{ | 			TypeMeta: unversioned.TypeMeta{ | ||||||
| 				Kind: "Pod", | 				Kind: "Pod", | ||||||
| 			}, | 			}, | ||||||
| @@ -1411,7 +1411,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 		// kubelet and the scheduler: the scheduler might have scheduled a pod | 		// kubelet and the scheduler: the scheduler might have scheduled a pod | ||||||
| 		// already when the kubelet does not know about its new taint yet. The | 		// already when the kubelet does not know about its new taint yet. The | ||||||
| 		// kubelet will then refuse to launch the pod. | 		// kubelet will then refuse to launch the pod. | ||||||
| 		framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, tolerationPodName, pod.ResourceVersion)) | 		framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, tolerationPodName)) | ||||||
| 		deployedPod, err := c.Pods(ns).Get(tolerationPodName) | 		deployedPod, err := c.Pods(ns).Get(tolerationPodName) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
| 		Expect(deployedPod.Spec.NodeName).To(Equal(nodeName)) | 		Expect(deployedPod.Spec.NodeName).To(Equal(nodeName)) | ||||||
| @@ -1428,7 +1428,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 		// scheduled onto it. | 		// scheduled onto it. | ||||||
| 		By("Trying to launch a pod without a toleration to get a node which can launch it.") | 		By("Trying to launch a pod without a toleration to get a node which can launch it.") | ||||||
| 		podName := "without-toleration" | 		podName := "without-toleration" | ||||||
| 		pod, err := c.Pods(ns).Create(&api.Pod{ | 		_, err := c.Pods(ns).Create(&api.Pod{ | ||||||
| 			TypeMeta: unversioned.TypeMeta{ | 			TypeMeta: unversioned.TypeMeta{ | ||||||
| 				Kind: "Pod", | 				Kind: "Pod", | ||||||
| 			}, | 			}, | ||||||
| @@ -1445,8 +1445,8 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 			}, | 			}, | ||||||
| 		}) | 		}) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
| 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, pod)) | 		framework.ExpectNoError(framework.WaitForPodRunningInNamespace(c, podName, ns)) | ||||||
| 		pod, err = c.Pods(ns).Get(podName) | 		pod, err := c.Pods(ns).Get(podName) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
|  |  | ||||||
| 		nodeName := pod.Spec.NodeName | 		nodeName := pod.Spec.NodeName | ||||||
| @@ -1492,7 +1492,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
|  |  | ||||||
| 		By("Trying to relaunch the pod, still no tolerations.") | 		By("Trying to relaunch the pod, still no tolerations.") | ||||||
| 		podNameNoTolerations := "still-no-tolerations" | 		podNameNoTolerations := "still-no-tolerations" | ||||||
| 		podNoTolerations := &api.Pod{ | 		podNoTolerations := api.Pod{ | ||||||
| 			TypeMeta: unversioned.TypeMeta{ | 			TypeMeta: unversioned.TypeMeta{ | ||||||
| 				Kind: "Pod", | 				Kind: "Pod", | ||||||
| 			}, | 			}, | ||||||
| @@ -1509,7 +1509,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 				}, | 				}, | ||||||
| 			}, | 			}, | ||||||
| 		} | 		} | ||||||
| 		_, err = c.Pods(ns).Create(podNoTolerations) | 		_, err = c.Pods(ns).Create(&podNoTolerations) | ||||||
| 		framework.ExpectNoError(err) | 		framework.ExpectNoError(err) | ||||||
| 		// Wait a bit to allow scheduler to do its thing | 		// Wait a bit to allow scheduler to do its thing | ||||||
| 		// TODO: this is brittle; there's no guarantee the scheduler will have run in 10 seconds. | 		// TODO: this is brittle; there's no guarantee the scheduler will have run in 10 seconds. | ||||||
| @@ -1521,7 +1521,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
|  |  | ||||||
| 		// TODO(@kevin-wangzefeng) Figure out how to do it correctly | 		// TODO(@kevin-wangzefeng) Figure out how to do it correctly | ||||||
| 		// By("Trying to relaunch the same.") | 		// By("Trying to relaunch the same.") | ||||||
| 		// podNoTolerations, err = c.Pods(ns).Create(&podNoTolerations) | 		// _, err = c.Pods(ns).Create(&podNoTolerations) | ||||||
| 		// framework.ExpectNoError(err) | 		// framework.ExpectNoError(err) | ||||||
| 		// defer c.Pods(ns).Delete(podNameNoTolerations, api.NewDeleteOptions(0)) | 		// defer c.Pods(ns).Delete(podNameNoTolerations, api.NewDeleteOptions(0)) | ||||||
|  |  | ||||||
| @@ -1530,7 +1530,7 @@ var _ = framework.KubeDescribe("SchedulerPredicates [Serial]", func() { | |||||||
| 		// // kubelet and the scheduler: the scheduler might have scheduled a pod | 		// // kubelet and the scheduler: the scheduler might have scheduled a pod | ||||||
| 		// // already when the kubelet does not know about its new taint yet. The | 		// // already when the kubelet does not know about its new taint yet. The | ||||||
| 		// // kubelet will then refuse to launch the pod. | 		// // kubelet will then refuse to launch the pod. | ||||||
| 		// framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, podNameNoTolerations, podNoTolerations.ResourceVersion)) | 		// framework.ExpectNoError(framework.WaitForPodNotPending(c, ns, podNameNoTolerations)) | ||||||
| 		// deployedPod, err := c.Pods(ns).Get(podNameNoTolerations) | 		// deployedPod, err := c.Pods(ns).Get(podNameNoTolerations) | ||||||
| 		// framework.ExpectNoError(err) | 		// framework.ExpectNoError(err) | ||||||
| 		// Expect(deployedPod.Spec.NodeName).To(Equal(nodeName)) | 		// Expect(deployedPod.Spec.NodeName).To(Equal(nodeName)) | ||||||
|   | |||||||
| @@ -168,11 +168,11 @@ func testPodSELinuxLabeling(f *framework.Framework, hostIPC bool, hostPID bool) | |||||||
| 	pod.Spec.Containers[0].Command = []string{"sleep", "6000"} | 	pod.Spec.Containers[0].Command = []string{"sleep", "6000"} | ||||||
|  |  | ||||||
| 	client := f.Client.Pods(f.Namespace.Name) | 	client := f.Client.Pods(f.Namespace.Name) | ||||||
| 	pod, err := client.Create(pod) | 	_, err := client.Create(pod) | ||||||
|  |  | ||||||
| 	framework.ExpectNoError(err, "Error creating pod %v", pod) | 	framework.ExpectNoError(err, "Error creating pod %v", pod) | ||||||
| 	defer client.Delete(pod.Name, nil) | 	defer client.Delete(pod.Name, nil) | ||||||
| 	framework.ExpectNoError(framework.WaitForPodRunningInNamespace(f.Client, pod)) | 	framework.ExpectNoError(framework.WaitForPodRunningInNamespace(f.Client, pod.Name, f.Namespace.Name)) | ||||||
|  |  | ||||||
| 	testContent := "hello" | 	testContent := "hello" | ||||||
| 	testFilePath := mountPath + "/TEST" | 	testFilePath := mountPath + "/TEST" | ||||||
|   | |||||||
| @@ -141,10 +141,10 @@ func startVolumeServer(client *client.Client, config VolumeTestConfig) *api.Pod | |||||||
| 			Volumes: volumes, | 			Volumes: volumes, | ||||||
| 		}, | 		}, | ||||||
| 	} | 	} | ||||||
| 	serverPod, err := podClient.Create(serverPod) | 	_, err := podClient.Create(serverPod) | ||||||
| 	framework.ExpectNoError(err, "Failed to create %s pod: %v", serverPod.Name, err) | 	framework.ExpectNoError(err, "Failed to create %s pod: %v", serverPod.Name, err) | ||||||
|  |  | ||||||
| 	framework.ExpectNoError(framework.WaitForPodRunningInNamespace(client, serverPod)) | 	framework.ExpectNoError(framework.WaitForPodRunningInNamespace(client, serverPod.Name, config.namespace)) | ||||||
|  |  | ||||||
| 	By("locating the server pod") | 	By("locating the server pod") | ||||||
| 	pod, err := podClient.Get(serverPod.Name) | 	pod, err := podClient.Get(serverPod.Name) | ||||||
| @@ -244,14 +244,13 @@ func testVolumeClient(client *client.Client, config VolumeTestConfig, volume api | |||||||
| 	if fsGroup != nil { | 	if fsGroup != nil { | ||||||
| 		clientPod.Spec.SecurityContext.FSGroup = fsGroup | 		clientPod.Spec.SecurityContext.FSGroup = fsGroup | ||||||
| 	} | 	} | ||||||
| 	clientPod, err := podsNamespacer.Create(clientPod) | 	if _, err := podsNamespacer.Create(clientPod); err != nil { | ||||||
| 	if err != nil { |  | ||||||
| 		framework.Failf("Failed to create %s pod: %v", clientPod.Name, err) | 		framework.Failf("Failed to create %s pod: %v", clientPod.Name, err) | ||||||
| 	} | 	} | ||||||
| 	framework.ExpectNoError(framework.WaitForPodRunningInNamespace(client, clientPod)) | 	framework.ExpectNoError(framework.WaitForPodRunningInNamespace(client, clientPod.Name, config.namespace)) | ||||||
|  |  | ||||||
| 	By("Checking that text file contents are perfect.") | 	By("Checking that text file contents are perfect.") | ||||||
| 	_, err = framework.LookForStringInPodExec(config.namespace, clientPod.Name, []string{"cat", "/opt/index.html"}, expectedContent, time.Minute) | 	_, err := framework.LookForStringInPodExec(config.namespace, clientPod.Name, []string{"cat", "/opt/index.html"}, expectedContent, time.Minute) | ||||||
| 	Expect(err).NotTo(HaveOccurred(), "failed: finding the contents of the mounted file.") | 	Expect(err).NotTo(HaveOccurred(), "failed: finding the contents of the mounted file.") | ||||||
|  |  | ||||||
| 	if fsGroup != nil { | 	if fsGroup != nil { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Antoine Pelisse
					Antoine Pelisse