diff --git a/CHANGELOG.md b/CHANGELOG.md index 38644faaad5..031656676ba 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -55,6 +55,7 @@ To learn more about active deprecations, we recommend checking [GitHub Discussio ### Fixes - **General:** Provide patch for CVE-2022-3172 vulnerability ([#3690](https://github.com/kedacore/keda/issues/3690)) +- **General:** Respect optional parameter inside envs for ScaledJobs ([#3568](https://github.com/kedacore/keda/issues/3568)) ### Deprecations diff --git a/pkg/scaling/resolver/scale_resolvers.go b/pkg/scaling/resolver/scale_resolvers.go index d420b944a79..1b47227cad1 100644 --- a/pkg/scaling/resolver/scale_resolvers.go +++ b/pkg/scaling/resolver/scale_resolvers.go @@ -332,6 +332,9 @@ func resolveEnv(ctx context.Context, client client.Client, logger logr.Logger, c // env is a secret selector value, err = resolveSecretValue(ctx, client, envVar.ValueFrom.SecretKeyRef, envVar.ValueFrom.SecretKeyRef.Key, namespace) if err != nil { + if envVar.ValueFrom.SecretKeyRef.Optional != nil && *envVar.ValueFrom.SecretKeyRef.Optional { + continue + } return nil, fmt.Errorf("error resolving secret name %s for env %s in namespace %s", envVar.ValueFrom.SecretKeyRef, envVar.Name, @@ -341,6 +344,9 @@ func resolveEnv(ctx context.Context, client client.Client, logger logr.Logger, c // env is a configMap selector value, err = resolveConfigValue(ctx, client, envVar.ValueFrom.ConfigMapKeyRef, envVar.ValueFrom.ConfigMapKeyRef.Key, namespace) if err != nil { + if envVar.ValueFrom.ConfigMapKeyRef.Optional != nil && *envVar.ValueFrom.ConfigMapKeyRef.Optional { + continue + } return nil, fmt.Errorf("error resolving config %s for env %s in namespace %s", envVar.ValueFrom.ConfigMapKeyRef, envVar.Name, diff --git a/pkg/scaling/resolver/scale_resolvers_test.go b/pkg/scaling/resolver/scale_resolvers_test.go index e4a109b6bdb..6f5f9d53a77 100644 --- a/pkg/scaling/resolver/scale_resolvers_test.go +++ b/pkg/scaling/resolver/scale_resolvers_test.go @@ -143,6 +143,78 @@ var testMetadatas = []testMetadata{ }}, }, }, + { + isError: false, + comment: "configmap does not exist, but it is marked as an optional, there should not be an error", + container: &corev1.Container{ + Env: []corev1.EnvVar{{ + Name: "test", + ValueFrom: &corev1.EnvVarSource{ + ConfigMapKeyRef: &corev1.ConfigMapKeySelector{ + LocalObjectReference: corev1.LocalObjectReference{ + Name: "do-not-exist-and-optional-explicitly", + }, + Key: "test", + Optional: &trueValue, + }, + }, + }}, + }, + }, + { + isError: false, + comment: "secret does not exist, but it is marked as an optional, there should not be an error", + container: &corev1.Container{ + Env: []corev1.EnvVar{{ + Name: "test", + ValueFrom: &corev1.EnvVarSource{ + SecretKeyRef: &corev1.SecretKeySelector{ + LocalObjectReference: corev1.LocalObjectReference{ + Name: "do-not-exist-and-optional-explicitly", + }, + Key: "test", + Optional: &trueValue, + }, + }, + }}, + }, + }, + { + isError: true, + comment: "configmap does not exist, and it is not marked as an optional, there should be an error", + container: &corev1.Container{ + Env: []corev1.EnvVar{{ + Name: "test", + ValueFrom: &corev1.EnvVarSource{ + ConfigMapKeyRef: &corev1.ConfigMapKeySelector{ + LocalObjectReference: corev1.LocalObjectReference{ + Name: "do-not-exist-and-not-optional", + }, + Key: "test", + Optional: &falseValue, + }, + }, + }}, + }, + }, + { + isError: true, + comment: "secret does not exist, and it is not marked as an optional, there should be an error", + container: &corev1.Container{ + Env: []corev1.EnvVar{{ + Name: "test", + ValueFrom: &corev1.EnvVarSource{ + SecretKeyRef: &corev1.SecretKeySelector{ + LocalObjectReference: corev1.LocalObjectReference{ + Name: "do-not-exist-and-not-optional", + }, + Key: "test", + Optional: &falseValue, + }, + }, + }}, + }, + }, } func TestResolveNonExistingConfigMapsOrSecretsEnv(t *testing.T) {