You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
ntool/nstr/textutil/textutil_test.go

148 lines
4.0 KiB
Go

package textutil_test
import (
"git.noahlan.cn/noahlan/ntool/nstr"
"git.noahlan.cn/noahlan/ntool/nstr/textutil"
"git.noahlan.cn/noahlan/ntool/ntest/assert"
"testing"
)
func TestReplaceVars(t *testing.T) {
tplVars := map[string]any{
"name": "inhere",
"key_01": "inhere",
"key-02": "inhere",
"info": map[string]any{"age": 230, "sex": "man"},
}
tests := []struct {
tplText string
want string
}{
{"hi inhere", "hi inhere"},
{"hi {{name}}", "hi inhere"},
{"hi {{ name}}", "hi inhere"},
{"hi {{name }}", "hi inhere"},
{"hi {{ name }}", "hi inhere"},
{"hi {{ key_01 }}", "hi inhere"},
{"hi {{ key-02 }}", "hi inhere"},
{"hi {{ info.age }}", "hi 230"},
}
for i, tt := range tests {
t.Run(nstr.JoinAny(" ", "case", i), func(t *testing.T) {
if got := textutil.ReplaceVars(tt.tplText, tplVars, ""); got != tt.want {
t.Errorf("ReplaceVars() = %v, want = %v", got, tt.want)
}
})
}
// custom format
assert.Equal(t, "hi inhere", textutil.ReplaceVars("hi {$name}", tplVars, "{$,}"))
assert.Equal(t, "hi inhere age is 230", textutil.ReplaceVars("hi $name age is $info.age", tplVars, "$,"))
assert.Equal(t, "hi {$name}", textutil.ReplaceVars("hi {$name}", nil, "{$,}"))
}
func TestNewFullReplacer(t *testing.T) {
vp := textutil.NewFullReplacer("")
tplVars := map[string]any{
"name": "inhere",
"info": map[string]any{"age": 230, "sex": "man"},
}
tpl := "hi, {{ name }}, {{ age | 23 }}"
str := vp.Render(tpl, nil)
assert.Eq(t, "hi, {{ name }}, 23", str)
str = vp.Render(tpl, tplVars)
assert.Eq(t, "hi, inhere, 23", str)
vp.OnNotFound(func(name string) (val string, ok bool) {
if name == "name" {
return "tom", true
}
return
})
str = vp.Render(tpl, nil)
assert.Eq(t, "hi, tom, 23", str)
}
func TestRenderSMap(t *testing.T) {
tplVars := map[string]string{
"name": "inhere",
"age": "234",
"key_01": "inhere",
"key-02": "inhere",
}
tests := []struct {
tplText string
want string
}{
{"hi inhere", "hi inhere"},
{"hi {{name}}", "hi inhere"},
{"hi {{ name}}", "hi inhere"},
{"hi {{name }}", "hi inhere"},
{"hi {{ name }}", "hi inhere"},
{"hi {{ key_01 }}", "hi inhere"},
{"hi {{ key-02 }}", "hi inhere"},
}
for i, tt := range tests {
t.Run(nstr.JoinAny(" ", "case", i), func(t *testing.T) {
if got := textutil.RenderSMap(tt.tplText, tplVars, ""); got != tt.want {
t.Errorf("RenderSMap() = %v, want = %v", got, tt.want)
}
})
}
// custom format
assert.Equal(t, "hi inhere", textutil.RenderSMap("hi {$name}", tplVars, "{$,}"))
assert.Equal(t, "hi inhere age is 234", textutil.RenderSMap("hi $name age is $age", tplVars, "$"))
assert.Equal(t, "hi inhere age is 234.", textutil.RenderSMap("hi $name age is $age.", tplVars, "$,"))
assert.Equal(t, "hi {$name}", textutil.RenderSMap("hi {$name}", nil, "{$,}"))
}
func TestVarReplacer_ParseVars(t *testing.T) {
vp := textutil.NewVarReplacer("")
str := "hi {{ name }}, age {{age}}, age {{age }}"
ss := vp.ParseVars(str)
assert.NotEmpty(t, ss)
assert.Len(t, ss, 2)
assert.Contains(t, ss, "name")
assert.Contains(t, ss, "age")
tplVars := map[string]any{
"name": "inhere",
"age": 234,
}
assert.Equal(t, "hi inhere, age 234, age 234", vp.Render(str, tplVars))
vp.DisableFlatten()
assert.Equal(t, "hi inhere, age 234, age 234", vp.Render(str, tplVars))
}
func TestIsMatchAll(t *testing.T) {
str := "hi inhere, age is 120"
assert.True(t, textutil.IsMatchAll(str, []string{"hi", "inhere"}))
assert.False(t, textutil.IsMatchAll(str, []string{"hi", "^inhere"}))
}
func TestParseInlineINI(t *testing.T) {
mp, err := textutil.ParseInlineINI("")
assert.NoErr(t, err)
assert.Empty(t, mp)
mp, err = textutil.ParseInlineINI("default=inhere")
assert.NoErr(t, err)
assert.NotEmpty(t, mp)
assert.Eq(t, "inhere", mp.Str("default"))
_, err = textutil.ParseInlineINI("string")
assert.ErrSubMsg(t, err, "parse inline config error: must")
_, err = textutil.ParseInlineINI("name=n;default=inhere", "name")
assert.ErrSubMsg(t, err, "parse inline config error: invalid key name")
}