var _ = framework.KubeDescribe("Restart [Disruptive]", func() { f := framework.NewDefaultFramework("restart") var ps *framework.PodStore BeforeEach(func() { // This test requires the ability to restart all nodes, so the provider // check must be identical to that call. framework.SkipUnlessProviderIs("gce", "gke") ps = framework.NewPodStore(f.Client, api.NamespaceSystem, labels.Everything(), fields.Everything()) }) AfterEach(func() { if ps != nil { ps.Stop() } }) It("should restart all nodes and ensure all nodes and pods recover", func() { nn := framework.TestContext.CloudConfig.NumNodes By("ensuring all nodes are ready") nodeNamesBefore, err := checkNodesReady(f.Client, framework.NodeReadyInitialTimeout, nn) Expect(err).NotTo(HaveOccurred()) framework.Logf("Got the following nodes before restart: %v", nodeNamesBefore) By("ensuring all pods are running and ready") pods := ps.List() podNamesBefore := make([]string, len(pods)) for i, p := range pods {