Add support for multiple config files via --config a.toml,b.toml,c.toml
authorJohan Gielstra <jgielstra@users.noreply.github.com>
Wed, 9 Aug 2017 18:13:02 +0000 (13:13 -0500)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Wed, 9 Aug 2017 18:13:02 +0000 (20:13 +0200)
hugolib/config.go
hugolib/config_test.go

index 8f36253313db2389d654bb309b322b1cc016ddce..dcc56486adfbe2be2528d18e6ea34d1a91652acd 100644 (file)
@@ -19,6 +19,8 @@ import (
        "github.com/gohugoio/hugo/helpers"
        "github.com/spf13/afero"
        "github.com/spf13/viper"
+       "io"
+       "strings"
 )
 
 // LoadConfig loads Hugo configuration into a new Viper and then adds
@@ -29,10 +31,10 @@ func LoadConfig(fs afero.Fs, relativeSourcePath, configFilename string) (*viper.
        if relativeSourcePath == "" {
                relativeSourcePath = "."
        }
-
+       configFilenames := strings.Split(configFilename, ",")
        v.AutomaticEnv()
        v.SetEnvPrefix("hugo")
-       v.SetConfigFile(configFilename)
+       v.SetConfigFile(configFilenames[0])
        // See https://github.com/spf13/viper/issues/73#issuecomment-126970794
        if relativeSourcePath == "" {
                v.AddConfigPath(".")
@@ -46,6 +48,16 @@ func LoadConfig(fs afero.Fs, relativeSourcePath, configFilename string) (*viper.
                }
                return nil, fmt.Errorf("Unable to locate Config file. Perhaps you need to create a new site.\n       Run `hugo help new` for details. (%s)\n", err)
        }
+       for _, configFile := range configFilenames[1:] {
+               var r io.Reader
+               var err error
+               if r, err = fs.Open(configFile); err != nil {
+                       return nil, fmt.Errorf("Unable to open Config file.\n (%s)\n", err)
+               }
+               if err = v.MergeConfig(r); err != nil {
+                       return nil, fmt.Errorf("Unable to parse/merge Config file (%s).\n (%s)\n", configFile, err)
+               }
+       }
 
        v.RegisterAlias("indexes", "taxonomies")
 
index 780e5c33d3c4324fed31e19debabb5b73b55d9f9..874416b9d0efc4dc1df90902cb5cbdafb7afcfdb 100644 (file)
@@ -41,3 +41,27 @@ func TestLoadConfig(t *testing.T) {
        // default
        assert.Equal(t, "layouts", cfg.GetString("layoutDir"))
 }
+func TestLoadMultiConfig(t *testing.T) {
+       t.Parallel()
+
+       // Add a random config variable for testing.
+       // side = page in Norwegian.
+       configContentBase := `
+       DontChange = "same"
+       PaginatePath = "side"
+       `
+       configContentSub := `
+       PaginatePath = "top"
+       `
+       mm := afero.NewMemMapFs()
+
+       writeToFs(t, mm, "base.toml", configContentBase)
+
+       writeToFs(t, mm, "override.toml", configContentSub)
+
+       cfg, err := LoadConfig(mm, "", "base.toml,override.toml")
+       require.NoError(t, err)
+
+       assert.Equal(t, "top", cfg.GetString("paginatePath"))
+       assert.Equal(t, "same", cfg.GetString("DontChange"))
+}