hugolib, i18n: Update tests with flat format and TOML files
authorAlbert Nigmatzianov <albertnigma@gmail.com>
Sat, 1 Apr 2017 20:36:07 +0000 (22:36 +0200)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Sun, 2 Apr 2017 16:43:32 +0000 (18:43 +0200)
hugolib/hugo_sites_build_test.go
i18n/i18n_test.go

index b5eac857c9a6b0c8d38a54aae3d8432afd0eb001..80f4d5cc48e27e2985769d45d07df9b7b2a9b786 100644 (file)
@@ -1050,8 +1050,8 @@ func createMultiTestSitesForConfig(t *testing.T, siteConfig testSiteConfig, conf
        if err := afero.WriteFile(mf,
                filepath.Join("i18n", "en.yaml"),
                []byte(`
-- id: hello
-  translation: "Hello"
+hello:
+  other: "Hello"
 `),
                0755); err != nil {
                t.Fatalf("Failed to write language file: %s", err)
@@ -1059,8 +1059,8 @@ func createMultiTestSitesForConfig(t *testing.T, siteConfig testSiteConfig, conf
        if err := afero.WriteFile(mf,
                filepath.Join("i18n", "fr.yaml"),
                []byte(`
-- id: hello
-  translation: "Bonjour"
+hello:
+  other: "Bonjour"
 `),
                0755); err != nil {
                t.Fatalf("Failed to write language file: %s", err)
index fd9c91b3ec11d47d791756f2cb174d3cdffc7f25..157c478d8187881012990f8c6b02b24baa7cd93d 100644 (file)
@@ -40,8 +40,8 @@ var i18nTests = []i18nTest{
        // All translations present
        {
                data: map[string][]byte{
-                       "en.yaml": []byte("- id: \"hello\"\n  translation: \"Hello, World!\""),
-                       "es.yaml": []byte("- id: \"hello\"\n  translation: \"¡Hola, Mundo!\""),
+                       "en.toml": []byte("[hello]\nother = \"Hello, World!\""),
+                       "es.toml": []byte("[hello]\nother = \"¡Hola, Mundo!\""),
                },
                args:         nil,
                lang:         "es",
@@ -52,8 +52,8 @@ var i18nTests = []i18nTest{
        // Translation missing in current language but present in default
        {
                data: map[string][]byte{
-                       "en.yaml": []byte("- id: \"hello\"\n  translation: \"Hello, World!\""),
-                       "es.yaml": []byte("- id: \"goodbye\"\n  translation: \"¡Adiós, Mundo!\""),
+                       "en.toml": []byte("[hello]\nother = \"Hello, World!\""),
+                       "es.toml": []byte("[goodbye]\nother = \"¡Adiós, Mundo!\""),
                },
                args:         nil,
                lang:         "es",
@@ -64,8 +64,8 @@ var i18nTests = []i18nTest{
        // Translation missing in default language but present in current
        {
                data: map[string][]byte{
-                       "en.yaml": []byte("- id: \"goodybe\"\n  translation: \"Goodbye, World!\""),
-                       "es.yaml": []byte("- id: \"hello\"\n  translation: \"¡Hola, Mundo!\""),
+                       "en.toml": []byte("[goodybe]\nother = \"Goodbye, World!\""),
+                       "es.toml": []byte("[hello]\nother = \"¡Hola, Mundo!\""),
                },
                args:         nil,
                lang:         "es",
@@ -76,8 +76,8 @@ var i18nTests = []i18nTest{
        // Translation missing in both default and current language
        {
                data: map[string][]byte{
-                       "en.yaml": []byte("- id: \"goodbye\"\n  translation: \"Goodbye, World!\""),
-                       "es.yaml": []byte("- id: \"goodbye\"\n  translation: \"¡Adiós, Mundo!\""),
+                       "en.toml": []byte("[goodbye]\nother = \"Goodbye, World!\""),
+                       "es.toml": []byte("[goodbye]\nother = \"¡Adiós, Mundo!\""),
                },
                args:         nil,
                lang:         "es",
@@ -88,7 +88,7 @@ var i18nTests = []i18nTest{
        // Default translation file missing or empty
        {
                data: map[string][]byte{
-                       "en.yaml": []byte(""),
+                       "en.toml": []byte(""),
                },
                args:         nil,
                lang:         "es",
@@ -99,8 +99,8 @@ var i18nTests = []i18nTest{
        // Context provided
        {
                data: map[string][]byte{
-                       "en.yaml": []byte("- id: \"wordCount\"\n  translation: \"Hello, {{.WordCount}} people!\""),
-                       "es.yaml": []byte("- id: \"wordCount\"\n  translation: \"¡Hola, {{.WordCount}} gente!\""),
+                       "en.toml": []byte("[wordCount]\nother = \"Hello, {{.WordCount}} people!\""),
+                       "es.toml": []byte("[wordCount]\nother = \"¡Hola, {{.WordCount}} gente!\""),
                },
                args: struct {
                        WordCount int
@@ -114,10 +114,10 @@ var i18nTests = []i18nTest{
        },
 }
 
-func doTestI18nTranslate(t *testing.T, data map[string][]byte, lang, id string, args interface{}, cfg config.Provider) string {
+func doTestI18nTranslate(t *testing.T, test i18nTest, cfg config.Provider) string {
        i18nBundle := bundle.New()
 
-       for file, content := range data {
+       for file, content := range test.data {
                err := i18nBundle.ParseTranslationFileBytes(file, content)
                if err != nil {
                        t.Errorf("Error parsing translation file: %s", err)
@@ -125,11 +125,8 @@ func doTestI18nTranslate(t *testing.T, data map[string][]byte, lang, id string,
        }
 
        translator := NewTranslator(i18nBundle, cfg, logger)
-
-       f := translator.Func(lang)
-
-       translated := f(id, args)
-
+       f := translator.Func(test.lang)
+       translated := f(test.id, test.args)
        return translated
 }
 
@@ -148,7 +145,7 @@ func TestI18nTranslate(t *testing.T) {
                        } else {
                                expected = test.expected
                        }
-                       actual = doTestI18nTranslate(t, test.data, test.lang, test.id, test.args, v)
+                       actual = doTestI18nTranslate(t, test, v)
                        require.Equal(t, expected, actual)
                }
        }