cc.cmd.PersistentFlags().BoolVar(&cc.quiet, "quiet", false, "build in quiet mode")
 
        // Set bash-completion
-       validConfigFilenames := []string{"json", "js", "yaml", "yml", "toml", "tml"}
-       _ = cc.cmd.PersistentFlags().SetAnnotation("config", cobra.BashCompFilenameExt, validConfigFilenames)
+       _ = cc.cmd.PersistentFlags().SetAnnotation("config", cobra.BashCompFilenameExt, config.ValidConfigFileExtensions)
 
        cc.cmd.PersistentFlags().BoolVarP(&cc.verbose, "verbose", "v", false, "verbose output")
        cc.cmd.PersistentFlags().BoolVarP(&cc.debug, "debug", "", false, "debug output")
 
        "github.com/spf13/viper"
 )
 
+var (
+       ValidConfigFileExtensions = []string{"toml", "yaml", "yml", "json"}
+)
+
 // FromConfigString creates a config from the given YAML, JSON or TOML config. This is useful in tests.
 func FromConfigString(config, configType string) (Provider, error) {
        v := newViper()
 
                        filename = baseFilename
                }
        } else {
-               for _, ext := range []string{"toml", "yaml", "yml", "json"} {
+               for _, ext := range config.ValidConfigFileExtensions {
                        filenameToCheck := baseFilename + "." + ext
                        exists, _ := helpers.Exists(filenameToCheck, l.Fs)
                        if exists {
 
        )
 
        // Viper supports more, but this is the sub-set supported by Hugo.
-       for _, configFormats := range []string{"toml", "yaml", "yml", "json"} {
+       for _, configFormats := range config.ValidConfigFileExtensions {
                configFilename = filepath.Join(configDir, "config."+configFormats)
                exists, _ = afero.Exists(c.fs, configFilename)
                if exists {