From 6ae98747ff960757b10d630b8daca260ed244dd7 Mon Sep 17 00:00:00 2001 From: Shane Date: Tue, 19 Nov 2024 14:39:43 +0800 Subject: [PATCH 1/5] revise some object name and fix fallback check Signed-off-by: Shane --- apis/keda/v1alpha1/scaledobject_types.go | 8 ++++---- apis/keda/v1alpha1/scaledobject_webhook.go | 2 +- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/apis/keda/v1alpha1/scaledobject_types.go b/apis/keda/v1alpha1/scaledobject_types.go index 37c5e640963..216a93b6f9a 100644 --- a/apis/keda/v1alpha1/scaledobject_types.go +++ b/apis/keda/v1alpha1/scaledobject_types.go @@ -237,7 +237,7 @@ func (so *ScaledObject) IsUsingModifiers() bool { return so.Spec.Advanced != nil && !reflect.DeepEqual(so.Spec.Advanced.ScalingModifiers, ScalingModifiers{}) } -// getHPAMinReplicas returns MinReplicas based on definition in ScaledObject or default value if not defined +// GetHPAMinReplicas returns MinReplicas based on definition in ScaledObject or default value if not defined func (so *ScaledObject) GetHPAMinReplicas() *int32 { if so.Spec.MinReplicaCount != nil && *so.Spec.MinReplicaCount > 0 { return so.Spec.MinReplicaCount @@ -246,7 +246,7 @@ func (so *ScaledObject) GetHPAMinReplicas() *int32 { return &tmp } -// getHPAMaxReplicas returns MaxReplicas based on definition in ScaledObject or default value if not defined +// GetHPAMaxReplicas returns MaxReplicas based on definition in ScaledObject or default value if not defined func (so *ScaledObject) GetHPAMaxReplicas() int32 { if so.Spec.MaxReplicaCount != nil { return *so.Spec.MaxReplicaCount @@ -254,7 +254,7 @@ func (so *ScaledObject) GetHPAMaxReplicas() int32 { return defaultHPAMaxReplicas } -// checkReplicaCountBoundsAreValid checks that Idle/Min/Max ReplicaCount defined in ScaledObject are correctly specified +// CheckReplicaCountBoundsAreValid checks that Idle/Min/Max ReplicaCount defined in ScaledObject are correctly specified // i.e. that Min is not greater than Max or Idle greater or equal to Min func CheckReplicaCountBoundsAreValid(scaledObject *ScaledObject) error { min := int32(0) @@ -291,7 +291,7 @@ func CheckFallbackValid(scaledObject *ScaledObject) error { return fmt.Errorf("type is %s , but fallback it is not supported by the CPU & memory scalers", trigger.Type) } if trigger.MetricType != autoscalingv2.AverageValueMetricType { - return fmt.Errorf("MetricType=%s, but Fallback can only be enabled for triggers with metric of type AverageValue", trigger.MetricType) + return fmt.Errorf("MetricType=%s, but fallback can only be enabled for triggers with metric of type AverageValue", trigger.MetricType) } } return nil diff --git a/apis/keda/v1alpha1/scaledobject_webhook.go b/apis/keda/v1alpha1/scaledobject_webhook.go index 41bd0355596..4b7e0cb60e3 100644 --- a/apis/keda/v1alpha1/scaledobject_webhook.go +++ b/apis/keda/v1alpha1/scaledobject_webhook.go @@ -193,7 +193,7 @@ func verifyFallback(incomingSo *ScaledObject, action string, _ bool) error { scaledobjectlog.WithValues("name", incomingSo.Name).Error(err, "validation error") metricscollector.RecordScaledObjectValidatingErrors(incomingSo.Namespace, action, "incorrect-fallback") } - return nil + return err } func verifyTriggers(incomingObject interface{}, action string, _ bool) error { From 6986e93e38e90b8fc1c858c24762f08f23038e49 Mon Sep 17 00:00:00 2001 From: Shane Date: Tue, 19 Nov 2024 15:30:45 +0800 Subject: [PATCH 2/5] add changelog Signed-off-by: Shane --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index dbba7b57a05..f5e55677fa6 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -58,7 +58,7 @@ To learn more about active deprecations, we recommend checking [GitHub Discussio ### New -- TODO ([#XXX](https://github.com/kedacore/keda/issues/XXX)) +- **General**: Revise some annotations above function and fix fallback check bug ([#6346](https://github.com/kedacore/keda/pull/6346) #### Experimental From 55c962bf7b5e6cf3bf15c677c01f1cddfce809ad Mon Sep 17 00:00:00 2001 From: Shane Date: Tue, 19 Nov 2024 17:16:10 +0800 Subject: [PATCH 3/5] fix CAHNGELOG.MD Signed-off-by: Shane --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index f5e55677fa6..a5ab24a0b52 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -58,7 +58,7 @@ To learn more about active deprecations, we recommend checking [GitHub Discussio ### New -- **General**: Revise some annotations above function and fix fallback check bug ([#6346](https://github.com/kedacore/keda/pull/6346) +- **General**: Revise some annotations above function and fix fallback check bug ([#6346](https://github.com/kedacore/keda/pull/6346)) #### Experimental From dfeed8232f5006da13ab5f2bc972eb605b8eb77e Mon Sep 17 00:00:00 2001 From: Shane Date: Tue, 19 Nov 2024 17:22:34 +0800 Subject: [PATCH 4/5] put new log in CAHNGELOG.MD fix section Signed-off-by: Shane --- CHANGELOG.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index a5ab24a0b52..2db61f58625 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -58,7 +58,7 @@ To learn more about active deprecations, we recommend checking [GitHub Discussio ### New -- **General**: Revise some annotations above function and fix fallback check bug ([#6346](https://github.com/kedacore/keda/pull/6346)) +- TODO ([#XXX](https://github.com/kedacore/keda/issues/XXX)) #### Experimental @@ -73,6 +73,7 @@ Here is an overview of all new **experimental** features: ### Fixes - **General**: Paused ScaledObject count is reported correctly after operator restart ([#6321](https://github.com/kedacore/keda/issues/6321)) +- **General**: Revise some annotations above function and fix fallback check bug ([#6346](https://github.com/kedacore/keda/pull/6346)) ### Deprecations From f2ad7309ea96d02c6d6d0a34188dc78fca453a16 Mon Sep 17 00:00:00 2001 From: Shane Date: Thu, 28 Nov 2024 22:09:23 +0800 Subject: [PATCH 5/5] change fallback check Signed-off-by: Shane --- apis/keda/v1alpha1/scaledobject_types.go | 14 +++++++++++++- apis/keda/v1alpha1/scaledobject_webhook_test.go | 4 ++-- pkg/common/message/message.go | 2 ++ 3 files changed, 17 insertions(+), 3 deletions(-) diff --git a/apis/keda/v1alpha1/scaledobject_types.go b/apis/keda/v1alpha1/scaledobject_types.go index 216a93b6f9a..74a0cc030d1 100644 --- a/apis/keda/v1alpha1/scaledobject_types.go +++ b/apis/keda/v1alpha1/scaledobject_types.go @@ -21,10 +21,21 @@ import ( "reflect" "strconv" + eventingv1alpha1 "github.com/kedacore/keda/v2/apis/eventing/v1alpha1" + "github.com/kedacore/keda/v2/pkg/common/message" + "github.com/kedacore/keda/v2/pkg/eventemitter" + "github.com/kedacore/keda/v2/pkg/eventreason" + autoscalingv2 "k8s.io/api/autoscaling/v2" + corev1 "k8s.io/api/core/v1" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + logf "sigs.k8s.io/controller-runtime/pkg/log" ) +var scaledobjecttypeslog = logf.Log.WithName("scaledobject-types") + +var EventEmitter eventemitter.EventHandler + // +genclient // +kubebuilder:object:root=true // +kubebuilder:subresource:status @@ -288,7 +299,8 @@ func CheckFallbackValid(scaledObject *ScaledObject) error { for _, trigger := range scaledObject.Spec.Triggers { if trigger.Type == cpuString || trigger.Type == memoryString { - return fmt.Errorf("type is %s , but fallback it is not supported by the CPU & memory scalers", trigger.Type) + scaledobjecttypeslog.Error(nil, fmt.Sprintf("type is %s , but fallback it is not supported by the CPU & memory scalers", trigger.Type)) + EventEmitter.Emit(scaledObject, scaledObject.Namespace, corev1.EventTypeWarning, eventingv1alpha1.ScaledObjectFailedType, eventreason.ScaledObjectCheckFailed, message.ScaledObjectMayNotBehaveAsExpectationMsg) } if trigger.MetricType != autoscalingv2.AverageValueMetricType { return fmt.Errorf("MetricType=%s, but fallback can only be enabled for triggers with metric of type AverageValue", trigger.MetricType) diff --git a/apis/keda/v1alpha1/scaledobject_webhook_test.go b/apis/keda/v1alpha1/scaledobject_webhook_test.go index e30404d16c4..08970b121ac 100644 --- a/apis/keda/v1alpha1/scaledobject_webhook_test.go +++ b/apis/keda/v1alpha1/scaledobject_webhook_test.go @@ -176,7 +176,7 @@ var _ = It("shouldn't validate the so creation when the fallback is wrong", func }).Should(HaveOccurred()) }) -var _ = It("shouldn't validate the so creation When the fallback are configured and the scaler is either CPU or memory.", func() { +var _ = It("should validate the so creation When the fallback are configured and the scaler is either CPU or memory.", func() { namespaceName := "wrong-fallback-cpu-memory" namespace := createNamespace(namespaceName) workload := createDeployment(namespaceName, true, true) @@ -193,7 +193,7 @@ var _ = It("shouldn't validate the so creation When the fallback are configured Eventually(func() error { return k8sClient.Create(context.Background(), so) - }).Should(HaveOccurred()) + }).ShouldNot(HaveOccurred()) }) var _ = It("shouldn't validate the so creation when there is another unmanaged hpa and so has transfer-hpa-ownership activated", func() { diff --git a/pkg/common/message/message.go b/pkg/common/message/message.go index 4abcc0402ff..388e032d75e 100644 --- a/pkg/common/message/message.go +++ b/pkg/common/message/message.go @@ -42,4 +42,6 @@ const ( ClusterTriggerAuthenticationCreatedMsg = "New ClusterTriggerAuthentication configured" ClusterTriggerAuthenticationUpdatedMsg = "ClusterTriggerAuthentication %s is updated" + + ScaledObjectMayNotBehaveAsExpectationMsg = "ScaledObject may not behave as expectation" )