Return an error when unknown options are found in the config file
This commit is contained in:
parent
c5be09ca48
commit
00fed1a31f
@ -38,7 +38,9 @@ func Load(configFileName string, flagSet *pflag.FlagSet, into interface{}) error
|
||||
return fmt.Errorf("unable to register flags: %w", err)
|
||||
}
|
||||
|
||||
err = v.Unmarshal(into, decodeFromCfgTag)
|
||||
// UnmarhsalExact will return an error if the config includes options that are
|
||||
// not mapped to felds of the into struct
|
||||
err = v.UnmarshalExact(into, decodeFromCfgTag)
|
||||
if err != nil {
|
||||
return fmt.Errorf("error unmarshalling config: %w", err)
|
||||
}
|
||||
|
@ -283,6 +283,18 @@ var _ = Describe("Load", func() {
|
||||
unexported: "unexported",
|
||||
},
|
||||
}),
|
||||
Entry("with an unknown option in the config file", &testOptionsTableInput{
|
||||
configFile: []byte(`unknown_option="foo"`),
|
||||
flagSet: func() *pflag.FlagSet { return testOptionsFlagSet },
|
||||
expectedErr: fmt.Errorf("error unmarshalling config: 1 error(s) decoding:\n\n* '' has invalid keys: unknown_option"),
|
||||
// Viper will unmarshal before returning the error, so this is the default output
|
||||
expectedOutput: &TestOptions{
|
||||
StringOption: "default",
|
||||
Sub: TestOptionSubStruct{
|
||||
StringSliceOption: []string{"a", "b"},
|
||||
},
|
||||
},
|
||||
}),
|
||||
)
|
||||
})
|
||||
})
|
||||
|
Loading…
x
Reference in New Issue
Block a user