Fix YAML loading of multilingual config
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Wed, 10 Aug 2016 20:46:02 +0000 (22:46 +0200)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Tue, 6 Sep 2016 15:32:20 +0000 (18:32 +0300)
And some other minor fixes from code review.

Updates #2309

helpers/url.go
hugolib/hugo_sites.go
hugolib/hugo_sites_test.go
hugolib/multilingual.go
hugolib/site.go

index 4d06fb042918596072956779cc08438c83fef2d0..1d87cf89f4d02138f79fb0e90c05467bfb9584fb 100644 (file)
@@ -183,12 +183,13 @@ func AbsURL(in string, addLanguage bool) string {
 }
 
 func getLanguagePrefix() string {
-       defaultLang := viper.GetString("DefaultContentLanguage")
-       defaultInSubDir := viper.GetBool("DefaultContentLanguageInSubdir")
-
        if !viper.GetBool("Multilingual") {
                return ""
        }
+
+       defaultLang := viper.GetString("DefaultContentLanguage")
+       defaultInSubDir := viper.GetBool("DefaultContentLanguageInSubdir")
+
        currentLang := viper.Get("CurrentContentLanguage").(*Language).Lang
        if currentLang == "" || (currentLang == defaultLang && !defaultInSubDir) {
                return ""
index 8e97e078386a98a735b27025d993535b2b0ad483..d05415d98b09192cdcc2f4159035d735187aa752 100644 (file)
@@ -385,9 +385,9 @@ func (h *HugoSites) setupTranslations(master *Site) {
        }
 }
 
-// preRender performs build tasks that needs to be done as late as possible.
+// preRender performs build tasks that need to be done as late as possible.
 // Shortcode handling is the main task in here.
-// TODO(bep) We need to look at the whole handler-chain construct witht he below in mind.
+// TODO(bep) We need to look at the whole handler-chain construct with he below in mind.
 func (h *HugoSites) preRender() error {
 
        for _, s := range h.Sites {
index 26a294d5edba96114a8e944a5b9b97cb573750a9..c5a226dc21162fbaa67430cfb2c44b5be4fc1429 100644 (file)
@@ -160,9 +160,22 @@ func assertFileContent(t *testing.T, filename string, defaultInSubDir bool, matc
        }
 }
 
+//
 func TestMultiSitesBuild(t *testing.T) {
+       for _, config := range []struct {
+               content string
+               suffix  string
+       }{
+               {multiSiteTomlConfig, "toml"},
+               {multiSiteYAMLConfig, "yml"},
+       } {
+               doTestMultiSitesBuild(t, config.content, config.suffix)
+       }
+}
+
+func doTestMultiSitesBuild(t *testing.T, configContent, configSuffix string) {
        testCommonResetState()
-       sites := createMultiTestSites(t, multiSiteTomlConfig)
+       sites := createMultiTestSitesForConfig(t, configContent, configSuffix)
 
        err := sites.Build(BuildCfg{})
 
@@ -598,7 +611,54 @@ title = "Bokmål"
 lag = "lag"
 `
 
+var multiSiteYAMLConfig = `
+DefaultExtension: "html"
+baseurl: "http://example.com/blog"
+DisableSitemap: false
+DisableRSS: false
+RSSUri: "index.xml"
+
+paginate: 1
+DefaultContentLanguage: "fr"
+
+permalinks:
+    other: "/somewhere/else/:filename"
+
+blackfriday:
+    angledQuotes: true
+
+Taxonomies:
+    tag: "tags"
+
+Languages:
+    en:
+        weight: 10
+        title: "English"
+        blackfriday:
+            angledQuotes: false
+    fr:
+        weight: 20
+        title: "Français"
+        Taxonomies:
+            plaque: "plaques"
+    nn:
+        weight: 30
+        title: "Nynorsk"
+        Taxonomies:
+            lag: "lag"
+    nb:
+        weight: 40
+        title: "Bokmål"
+        Taxonomies:
+            lag: "lag"
+
+`
+
 func createMultiTestSites(t *testing.T, tomlConfig string) *HugoSites {
+       return createMultiTestSitesForConfig(t, tomlConfig, "toml")
+}
+
+func createMultiTestSitesForConfig(t *testing.T, configContent, configSuffix string) *HugoSites {
 
        // Add some layouts
        if err := afero.WriteFile(hugofs.Source(),
@@ -760,8 +820,9 @@ lag:
 `)},
        }
 
-       writeSource(t, "multilangconfig.toml", tomlConfig)
-       if err := LoadGlobalConfig("", "multilangconfig.toml"); err != nil {
+       configFile := "multilangconfig." + configSuffix
+       writeSource(t, configFile, configContent)
+       if err := LoadGlobalConfig("", configFile); err != nil {
                t.Fatalf("Failed to load config: %s", err)
        }
 
index c59b3b649e3df2d1324b93f3de5db6fa244579d5..493a8e8a385022483f41123cd323fe8e8cc4172f 100644 (file)
@@ -83,10 +83,10 @@ func toSortedLanguages(l map[string]interface{}) (helpers.Languages, error) {
        i := 0
 
        for lang, langConf := range l {
-               langsMap, ok := langConf.(map[string]interface{})
+               langsMap, err := cast.ToStringMapE(langConf)
 
-               if !ok {
-                       return nil, fmt.Errorf("Language config is not a map: %v", langsMap)
+               if err != nil {
+                       return nil, fmt.Errorf("Language config is not a map: %T", langConf)
                }
 
                language := helpers.NewLanguage(lang)
index 8403a6af062c668ce425889a959071b77e1811d2..94c9efab77312e3df8752903737c4dec40a52dee 100644 (file)
@@ -777,7 +777,7 @@ func (s *Site) setupPrevNext() {
 }
 
 func (s *Site) render() (err error) {
-       // There are sadly some global template funcs etc. that needs the language information.
+       // There are sadly some global template funcs etc. that need the language information.
        viper.Set("Multilingual", s.multilingualEnabled())
        viper.Set("CurrentContentLanguage", s.Language)
        if err = tpl.SetTranslateLang(s.Language.Lang); err != nil {