Handle more edge cases, unit tests
This commit is contained in:
parent
57437f8d23
commit
cfa3bd35ae
|
@ -1,6 +1,7 @@
|
||||||
package templatestrings
|
package templatestrings
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
|
||||||
|
@ -18,32 +19,47 @@ func InitTemplateStrings(stringsDir string, fileExt string, defaultVariant strin
|
||||||
map[string]map[string]string{},
|
map[string]map[string]string{},
|
||||||
defaultVariant,
|
defaultVariant,
|
||||||
}
|
}
|
||||||
|
// Check directory
|
||||||
|
if stat, err := os.Stat(stringsDir); err != nil {
|
||||||
|
return nil, err
|
||||||
|
} else if !stat.IsDir() {
|
||||||
|
return nil, errors.New("specified directory is no dir")
|
||||||
|
}
|
||||||
// Load strings
|
// Load strings
|
||||||
variants := append(otherVariants, defaultVariant)
|
variants := append(otherVariants, defaultVariant)
|
||||||
for _, variant := range variants {
|
for _, variant := range variants {
|
||||||
|
// Check if variant is empty
|
||||||
|
if variant == "" {
|
||||||
|
return nil, errors.New("language variant needs to have a name")
|
||||||
|
}
|
||||||
|
// Check if variant already loaded
|
||||||
if _, ok := ts.templateStrings[variant]; ok {
|
if _, ok := ts.templateStrings[variant]; ok {
|
||||||
// Already loaded
|
continue
|
||||||
|
}
|
||||||
|
fb, err := os.ReadFile(filepath.Join(stringsDir, variant+fileExt))
|
||||||
|
if err != nil {
|
||||||
|
// Just ignore the file
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
variantStrings := map[string]string{}
|
variantStrings := map[string]string{}
|
||||||
f, err := os.Open(filepath.Join(stringsDir, variant+fileExt))
|
if err = yaml.Unmarshal(fb, variantStrings); err != nil {
|
||||||
if err != nil {
|
// Error loading YAML
|
||||||
if os.IsNotExist(err) {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
err = yaml.NewDecoder(f).Decode(variantStrings)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
ts.templateStrings[variant] = variantStrings
|
ts.templateStrings[variant] = variantStrings
|
||||||
}
|
}
|
||||||
|
// Checks
|
||||||
|
if len(ts.templateStrings) == 0 {
|
||||||
|
return nil, errors.New("no variants initialized")
|
||||||
|
}
|
||||||
|
if _, ok := ts.templateStrings[ts.defaultVariant]; !ok {
|
||||||
|
return nil, errors.New("default variant not loaded")
|
||||||
|
}
|
||||||
return ts, nil
|
return ts, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get a string
|
// Get a string
|
||||||
// input: lang, name or just name (uses default)
|
// input: language, name or just name (uses default language)
|
||||||
func (ts *TemplateStrings) GetTemplateStringVariant(input ...string) (result string) {
|
func (ts *TemplateStrings) GetTemplateStringVariant(input ...string) (result string) {
|
||||||
var lang, name string
|
var lang, name string
|
||||||
if l := len(input); l == 1 {
|
if l := len(input); l == 1 {
|
||||||
|
@ -55,7 +71,7 @@ func (ts *TemplateStrings) GetTemplateStringVariant(input ...string) (result str
|
||||||
lang = input[0]
|
lang = input[0]
|
||||||
name = input[1]
|
name = input[1]
|
||||||
} else {
|
} else {
|
||||||
// Wrong number of input strings
|
// Wrong number of input strings, return empty string
|
||||||
return ""
|
return ""
|
||||||
}
|
}
|
||||||
m, ok := ts.templateStrings[lang]
|
m, ok := ts.templateStrings[lang]
|
||||||
|
@ -69,7 +85,7 @@ func (ts *TemplateStrings) GetTemplateStringVariant(input ...string) (result str
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get a func to use for templates
|
// Get a function to use in templates
|
||||||
func (ts *TemplateStrings) GetTemplateStringVariantFunc() func(...string) string {
|
func (ts *TemplateStrings) GetTemplateStringVariantFunc() func(...string) string {
|
||||||
return func(s ...string) string {
|
return func(s ...string) string {
|
||||||
return ts.GetTemplateStringVariant(s...)
|
return ts.GetTemplateStringVariant(s...)
|
||||||
|
|
|
@ -0,0 +1,122 @@
|
||||||
|
package templatestrings
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestAll(t *testing.T) {
|
||||||
|
t.Run("Faulty initialization", func(t *testing.T) {
|
||||||
|
_, err := InitTemplateStrings("testdata", ".yaml", "en", "faulty")
|
||||||
|
if err == nil {
|
||||||
|
t.Error()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
t.Run("Missing dir", func(t *testing.T) {
|
||||||
|
_, err := InitTemplateStrings("testdata/x", ".yaml", "en")
|
||||||
|
if err == nil {
|
||||||
|
t.Error()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
t.Run("Missing file", func(t *testing.T) {
|
||||||
|
_, err := InitTemplateStrings("testdata", ".yaml", "en", "x")
|
||||||
|
if err != nil {
|
||||||
|
t.Error()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
t.Run("File as directory", func(t *testing.T) {
|
||||||
|
_, err := InitTemplateStrings("testdata/en.yaml", ".yaml", "en")
|
||||||
|
if err == nil {
|
||||||
|
t.Error()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
t.Run("Missing default variant", func(t *testing.T) {
|
||||||
|
_, err := InitTemplateStrings("testdata", ".yaml", "x", "en")
|
||||||
|
if err == nil {
|
||||||
|
t.Error()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
t.Run("No variants", func(t *testing.T) {
|
||||||
|
_, err := InitTemplateStrings("testdata", ".yaml", "x")
|
||||||
|
if err == nil {
|
||||||
|
t.Error()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
t.Run("Language twice", func(t *testing.T) {
|
||||||
|
_, err := InitTemplateStrings("testdata", ".yaml", "en", "en", "de")
|
||||||
|
if err != nil {
|
||||||
|
t.Error()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
t.Run("Empty language", func(t *testing.T) {
|
||||||
|
_, err := InitTemplateStrings("testdata", ".yaml", "")
|
||||||
|
if err == nil {
|
||||||
|
t.Error()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
t.Run("Wrong number of inputs", func(t *testing.T) {
|
||||||
|
ts, err := InitTemplateStrings("testdata", ".yaml", "en", "de")
|
||||||
|
if err != nil {
|
||||||
|
t.FailNow()
|
||||||
|
}
|
||||||
|
if ts.GetTemplateStringVariant("simple", "en", "x") != "" {
|
||||||
|
t.Error()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
t.Run("Default variant", func(t *testing.T) {
|
||||||
|
ts, err := InitTemplateStrings("testdata", ".yaml", "en", "de")
|
||||||
|
if err != nil {
|
||||||
|
t.FailNow()
|
||||||
|
}
|
||||||
|
if ts.GetTemplateStringVariant("simple") != "Simple" {
|
||||||
|
t.Error()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
t.Run("Specified variant", func(t *testing.T) {
|
||||||
|
ts, err := InitTemplateStrings("testdata", ".yaml", "en", "de")
|
||||||
|
if err != nil {
|
||||||
|
t.FailNow()
|
||||||
|
}
|
||||||
|
if ts.GetTemplateStringVariant("en", "simple") != "Simple" {
|
||||||
|
t.Error()
|
||||||
|
}
|
||||||
|
if ts.GetTemplateStringVariant("de", "simple") != "Einfach" {
|
||||||
|
t.Error()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
t.Run("Fallback to default variant", func(t *testing.T) {
|
||||||
|
ts, err := InitTemplateStrings("testdata", ".yaml", "en", "de")
|
||||||
|
if err != nil {
|
||||||
|
t.FailNow()
|
||||||
|
}
|
||||||
|
if ts.GetTemplateStringVariant("de", "fallback") != "Fallback" {
|
||||||
|
t.Error()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
t.Run("Missing variant", func(t *testing.T) {
|
||||||
|
ts, err := InitTemplateStrings("testdata", ".yaml", "en", "de")
|
||||||
|
if err != nil {
|
||||||
|
t.FailNow()
|
||||||
|
}
|
||||||
|
if ts.GetTemplateStringVariant("x", "simple") != "Simple" {
|
||||||
|
t.Error()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
t.Run("Missing string", func(t *testing.T) {
|
||||||
|
ts, err := InitTemplateStrings("testdata", ".yaml", "en", "de")
|
||||||
|
if err != nil {
|
||||||
|
t.FailNow()
|
||||||
|
}
|
||||||
|
if ts.GetTemplateStringVariant("x") != "" {
|
||||||
|
t.Error()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
t.Run("Template func", func(t *testing.T) {
|
||||||
|
ts, err := InitTemplateStrings("testdata", ".yaml", "en", "de")
|
||||||
|
if err != nil {
|
||||||
|
t.FailNow()
|
||||||
|
}
|
||||||
|
if ts.GetTemplateStringVariantFunc()("simple") != "Simple" {
|
||||||
|
t.Error()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
|
@ -0,0 +1 @@
|
||||||
|
simple: Einfach
|
|
@ -0,0 +1,2 @@
|
||||||
|
simple: Simple
|
||||||
|
fallback: Fallback
|
|
@ -0,0 +1 @@
|
||||||
|
hsjdfhksjdhfjshdf, iusdhfjshdkjfhs
|
Loading…
Reference in New Issue