e2e: node: podresources: fix restart wait
Fix the waiting logic in the e2e test loop to wait for resources to be reported again instead of making logic on the timestamp. The idea is that waiting for resource availability is the canonical way clients should observe the desired state, and it should also be more robust than comparing timestamps, especially on CI environments. Signed-off-by: Francesco Romani <fromani@redhat.com>
This commit is contained in:
		| @@ -806,23 +806,13 @@ var _ = SIGDescribe("POD Resources [Serial] [Feature:PodResources][NodeFeature:P | |||||||
|  |  | ||||||
| 					expectPodResources(ctx, 1, cli, []podDesc{desc}) | 					expectPodResources(ctx, 1, cli, []podDesc{desc}) | ||||||
|  |  | ||||||
| 					restartTime := time.Now() |  | ||||||
| 					ginkgo.By("Restarting Kubelet") | 					ginkgo.By("Restarting Kubelet") | ||||||
| 					restartKubelet(true) | 					restartKubelet(true) | ||||||
|  |  | ||||||
| 					// we need to wait for the node to be reported ready before we can safely query | 					// we need to wait for the node to be reported ready before we can safely query | ||||||
| 					// the podresources endpoint again. Otherwise we will have false negatives. | 					// the podresources endpoint again. Otherwise we will have false negatives. | ||||||
| 					ginkgo.By("Wait for node to be ready") | 					ginkgo.By("Wait for node to be ready") | ||||||
| 					gomega.Eventually(ctx, func() bool { | 					waitForTopologyUnawareResources(ctx, f) | ||||||
| 						node, err := f.ClientSet.CoreV1().Nodes().Get(ctx, framework.TestContext.NodeName, metav1.GetOptions{}) |  | ||||||
| 						framework.ExpectNoError(err) |  | ||||||
| 						for _, cond := range node.Status.Conditions { |  | ||||||
| 							if cond.Type == v1.NodeReady && cond.Status == v1.ConditionTrue && cond.LastHeartbeatTime.After(restartTime) { |  | ||||||
| 								return true |  | ||||||
| 							} |  | ||||||
| 						} |  | ||||||
| 						return false |  | ||||||
| 					}, 5*time.Minute, framework.Poll).Should(gomega.BeTrue()) |  | ||||||
|  |  | ||||||
| 					expectPodResources(ctx, 1, cli, []podDesc{desc}) | 					expectPodResources(ctx, 1, cli, []podDesc{desc}) | ||||||
| 					tpd.deletePodsForTest(ctx, f) | 					tpd.deletePodsForTest(ctx, f) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Francesco Romani
					Francesco Romani