diff --git a/cluster-autoscaler/expander/priority/priority.go b/cluster-autoscaler/expander/priority/priority.go index 37f0d38a23f1..f794931f3f72 100644 --- a/cluster-autoscaler/expander/priority/priority.go +++ b/cluster-autoscaler/expander/priority/priority.go @@ -148,7 +148,6 @@ func (p *priority) BestOption(expansionOptions []expander.Option, nodeInfo map[s } best = append(best, option) found = true - break } if !found { msg := fmt.Sprintf("Priority expander: node group %s not found in priority expander configuration. "+ diff --git a/cluster-autoscaler/expander/priority/priority_test.go b/cluster-autoscaler/expander/priority/priority_test.go index 592d2e26e323..41bc2e7ba835 100644 --- a/cluster-autoscaler/expander/priority/priority_test.go +++ b/cluster-autoscaler/expander/priority/priority_test.go @@ -62,6 +62,13 @@ var ( 10: - ".*t\\.large.*" ` + wildcardMatchconfig = ` +5: + - ".*" +10: + - ".t2\\.large.*" +` + eoT2Micro = expander.Option{ Debug: "t2.micro", NodeGroup: test.NewTestNodeGroup("my-asg.t2.micro", 10, 1, 1, true, false, "t2.micro", nil, nil), @@ -109,6 +116,14 @@ func TestPriorityExpanderCorrecltySelectsSingleMatchingOptionOutOfMany(t *testin assert.Equal(t, *ret, eoM44XLarge) } +func TestPriorityExpanderDoesNotFallBackToRandomWhenHigherPriorityMatches(t *testing.T) { + s, _, _, _ := getStrategyInstance(t, wildcardMatchconfig) + for i := 0; i < 10; i++ { + ret := s.BestOption([]expander.Option{eoT2Large, eoT2Micro}, nil) + assert.Equal(t, *ret, eoT2Large) + } +} + func TestPriorityExpanderCorrecltySelectsOneOfTwoMatchingOptionsOutOfMany(t *testing.T) { s, _, _, _ := getStrategyInstance(t, config) for i := 0; i < 10; i++ {