diff options
Diffstat (limited to 'vendor/github.com/go-playground/universal-translator/translator_test.go')
-rw-r--r-- | vendor/github.com/go-playground/universal-translator/translator_test.go | 858 |
1 files changed, 0 insertions, 858 deletions
diff --git a/vendor/github.com/go-playground/universal-translator/translator_test.go b/vendor/github.com/go-playground/universal-translator/translator_test.go deleted file mode 100644 index 837d2d3..0000000 --- a/vendor/github.com/go-playground/universal-translator/translator_test.go +++ /dev/null @@ -1,858 +0,0 @@ -package ut - -import ( - "fmt" - "testing" - - "github.com/go-playground/locales" - "github.com/go-playground/locales/en" - "github.com/go-playground/locales/en_CA" - "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 TestBasicTranslation(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()) - } - } - } - } - - 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 && err != ErrUnknowTranslation { - t.Errorf("Expected '%s' Got '%s'", tt.expected, s) - } - } - } -} - -func TestCardinalTranslation(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, - }, - // bad translation - { - key: "cardinal_test", - trans: "You have a day left few.", - rule: locales.PluralRuleFew, - expected: &ErrCardinalTranslation{text: fmt.Sprintf("error: cardinal plural rule '%s' does not exist for locale '%s' key: '%s' text: '%s'", locales.PluralRuleFew, en.Locale(), "cardinal_test", "You have a day left few.")}, - 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 '<nil>' Got '%s'", err) - } - } - } - - 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 TestOrdinalTranslation(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, - }, - // bad translation - { - key: "day", - trans: "st", - rule: locales.PluralRuleMany, - expected: &ErrOrdinalTranslation{text: fmt.Sprintf("error: ordinal plural rule '%s' does not exist for locale '%s' key: '%s' text: '%s'", locales.PluralRuleMany, en.Locale(), "day", "st")}, - expectedError: true, - }, - { - key: "day", - trans: "{0}st", - 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) - } - } - } - - 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 TestRangeTranslation(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.PluralRuleMany, - expected: &ErrRangeTranslation{text: fmt.Sprintf("error: range plural rule '%s' does not exist for locale '%s' key: '%s' text: '%s'", locales.PluralRuleMany, nl.Locale(), "day", "er {0}- 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) - } - } - } - - 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 TestFallbackTranslator(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) - } - - if en.Locale() != "en" { - t.Errorf("Expected '%s' Got '%s'", "en", en.Locale()) - } - - fallback, _ := uni.GetTranslator("nl") - if fallback.Locale() != "en" { - t.Errorf("Expected '%s' Got '%s'", "en", fallback.Locale()) - } - - en, _ = uni.FindTranslator("nl", "en") - if en.Locale() != "en" { - t.Errorf("Expected '%s' Got '%s'", "en", en.Locale()) - } - - fallback, _ = uni.FindTranslator("nl") - if fallback.Locale() != "en" { - t.Errorf("Expected '%s' Got '%s'", "en", fallback.Locale()) - } -} - -func TestAddTranslator(t *testing.T) { - - e := en.New() - n := nl.New() - uni := New(e, n) - - tests := []struct { - trans locales.Translator - expected error - expectedError bool - override bool - }{ - { - trans: en_CA.New(), - expected: nil, - override: false, - }, - { - trans: n, - expected: &ErrExistingTranslator{locale: n.Locale()}, - expectedError: true, - override: false, - }, - { - trans: e, - expected: &ErrExistingTranslator{locale: e.Locale()}, - expectedError: true, - override: false, - }, - { - trans: e, - expected: nil, - override: true, - }, - } - - for _, tt := range tests { - - err := uni.AddTranslator(tt.trans, tt.override) - if err != tt.expected { - if !tt.expectedError || err.Error() != tt.expected.Error() { - t.Errorf("Expected '%s' Got '%s'", tt.expected, err) - } - } - } -} - -func TestVerifyTranslations(t *testing.T) { - - n := nl.New() - // dutch - uni := New(n, n) - - loc, _ := uni.GetTranslator("nl") - if loc.Locale() != "nl" { - t.Errorf("Expected '%s' Got '%s'", "nl", loc.Locale()) - } - - // cardinal checks - - err := loc.AddCardinal("day", "je {0} dag hebben verlaten", locales.PluralRuleOne, false) - if err != nil { - t.Fatalf("Expected '<nil>' Got '%s'", err) - } - - // fail cardinal rules - expected := &ErrMissingPluralTranslation{locale: loc.Locale(), translationType: "plural", rule: locales.PluralRuleOther, key: "day"} - err = loc.VerifyTranslations() - if err == nil || err.Error() != expected.Error() { - t.Errorf("Expected '%s' Got '%s'", expected, err) - } - - // success cardinal - err = loc.AddCardinal("day", "je {0} dagen hebben verlaten", locales.PluralRuleOther, false) - if err != nil { - t.Fatalf("Expected '<nil>' Got '%s'", err) - } - - err = loc.VerifyTranslations() - if err != nil { - t.Fatalf("Expected '<nil>' Got '%s'", err) - } - - // range checks - err = loc.AddRange("day", "je {0}-{1} dagen hebben verlaten", locales.PluralRuleOther, false) - if err != nil { - t.Fatalf("Expected '<nil>' Got '%s'", err) - } - - // fail range rules - expected = &ErrMissingPluralTranslation{locale: loc.Locale(), translationType: "range", rule: locales.PluralRuleOne, key: "day"} - err = loc.VerifyTranslations() - if err == nil || err.Error() != expected.Error() { - t.Errorf("Expected '%s' Got '%s'", expected, err) - } - - // success range - err = loc.AddRange("day", "je {0}-{1} dag hebben verlaten", locales.PluralRuleOne, false) - if err != nil { - t.Fatalf("Expected '<nil>' Got '%s'", err) - } - - err = loc.VerifyTranslations() - if err != nil { - t.Fatalf("Expected '<nil>' Got '%s'", err) - } - - // ok so 'nl' aka dutch, ony has one plural rule for ordinals, so going to switch to english from here which has 4 - - err = uni.AddTranslator(en.New(), false) - if err != nil { - t.Fatalf("Expected '<nil>' Got '%s'", err) - } - - loc, _ = uni.GetTranslator("en") - if loc.Locale() != "en" { - t.Errorf("Expected '%s' Got '%s'", "en", loc.Locale()) - } - - // ordinal checks - - err = loc.AddOrdinal("day", "{0}st", locales.PluralRuleOne, false) - if err != nil { - t.Fatalf("Expected '<nil>' Got '%s'", err) - } - - err = loc.AddOrdinal("day", "{0}rd", locales.PluralRuleFew, false) - if err != nil { - t.Fatalf("Expected '<nil>' Got '%s'", err) - } - - err = loc.AddOrdinal("day", "{0}th", locales.PluralRuleOther, false) - if err != nil { - t.Fatalf("Expected '<nil>' Got '%s'", err) - } - - // fail ordinal rules - expected = &ErrMissingPluralTranslation{locale: loc.Locale(), translationType: "ordinal", rule: locales.PluralRuleTwo, key: "day"} - err = loc.VerifyTranslations() - if err == nil || err.Error() != expected.Error() { - t.Errorf("Expected '%s' Got '%s'", expected, err) - } - - // success ordinal - - err = loc.AddOrdinal("day", "{0}nd", locales.PluralRuleTwo, false) - if err != nil { - t.Fatalf("Expected '<nil>' Got '%s'", err) - } - - err = loc.VerifyTranslations() - if err != nil { - t.Fatalf("Expected '<nil>' Got '%s'", err) - } -} - -func TestVerifyTranslationsWithNonStringKeys(t *testing.T) { - - n := nl.New() - // dutch - uni := New(n, n) - - loc, _ := uni.GetTranslator("nl") - if loc.Locale() != "nl" { - t.Errorf("Expected '%s' Got '%s'", "nl", loc.Locale()) - } - - // cardinal checks - - err := loc.AddCardinal(-1, "je {0} dag hebben verlaten", locales.PluralRuleOne, false) - if err != nil { - t.Fatalf("Expected '<nil>' Got '%s'", err) - } - - // fail cardinal rules - expected := &ErrMissingPluralTranslation{locale: loc.Locale(), translationType: "plural", rule: locales.PluralRuleOther, key: -1} - err = loc.VerifyTranslations() - if err == nil || err.Error() != expected.Error() { - t.Errorf("Expected '%s' Got '%s'", expected, err) - } -} - -func TestGetFallback(t *testing.T) { - - // dutch - n := nl.New() - e := en.New() - - uni := New(e, n) - - trans := uni.GetFallback() - - expected := "en" - - if trans.Locale() != expected { - t.Errorf("Expected '%s' Got '%s'", expected, trans.Locale()) - } -} - -func TestVerifyUTTranslations(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 - }{ - { - key: "day", - trans: "{0}st", - 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, - }, - // intentionally leaving out plural other - // { - // key: "day", - // trans: "{0}th", - // rule: locales.PluralRuleOther, - // expected: nil, - // }, - } - - 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) - } - } - } - - expected := "error: missing 'ordinal' plural rule 'Other' for translation with key 'day' and locale 'en'" - err := uni.VerifyTranslations() - if err == nil || err.Error() != expected { - t.Fatalf("Expected '%s' Got '%s'", expected, err) - } - - err = en.AddOrdinal("day", "{0}th", locales.PluralRuleOther, false) - if err != nil { - t.Fatalf("Expected '%v' Got '%s'", nil, err) - } - - err = uni.VerifyTranslations() - if err != nil { - t.Fatalf("Expected '%v' Got '%s'", nil, err) - } -} |