From eacd3f405e37d995df3f7abb48d0a3a9e60759bb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lovro=20Ma=C5=BEgon?= Date: Wed, 17 Apr 2024 18:24:13 +0200 Subject: [PATCH] don't populate empty defaults --- config/config.go | 2 +- config/config_test.go | 4 +--- 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/config/config.go b/config/config.go index 06763c7..2aa4c4d 100644 --- a/config/config.go +++ b/config/config.go @@ -51,7 +51,7 @@ func (c Config) Sanitize() Config { func (c Config) ApplyDefaults(params Parameters) Config { for key, param := range params { for _, key := range c.getKeysForParameter(key) { - if strings.TrimSpace(c[key]) == "" { + if strings.TrimSpace(c[key]) == "" && param.Default != "" { c[key] = param.Default } } diff --git a/config/config_test.go b/config/config_test.go index b554591..c6130f7 100644 --- a/config/config_test.go +++ b/config/config_test.go @@ -621,7 +621,7 @@ func TestConfig_ApplyDefaults(t *testing.T) { want: Config{ "limit": "-1", "foo.0.param1": "custom", - "foo.0.param2": "", + // empty defaults are not populated }, }, { name: "multiple dynamic params", @@ -634,11 +634,9 @@ func TestConfig_ApplyDefaults(t *testing.T) { want: Config{ "limit": "-1", "foo.0.param1": "parameter", - "foo.0.param2": "", "foo.1.param1": "foo", "foo.1.param2": "custom", "foo.2.param1": "foo", - "foo.2.param2": "", "foo.2.does-not-exist": "unrecognized key still triggers creation of defaults", }, }}