diff --git a/controllers/pod.go b/controllers/pod.go index 160c79c1..25204a59 100644 --- a/controllers/pod.go +++ b/controllers/pod.go @@ -1538,13 +1538,13 @@ func (r *SingleClusterReconciler) updateOperationStatus(restartedASDPodNames, re statusPods := sets.New(statusOp.PodList...) if statusOp.Kind == asdbv1.OperationWarmRestart { - if quickRestartsSet != nil { + if quickRestartsSet.Len() > 0 { statusOp.PodList = statusPods.Union(quickRestartsSet.Intersection(specPods)).UnsortedList() } // If the operation is a warm restart and the pod undergoes a cold restart for any reason, // we will still consider the warm restart operation as completed for that pod. - if podRestartsSet != nil { + if podRestartsSet.Len() > 0 { statusOp.PodList = statusPods.Union(podRestartsSet.Intersection(specPods)).UnsortedList() } } @@ -1562,13 +1562,13 @@ func (r *SingleClusterReconciler) updateOperationStatus(restartedASDPodNames, re var podList []string if specOp.Kind == asdbv1.OperationWarmRestart { - if quickRestartsSet != nil { + if quickRestartsSet.Len() > 0 { podList = quickRestartsSet.Intersection(specPods).UnsortedList() } // If the operation is a warm restart and the pod undergoes a cold restart for any reason, // we will still consider the warm restart operation as completed for that pod. - if podRestartsSet != nil { + if podRestartsSet.Len() > 0 { podList = append(podList, podRestartsSet.Intersection(specPods).UnsortedList()...) } } diff --git a/controllers/rack.go b/controllers/rack.go index eaf6e74d..d51d49ac 100644 --- a/controllers/rack.go +++ b/controllers/rack.go @@ -87,7 +87,7 @@ func (r *SingleClusterReconciler) reconcileRacks() common.ReconcileResult { // remove ignorable pods from failedPods failedPods = getNonIgnorablePods(failedPods, ignorablePodNames) if len(failedPods) != 0 { - r.Log.Info("Reconcile the failed pods in the Rack", "rackID", state.Rack.ID, "failedPods", failedPods) + r.Log.Info("Reconcile the failed pods in the Rack", "rackID", state.Rack.ID, "failedPods", getPodNames(failedPods)) if res = r.reconcileRack( found, state, ignorablePodNames, failedPods, @@ -95,7 +95,7 @@ func (r *SingleClusterReconciler) reconcileRacks() common.ReconcileResult { return res } - r.Log.Info("Reconciled the failed pods in the Rack", "rackID", state.Rack.ID, "failedPods", failedPods) + r.Log.Info("Reconciled the failed pods in the Rack", "rackID", state.Rack.ID, "failedPods", getPodNames(failedPods)) } // 2. Again, fetch the pods for the rack and if there are failed pods then restart them. @@ -115,14 +115,14 @@ func (r *SingleClusterReconciler) reconcileRacks() common.ReconcileResult { // remove ignorable pods from failedPods failedPods = getNonIgnorablePods(failedPods, ignorablePodNames) if len(failedPods) != 0 { - r.Log.Info("Restart the failed pods in the Rack", "rackID", state.Rack.ID, "failedPods", failedPods) + r.Log.Info("Restart the failed pods in the Rack", "rackID", state.Rack.ID, "failedPods", getPodNames(failedPods)) if _, res = r.rollingRestartRack(found, state, ignorablePodNames, nil, failedPods); !res.IsSuccess { return res } - r.Log.Info("Restarted the failed pods in the Rack", "rackID", state.Rack.ID, "failedPods", failedPods) + r.Log.Info("Restarted the failed pods in the Rack", "rackID", state.Rack.ID, "failedPods", getPodNames(failedPods)) // Requeue after 1 second to fetch latest CR object with updated pod status return common.ReconcileRequeueAfter(1) } diff --git a/test/cluster/cluster_test.go b/test/cluster/cluster_test.go index 85fe5662..ca4e5824 100644 --- a/test/cluster/cluster_test.go +++ b/test/cluster/cluster_test.go @@ -351,6 +351,7 @@ func clusterWithMaxIgnorablePod(ctx goctx.Context) { err = k8sClient.Update(ctx, pod) Expect(err).ToNot(HaveOccurred()) + // Underlying kubernetes cluster should have atleast 6 nodes to run this test successfully. By("Delete rack with id 2") aeroCluster, err = getCluster(k8sClient, ctx, clusterNamespacedName) Expect(err).ToNot(HaveOccurred())