summaryrefslogtreecommitdiff
path: root/vendor/github.com/go-playground/universal-translator/import_export_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/github.com/go-playground/universal-translator/import_export_test.go')
-rw-r--r--vendor/github.com/go-playground/universal-translator/import_export_test.go789
1 files changed, 0 insertions, 789 deletions
diff --git a/vendor/github.com/go-playground/universal-translator/import_export_test.go b/vendor/github.com/go-playground/universal-translator/import_export_test.go
deleted file mode 100644
index e6a8505..0000000
--- a/vendor/github.com/go-playground/universal-translator/import_export_test.go
+++ /dev/null
@@ -1,789 +0,0 @@
-package ut
-
-import (
- "fmt"
- "path/filepath"
- "testing"
-
- "os"
-
- "github.com/go-playground/locales"
- "github.com/go-playground/locales/en"
- "github.com/go-playground/locales/nl"
-)
-
-// NOTES:
-// - Run "go test" to run tests
-// - Run "gocov test | gocov report" to report on test converage by file
-// - Run "gocov test | gocov annotate -" to report on all code and functions, those ,marked with "MISS" were never called
-//
-// or
-//
-// -- may be a good idea to change to output path to somewherelike /tmp
-// go test -coverprofile cover.out && go tool cover -html=cover.out -o cover.html
-//
-
-func TestExportImportBasic(t *testing.T) {
-
- e := en.New()
- uni := New(e, e)
- en, found := uni.GetTranslator("en") // or fallback if fails to find 'en'
- if !found {
- t.Fatalf("Expected '%t' Got '%t'", true, found)
- }
-
- translations := []struct {
- key interface{}
- trans string
- expected error
- expectedError bool
- override bool
- }{
- {
- key: "test_trans",
- trans: "Welcome {0}",
- expected: nil,
- },
- {
- key: -1,
- trans: "Welcome {0}",
- expected: nil,
- },
- {
- key: "test_trans2",
- trans: "{0} to the {1}.",
- expected: nil,
- },
- {
- key: "test_trans3",
- trans: "Welcome {0} to the {1}",
- expected: nil,
- },
- {
- key: "test_trans4",
- trans: "{0}{1}",
- expected: nil,
- },
- {
- key: "test_trans",
- trans: "{0}{1}",
- expected: &ErrConflictingTranslation{locale: en.Locale(), key: "test_trans", text: "{0}{1}"},
- expectedError: true,
- },
- {
- key: -1,
- trans: "{0}{1}",
- expected: &ErrConflictingTranslation{locale: en.Locale(), key: -1, text: "{0}{1}"},
- expectedError: true,
- },
- {
- key: "test_trans",
- trans: "Welcome {0} to the {1}.",
- expected: nil,
- override: true,
- },
- }
-
- for _, tt := range translations {
-
- err := en.Add(tt.key, tt.trans, tt.override)
- if err != tt.expected {
- if !tt.expectedError {
- t.Errorf("Expected '%s' Got '%s'", tt.expected, err)
- } else {
- if err.Error() != tt.expected.Error() {
- t.Errorf("Expected '%s' Got '%s'", tt.expected.Error(), err.Error())
- }
- }
- }
- }
-
- dirname := "testdata/translations"
- defer os.RemoveAll(dirname)
-
- err := uni.Export(FormatJSON, dirname)
- if err != nil {
- t.Fatalf("Expected '%v' Got '%s'", nil, err)
- }
-
- uni = New(e, e)
-
- err = uni.Import(FormatJSON, dirname)
- if err != nil {
- t.Fatalf("Expected '%v' Got '%s'", nil, err)
- }
-
- en, found = uni.GetTranslator("en") // or fallback if fails to find 'en'
- if !found {
- t.Fatalf("Expected '%t' Got '%t'", true, found)
- }
-
- tests := []struct {
- key interface{}
- params []string
- expected string
- expectedError bool
- }{
- {
- key: "test_trans",
- params: []string{"Joeybloggs", "The Test"},
- expected: "Welcome Joeybloggs to the The Test.",
- },
- {
- key: "test_trans2",
- params: []string{"Joeybloggs", "The Test"},
- expected: "Joeybloggs to the The Test.",
- },
- {
- key: "test_trans3",
- params: []string{"Joeybloggs", "The Test"},
- expected: "Welcome Joeybloggs to the The Test",
- },
- {
- key: "test_trans4",
- params: []string{"Joeybloggs", "The Test"},
- expected: "JoeybloggsThe Test",
- },
- // bad translation
- {
- key: "non-existant-key",
- params: []string{"Joeybloggs", "The Test"},
- expected: "",
- expectedError: true,
- },
- }
-
- for _, tt := range tests {
-
- s, err := en.T(tt.key, tt.params...)
- if s != tt.expected {
- if !tt.expectedError || (tt.expectedError && err != ErrUnknowTranslation) {
- t.Errorf("Expected '%s' Got '%s'", tt.expected, s)
- }
- }
- }
-}
-
-func TestExportImportCardinal(t *testing.T) {
-
- e := en.New()
- uni := New(e, e)
- en, found := uni.GetTranslator("en")
- if !found {
- t.Fatalf("Expected '%t' Got '%t'", true, found)
- }
-
- translations := []struct {
- key interface{}
- trans string
- rule locales.PluralRule
- expected error
- expectedError bool
- override bool
- }{
- // bad translation
- {
- key: "cardinal_test",
- trans: "You have a day left.",
- rule: locales.PluralRuleOne,
- expected: &ErrCardinalTranslation{text: fmt.Sprintf("error: parameter '%s' not found, may want to use 'Add' instead of 'AddCardinal'. locale: '%s' key: '%v' text: '%s'", paramZero, en.Locale(), "cardinal_test", "You have a day left.")},
- expectedError: true,
- },
- {
- key: "cardinal_test",
- trans: "You have {0} day",
- rule: locales.PluralRuleOne,
- expected: nil,
- },
- {
- key: "cardinal_test",
- trans: "You have {0} days left.",
- rule: locales.PluralRuleOther,
- expected: nil,
- },
- {
- key: "cardinal_test",
- trans: "You have {0} days left.",
- rule: locales.PluralRuleOther,
- expected: &ErrConflictingTranslation{locale: en.Locale(), key: "cardinal_test", rule: locales.PluralRuleOther, text: "You have {0} days left."},
- expectedError: true,
- },
- {
- key: "cardinal_test",
- trans: "You have {0} day left.",
- rule: locales.PluralRuleOne,
- expected: nil,
- override: true,
- },
- }
-
- for _, tt := range translations {
-
- err := en.AddCardinal(tt.key, tt.trans, tt.rule, tt.override)
- if err != tt.expected {
- if !tt.expectedError || err.Error() != tt.expected.Error() {
- t.Errorf("Expected '%s' Got '%s'", tt.expected, err)
- }
- }
- }
-
- dirname := "testdata/translations"
- defer os.RemoveAll(dirname)
-
- err := uni.Export(FormatJSON, dirname)
- if err != nil {
- t.Fatalf("Expected '%v' Got '%s'", nil, err)
- }
-
- uni = New(e, e)
-
- err = uni.Import(FormatJSON, dirname)
- if err != nil {
- t.Fatalf("Expected '%v' Got '%s'", nil, err)
- }
-
- en, found = uni.GetTranslator("en") // or fallback if fails to find 'en'
- if !found {
- t.Fatalf("Expected '%t' Got '%t'", true, found)
- }
-
- tests := []struct {
- key interface{}
- num float64
- digits uint64
- param string
- expected string
- expectedError bool
- }{
- {
- key: "cardinal_test",
- num: 1,
- digits: 0,
- param: string(en.FmtNumber(1, 0)),
- expected: "You have 1 day left.",
- },
- // bad translation key
- {
- key: "non-existant",
- num: 1,
- digits: 0,
- param: string(en.FmtNumber(1, 0)),
- expected: "",
- expectedError: true,
- },
- }
-
- for _, tt := range tests {
-
- s, err := en.C(tt.key, tt.num, tt.digits, tt.param)
- if err != nil {
- if !tt.expectedError && err != ErrUnknowTranslation {
- t.Errorf("Expected '<nil>' Got '%s'", err)
- }
- }
-
- if s != tt.expected {
- t.Errorf("Expected '%s' Got '%s'", tt.expected, s)
- }
- }
-}
-
-func TestExportImportOrdinal(t *testing.T) {
-
- e := en.New()
- uni := New(e, e)
- en, found := uni.GetTranslator("en")
- if !found {
- t.Fatalf("Expected '%t' Got '%t'", true, found)
- }
-
- translations := []struct {
- key interface{}
- trans string
- rule locales.PluralRule
- expected error
- expectedError bool
- override bool
- }{
- // bad translation
- {
- key: "day",
- trans: "st",
- rule: locales.PluralRuleOne,
- expected: &ErrOrdinalTranslation{text: fmt.Sprintf("error: parameter '%s' not found, may want to use 'Add' instead of 'AddOrdinal'. locale: '%s' key: '%v' text: '%s'", paramZero, en.Locale(), "day", "st")},
- expectedError: true,
- },
- {
- key: "day",
- trans: "{0}sfefewt",
- rule: locales.PluralRuleOne,
- expected: nil,
- },
- {
- key: "day",
- trans: "{0}nd",
- rule: locales.PluralRuleTwo,
- expected: nil,
- },
- {
- key: "day",
- trans: "{0}rd",
- rule: locales.PluralRuleFew,
- expected: nil,
- },
- {
- key: "day",
- trans: "{0}th",
- rule: locales.PluralRuleOther,
- expected: nil,
- },
- // bad translation
- {
- key: "day",
- trans: "{0}th",
- rule: locales.PluralRuleOther,
- expected: &ErrConflictingTranslation{locale: en.Locale(), key: "day", rule: locales.PluralRuleOther, text: "{0}th"},
- expectedError: true,
- },
- {
- key: "day",
- trans: "{0}st",
- rule: locales.PluralRuleOne,
- expected: nil,
- override: true,
- },
- }
-
- for _, tt := range translations {
-
- err := en.AddOrdinal(tt.key, tt.trans, tt.rule, tt.override)
- if err != tt.expected {
- if !tt.expectedError || err.Error() != tt.expected.Error() {
- t.Errorf("Expected '<nil>' Got '%s'", err)
- }
- }
- }
-
- dirname := "testdata/translations"
- defer os.RemoveAll(dirname)
-
- err := uni.Export(FormatJSON, dirname)
- if err != nil {
- t.Fatalf("Expected '%v' Got '%s'", nil, err)
- }
-
- uni = New(e, e)
-
- err = uni.Import(FormatJSON, dirname)
- if err != nil {
- t.Fatalf("Expected '%v' Got '%s'", nil, err)
- }
-
- en, found = uni.GetTranslator("en") // or fallback if fails to find 'en'
- if !found {
- t.Fatalf("Expected '%t' Got '%t'", true, found)
- }
-
- tests := []struct {
- key interface{}
- num float64
- digits uint64
- param string
- expected string
- expectedError bool
- }{
- {
- key: "day",
- num: 1,
- digits: 0,
- param: string(en.FmtNumber(1, 0)),
- expected: "1st",
- },
- {
- key: "day",
- num: 2,
- digits: 0,
- param: string(en.FmtNumber(2, 0)),
- expected: "2nd",
- },
- {
- key: "day",
- num: 3,
- digits: 0,
- param: string(en.FmtNumber(3, 0)),
- expected: "3rd",
- },
- {
- key: "day",
- num: 4,
- digits: 0,
- param: string(en.FmtNumber(4, 0)),
- expected: "4th",
- },
- {
- key: "day",
- num: 10258.43,
- digits: 0,
- param: string(en.FmtNumber(10258.43, 0)),
- expected: "10,258th",
- },
- // bad translation
- {
- key: "d-day",
- num: 10258.43,
- digits: 0,
- param: string(en.FmtNumber(10258.43, 0)),
- expected: "",
- expectedError: true,
- },
- }
-
- for _, tt := range tests {
-
- s, err := en.O(tt.key, tt.num, tt.digits, tt.param)
- if err != nil {
- if !tt.expectedError && err != ErrUnknowTranslation {
- t.Errorf("Expected '<nil>' Got '%s'", err)
- }
- }
-
- if s != tt.expected {
- t.Errorf("Expected '%s' Got '%s'", tt.expected, s)
- }
- }
-}
-
-func TestExportImportRange(t *testing.T) {
-
- n := nl.New()
- uni := New(n, n)
-
- // dutch
- nl, found := uni.GetTranslator("nl")
- if !found {
- t.Fatalf("Expected '%t' Got '%t'", true, found)
- }
-
- translations := []struct {
- key interface{}
- trans string
- rule locales.PluralRule
- expected error
- expectedError bool
- override bool
- }{
- // bad translation
- {
- key: "day",
- trans: "er -{1} dag vertrokken",
- rule: locales.PluralRuleOne,
- expected: &ErrRangeTranslation{text: fmt.Sprintf("error: parameter '%s' not found, are you sure you're adding a Range Translation? locale: '%s' key: '%s' text: '%s'", paramZero, nl.Locale(), "day", "er -{1} dag vertrokken")},
- expectedError: true,
- },
- // bad translation
- {
- key: "day",
- trans: "er {0}- dag vertrokken",
- rule: locales.PluralRuleOne,
- expected: &ErrRangeTranslation{text: fmt.Sprintf("error: parameter '%s' not found, a Range Translation requires two parameters. locale: '%s' key: '%s' text: '%s'", paramOne, nl.Locale(), "day", "er {0}- dag vertrokken")},
- expectedError: true,
- },
- {
- key: "day",
- trans: "er {0}-{1} dag",
- rule: locales.PluralRuleOne,
- expected: nil,
- },
- {
- key: "day",
- trans: "er zijn {0}-{1} dagen over",
- rule: locales.PluralRuleOther,
- expected: nil,
- },
- // bad translation
- {
- key: "day",
- trans: "er zijn {0}-{1} dagen over",
- rule: locales.PluralRuleOther,
- expected: &ErrConflictingTranslation{locale: nl.Locale(), key: "day", rule: locales.PluralRuleOther, text: "er zijn {0}-{1} dagen over"},
- expectedError: true,
- },
- {
- key: "day",
- trans: "er {0}-{1} dag vertrokken",
- rule: locales.PluralRuleOne,
- expected: nil,
- override: true,
- },
- }
-
- for _, tt := range translations {
-
- err := nl.AddRange(tt.key, tt.trans, tt.rule, tt.override)
- if err != tt.expected {
- if !tt.expectedError || err.Error() != tt.expected.Error() {
- t.Errorf("Expected '%#v' Got '%s'", tt.expected, err)
- }
- }
- }
-
- dirname := "testdata/translations"
- defer os.RemoveAll(dirname)
-
- err := uni.Export(FormatJSON, dirname)
- if err != nil {
- t.Fatalf("Expected '%v' Got '%s'", nil, err)
- }
-
- uni = New(n, n)
-
- err = uni.Import(FormatJSON, dirname)
- if err != nil {
- t.Fatalf("Expected '%v' Got '%s'", nil, err)
- }
-
- nl, found = uni.GetTranslator("nl") // or fallback if fails to find 'en'
- if !found {
- t.Fatalf("Expected '%t' Got '%t'", true, found)
- }
-
- tests := []struct {
- key interface{}
- num1 float64
- digits1 uint64
- num2 float64
- digits2 uint64
- param1 string
- param2 string
- expected string
- expectedError bool
- }{
- {
- key: "day",
- num1: 1,
- digits1: 0,
- num2: 2,
- digits2: 0,
- param1: string(nl.FmtNumber(1, 0)),
- param2: string(nl.FmtNumber(2, 0)),
- expected: "er zijn 1-2 dagen over",
- },
- {
- key: "day",
- num1: 0,
- digits1: 0,
- num2: 1,
- digits2: 0,
- param1: string(nl.FmtNumber(0, 0)),
- param2: string(nl.FmtNumber(1, 0)),
- expected: "er 0-1 dag vertrokken",
- },
- {
- key: "day",
- num1: 0,
- digits1: 0,
- num2: 2,
- digits2: 0,
- param1: string(nl.FmtNumber(0, 0)),
- param2: string(nl.FmtNumber(2, 0)),
- expected: "er zijn 0-2 dagen over",
- },
- // bad translations from here
- {
- key: "d-day",
- num1: 0,
- digits1: 0,
- num2: 2,
- digits2: 0,
- param1: string(nl.FmtNumber(0, 0)),
- param2: string(nl.FmtNumber(2, 0)),
- expected: "",
- expectedError: true,
- },
- }
-
- for _, tt := range tests {
-
- s, err := nl.R(tt.key, tt.num1, tt.digits1, tt.num2, tt.digits2, tt.param1, tt.param2)
- if err != nil {
- if !tt.expectedError && err != ErrUnknowTranslation {
- t.Errorf("Expected '<nil>' Got '%s'", err)
- }
- }
-
- if s != tt.expected {
- t.Errorf("Expected '%s' Got '%s'", tt.expected, s)
- }
- }
-}
-
-func TestImportRecursive(t *testing.T) {
-
- e := en.New()
- uni := New(e, e)
-
- dirname := "testdata/nested1"
- err := uni.Import(FormatJSON, dirname)
- if err != nil {
- t.Fatalf("Expected '%v' Got '%s'", nil, err)
- }
-
- en, found := uni.GetTranslator("en") // or fallback if fails to find 'en'
- if !found {
- t.Fatalf("Expected '%t' Got '%t'", true, found)
- }
-
- tests := []struct {
- key interface{}
- params []string
- expected string
- expectedError bool
- }{
- {
- key: "test_trans",
- params: []string{"Joeybloggs", "The Test"},
- expected: "Welcome Joeybloggs to the The Test.",
- },
- {
- key: "test_trans2",
- params: []string{"Joeybloggs", "The Test"},
- expected: "Joeybloggs to the The Test.",
- },
- {
- key: "test_trans3",
- params: []string{"Joeybloggs", "The Test"},
- expected: "Welcome Joeybloggs to the The Test",
- },
- {
- key: "test_trans4",
- params: []string{"Joeybloggs", "The Test"},
- expected: "JoeybloggsThe Test",
- },
- // bad translation
- {
- key: "non-existant-key",
- params: []string{"Joeybloggs", "The Test"},
- expected: "",
- expectedError: true,
- },
- }
-
- for _, tt := range tests {
-
- s, err := en.T(tt.key, tt.params...)
- if s != tt.expected {
- if !tt.expectedError || (tt.expectedError && err != ErrUnknowTranslation) {
- t.Errorf("Expected '%s' Got '%s'", tt.expected, s)
- }
- }
- }
-}
-
-func TestBadImport(t *testing.T) {
-
- // test non existant file
- e := en.New()
- uni := New(e, e)
-
- filename := "testdata/non-existant-file.json"
- expected := "stat testdata/non-existant-file.json: no such file or directory"
- err := uni.Import(FormatJSON, filename)
- if err == nil || err.Error() != expected {
- t.Fatalf("Expected '%s' Got '%s'", expected, err)
- }
-
- // test bad parameter basic translation
- filename = "testdata/bad-translation1.json"
- expected = "error: bad parameter syntax, missing parameter '{0}' in translation. locale: 'en' key: 'test_trans3' text: 'Welcome {lettersnotpermitted} to the {1}'"
- err = uni.Import(FormatJSON, filename)
- if err == nil || err.Error() != expected {
- t.Fatalf("Expected '%s' Got '%s'", expected, err)
- }
-
- // test missing bracket basic translation
- filename = "testdata/bad-translation2.json"
- expected = "error: missing bracket '{}', in translation. locale: 'en' key: 'test_trans3' text: 'Welcome {0 to the {1}'"
- err = uni.Import(FormatJSON, filename)
- if err == nil || err.Error() != expected {
- t.Fatalf("Expected '%s' Got '%s'", expected, err)
- }
-
- // test missing locale basic translation
- filename = "testdata/bad-translation3.json"
- expected = "error: locale 'nl' not registered."
- err = uni.Import(FormatJSON, filename)
- if err == nil || err.Error() != expected {
- t.Fatalf("Expected '%s' Got '%s'", expected, err)
- }
-
- // test bad plural definition
- filename = "testdata/bad-translation4.json"
- expected = "error: bad plural definition 'ut.translation{Locale:\"en\", Key:\"cardinal_test\", Translation:\"You have {0} day left.\", PluralType:\"NotAPluralType\", PluralRule:\"One\", OverrideExisting:false}'"
- err = uni.Import(FormatJSON, filename)
- if err == nil || err.Error() != expected {
- t.Fatalf("Expected '%s' Got '%s'", expected, err)
- }
-
- // test bad plural rule for locale
- filename = "testdata/bad-translation5.json"
- expected = "error: cardinal plural rule 'Many' does not exist for locale 'en' key: 'cardinal_test' text: 'You have {0} day left.'"
- err = uni.Import(FormatJSON, filename)
- if err == nil || err.Error() != expected {
- t.Fatalf("Expected '%s' Got '%s'", expected, err)
- }
-
- // test invalid JSON
- filename = "testdata/bad-translation6.json"
- expected = "invalid character ']' after object key:value pair"
- err = uni.Import(FormatJSON, filename)
- if err == nil || err.Error() != expected {
- t.Fatalf("Expected '%s' Got '%s'", expected, err)
- }
-
- // test bad io.Reader
- f, err := os.Open(filename)
- if err != nil {
- t.Fatalf("Expected '%v' Got '%s'", nil, err)
- }
- f.Close()
-
- expected = "read testdata/bad-translation6.json: bad file descriptor"
- err = uni.ImportByReader(FormatJSON, f)
- if err == nil || err.Error() != expected {
- t.Fatalf("Expected '%s' Got '%s'", expected, err)
- }
-}
-
-func TestBadExport(t *testing.T) {
-
- // test readonly directory
- e := en.New()
- uni := New(e, e)
-
- en, found := uni.GetTranslator("en") // or fallback if fails to find 'en'
- if !found {
- t.Fatalf("Expected '%t' Got '%t'", true, found)
- }
-
- dirname := "testdata/readonly"
- err := os.Mkdir(dirname, 0444)
- if err != nil {
- t.Fatalf("Expected '%v' Got '%s'", nil, err)
- }
- defer os.RemoveAll(dirname)
-
- en.Add("day", "this is a day", false)
-
- expected := "open testdata/readonly/en.json: permission denied"
- err = uni.Export(FormatJSON, dirname)
- if err == nil || err.Error() != expected {
- t.Fatalf("Expected '%s' Got '%s'", expected, err)
- }
-
- // test exporting into directory inside readonly directory
- expected = "stat testdata/readonly/inner: permission denied"
- err = uni.Export(FormatJSON, filepath.Join(dirname, "inner"))
- if err == nil || err.Error() != expected {
- t.Fatalf("Expected '%s' Got '%s'", expected, err)
- }
-}