From f5729604b04ee817638bd397fb0e2a46c672dc0f Mon Sep 17 00:00:00 2001 From: Bradley Jones Date: Thu, 12 Sep 2024 23:02:32 +0100 Subject: [PATCH] fix: ensure missing config errors are caught issue #269 Signed-off-by: Bradley Jones --- internal/config/config.go | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/internal/config/config.go b/internal/config/config.go index 9332532..46dd973 100644 --- a/internal/config/config.go +++ b/internal/config/config.go @@ -175,16 +175,19 @@ func setNonCliDefaultValues(v *viper.Viper) { func LoadConfigFromFile(v *viper.Viper, cliOpts *CliOnlyOptions) (*Application, error) { // the user may not have a config, and this is OK, we can use the default config + default cobra cli values instead setNonCliDefaultValues(v) + cfgPath := "" if cliOpts != nil { - _ = readConfig(v, cliOpts.ConfigPath) - } else { - _ = readConfig(v, "") + cfgPath = cliOpts.ConfigPath + } + err := readConfig(v, cfgPath) + if err != nil && cfgPath != "" { + return nil, err } config := &Application{ CliOptions: *cliOpts, } - err := v.Unmarshal(config) + err = v.Unmarshal(config) if err != nil { return nil, fmt.Errorf("unable to parse config: %w", err) }