Skip to content

Commit

Permalink
datadog_scaler: handle mising { on dd query
Browse files Browse the repository at this point in the history
Signed-off-by: Ali Reza Yahya <ali.reza.yahya@wolt.com>

datadog_scaler: update change log

Signed-off-by: Ali Reza Yahya <ali.reza.yahya@wolt.com>

Update CHANGELOG.md

Co-authored-by: Zbynek Roubalik <726523+zroubalik@users.noreply.github.com>
  • Loading branch information
Ali Reza Yahya and zroubalik committed Feb 14, 2022
1 parent 85dd397 commit 3871c0d
Show file tree
Hide file tree
Showing 3 changed files with 6 additions and 0 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@
### Improvements

- **Azure Queue:** Don't call Azure queue GetProperties API unnecessarily ([#2613](https://github.com/kedacore/keda/pull/2613))
- **Datadog Scaler:** Validate query to contain `{` to prevent panic on invalid query ([#2625](https://github.com/kedacore/keda/issues/2625))

### Breaking Changes

Expand Down
3 changes: 3 additions & 0 deletions pkg/scalers/datadog_scaler.go
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,9 @@ func parseDatadogMetadata(config *ScalerConfig) (*datadogMetadata, error) {
} else {
return nil, fmt.Errorf("no query given")
}
if !strings.Contains(meta.query, "{") {
return nil, fmt.Errorf("expecting query to contain `{`, got %s", meta.query)
}

if val, ok := config.TriggerMetadata["queryValue"]; ok {
queryValue, err := strconv.Atoi(val)
Expand Down
2 changes: 2 additions & 0 deletions pkg/scalers/datadog_scaler_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,8 @@ var testDatadogMetadata = []datadogAuthMetadataTestData{
{map[string]string{"query": "sum:trace.redis.command.hits{env:none,service:redis}.as_count()", "queryValue": "7"}, map[string]string{"appKey": "appKey"}, true},
// missing appKey
{map[string]string{"query": "sum:trace.redis.command.hits{env:none,service:redis}.as_count()", "queryValue": "7"}, map[string]string{"apiKey": "apiKey"}, true},
// invalid query missing {
{map[string]string{"query": "sum:trace.redis.command.hits.as_count()", "queryValue": "7"}, map[string]string{}, true},
}

func TestDatadogScalerAuthParams(t *testing.T) {
Expand Down

0 comments on commit 3871c0d

Please sign in to comment.