From 6f71dcda4428bbd44c45bcb96a466f03eaf92eed Mon Sep 17 00:00:00 2001 From: Zbynek Roubalik <726523+zroubalik@users.noreply.github.com> Date: Tue, 16 Jun 2020 21:52:52 +0200 Subject: [PATCH] RabbitMQ: make queueLength optional (#881) Signed-off-by: Zbynek Roubalik --- go.mod | 2 +- pkg/scalers/rabbitmq_scaler.go | 3 ++- pkg/scalers/rabbitmq_scaler_test.go | 20 ++++++++++++++++++++ 3 files changed, 23 insertions(+), 2 deletions(-) diff --git a/go.mod b/go.mod index ba17699c1e0..2fc49c351ce 100644 --- a/go.mod +++ b/go.mod @@ -58,8 +58,8 @@ require ( github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822 // indirect github.com/operator-framework/operator-sdk v0.0.0-00010101000000-000000000000 github.com/pkg/errors v0.8.1 - github.com/spf13/pflag v1.0.5 github.com/robfig/cron/v3 v3.0.1 + github.com/spf13/pflag v1.0.5 github.com/streadway/amqp v0.0.0-20190827072141-edfb9018d271 github.com/stretchr/testify v1.4.0 github.com/xdg/scram v0.0.0-20180814205039-7eeb5667e42c diff --git a/pkg/scalers/rabbitmq_scaler.go b/pkg/scalers/rabbitmq_scaler.go index 1f859c4d485..44bf495bf17 100644 --- a/pkg/scalers/rabbitmq_scaler.go +++ b/pkg/scalers/rabbitmq_scaler.go @@ -21,6 +21,7 @@ import ( const ( rabbitQueueLengthMetricName = "queueLength" + defaultRabbitMQQueueLength = 20 rabbitMetricType = "External" rabbitIncludeUnacked = "includeUnacked" defaultIncludeUnacked = false @@ -127,7 +128,7 @@ func parseRabbitMQMetadata(resolvedEnv, metadata, authParams map[string]string) meta.queueLength = queueLength } else { - return nil, fmt.Errorf("no queue length given") + meta.queueLength = defaultRabbitMQQueueLength } return &meta, nil diff --git a/pkg/scalers/rabbitmq_scaler_test.go b/pkg/scalers/rabbitmq_scaler_test.go index 4ccc406e8e9..dbacdc805a6 100644 --- a/pkg/scalers/rabbitmq_scaler_test.go +++ b/pkg/scalers/rabbitmq_scaler_test.go @@ -54,6 +54,26 @@ func TestRabbitMQParseMetadata(t *testing.T) { } } +var testDefaultQueueLength = []parseRabbitMQMetadataTestData{ + // use default queueLength + {map[string]string{"queueName": "sample", "host": host}, false, map[string]string{}}, + // use default queueLength with includeUnacked + {map[string]string{"queueName": "sample", "apiHost": apiHost, "includeUnacked": "true"}, false, map[string]string{}}, +} + +func TestParseDefaultQueueLength(t *testing.T) { + for _, testData := range testDefaultQueueLength { + metadata, err := parseRabbitMQMetadata(sampleRabbitMqResolvedEnv, testData.metadata, testData.authParams) + if err != nil && !testData.isError { + t.Error("Expected success but got error", err) + } else if testData.isError && err == nil { + t.Error("Expected error but got success") + } else if metadata.queueLength != defaultRabbitMQQueueLength { + t.Error("Expected default queueLength =", defaultRabbitMQQueueLength, "but got", metadata.queueLength) + } + } +} + type getQueueInfoTestData struct { response string responseStatus int