From 946b1c7144cfdae1a4c98d3e7155df548a2bfdb1 Mon Sep 17 00:00:00 2001 From: Yaroslava Serdiuk Date: Tue, 12 Apr 2022 06:08:35 +0000 Subject: [PATCH] Continue CA loop when unregistered nodes were removed --- cluster-autoscaler/core/static_autoscaler.go | 3 +-- cluster-autoscaler/core/static_autoscaler_test.go | 4 ++++ 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/cluster-autoscaler/core/static_autoscaler.go b/cluster-autoscaler/core/static_autoscaler.go index 2b7a97738eb8..5444a58fb59e 100644 --- a/cluster-autoscaler/core/static_autoscaler.go +++ b/cluster-autoscaler/core/static_autoscaler.go @@ -330,8 +330,7 @@ func (a *StaticAutoscaler) RunOnce(currentTime time.Time) errors.AutoscalerError klog.Warningf("Failed to remove unregistered nodes: %v", err) } if removedAny { - klog.V(0).Infof("Some unregistered nodes were removed, skipping iteration") - return nil + klog.V(0).Infof("Some unregistered nodes were removed") } } diff --git a/cluster-autoscaler/core/static_autoscaler_test.go b/cluster-autoscaler/core/static_autoscaler_test.go index d7b08bfbf848..bb1bd64fbe1f 100644 --- a/cluster-autoscaler/core/static_autoscaler_test.go +++ b/cluster-autoscaler/core/static_autoscaler_test.go @@ -291,8 +291,10 @@ func TestStaticAutoscalerRunOnce(t *testing.T) { readyNodeLister.SetNodes([]*apiv1.Node{n1, n2}) allNodeLister.SetNodes([]*apiv1.Node{n1, n2}) scheduledPodMock.On("List").Return([]*apiv1.Pod{p1}, nil).Twice() + unschedulablePodMock.On("List").Return([]*apiv1.Pod{p2}, nil).Once() daemonSetListerMock.On("List", labels.Everything()).Return([]*appsv1.DaemonSet{}, nil).Once() onScaleDownMock.On("ScaleDown", "ng2", "n3").Return(nil).Once() + podDisruptionBudgetListerMock.On("List").Return([]*policyv1.PodDisruptionBudget{}, nil).Once() err = autoscaler.RunOnce(time.Now().Add(5 * time.Hour)) waitForDeleteToFinish(t, autoscaler.scaleDown) @@ -567,8 +569,10 @@ func TestStaticAutoscalerRunOnceWithALongUnregisteredNode(t *testing.T) { readyNodeLister.SetNodes([]*apiv1.Node{n1, n2}) allNodeLister.SetNodes([]*apiv1.Node{n1, n2}) scheduledPodMock.On("List").Return([]*apiv1.Pod{p1}, nil).Twice() + unschedulablePodMock.On("List").Return([]*apiv1.Pod{p2}, nil).Once() onScaleDownMock.On("ScaleDown", "ng1", "broken").Return(nil).Once() daemonSetListerMock.On("List", labels.Everything()).Return([]*appsv1.DaemonSet{}, nil).Once() + podDisruptionBudgetListerMock.On("List").Return([]*policyv1.PodDisruptionBudget{}, nil).Once() err = autoscaler.RunOnce(later.Add(2 * time.Hour)) waitForDeleteToFinish(t, autoscaler.scaleDown)