| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197 |
- package fasttemplate
- import (
- "io"
- "testing"
- )
- func TestEmptyTemplate(t *testing.T) {
- tpl := New("", "[", "]")
- s := tpl.ExecuteString(map[string]interface{}{"foo": "bar", "aaa": "bbb"})
- if s != "" {
- t.Fatalf("unexpected string returned %q. Expected empty string", s)
- }
- }
- func TestEmptyTagStart(t *testing.T) {
- expectPanic(t, func() { NewTemplate("foobar", "", "]") })
- }
- func TestEmptyTagEnd(t *testing.T) {
- expectPanic(t, func() { NewTemplate("foobar", "[", "") })
- }
- func TestNoTags(t *testing.T) {
- template := "foobar"
- tpl := New(template, "[", "]")
- s := tpl.ExecuteString(map[string]interface{}{"foo": "bar", "aaa": "bbb"})
- if s != template {
- t.Fatalf("unexpected template value %q. Expected %q", s, template)
- }
- }
- func TestEmptyTagName(t *testing.T) {
- template := "foo[]bar"
- tpl := New(template, "[", "]")
- s := tpl.ExecuteString(map[string]interface{}{"": "111", "aaa": "bbb"})
- result := "foo111bar"
- if s != result {
- t.Fatalf("unexpected template value %q. Expected %q", s, result)
- }
- }
- func TestOnlyTag(t *testing.T) {
- template := "[foo]"
- tpl := New(template, "[", "]")
- s := tpl.ExecuteString(map[string]interface{}{"foo": "111", "aaa": "bbb"})
- result := "111"
- if s != result {
- t.Fatalf("unexpected template value %q. Expected %q", s, result)
- }
- }
- func TestStartWithTag(t *testing.T) {
- template := "[foo]barbaz"
- tpl := New(template, "[", "]")
- s := tpl.ExecuteString(map[string]interface{}{"foo": "111", "aaa": "bbb"})
- result := "111barbaz"
- if s != result {
- t.Fatalf("unexpected template value %q. Expected %q", s, result)
- }
- }
- func TestEndWithTag(t *testing.T) {
- template := "foobar[foo]"
- tpl := New(template, "[", "]")
- s := tpl.ExecuteString(map[string]interface{}{"foo": "111", "aaa": "bbb"})
- result := "foobar111"
- if s != result {
- t.Fatalf("unexpected template value %q. Expected %q", s, result)
- }
- }
- func TestDuplicateTags(t *testing.T) {
- template := "[foo]bar[foo][foo]baz"
- tpl := New(template, "[", "]")
- s := tpl.ExecuteString(map[string]interface{}{"foo": "111", "aaa": "bbb"})
- result := "111bar111111baz"
- if s != result {
- t.Fatalf("unexpected template value %q. Expected %q", s, result)
- }
- }
- func TestMultipleTags(t *testing.T) {
- template := "foo[foo]aa[aaa]ccc"
- tpl := New(template, "[", "]")
- s := tpl.ExecuteString(map[string]interface{}{"foo": "111", "aaa": "bbb"})
- result := "foo111aabbbccc"
- if s != result {
- t.Fatalf("unexpected template value %q. Expected %q", s, result)
- }
- }
- func TestLongDelimiter(t *testing.T) {
- template := "foo{{{foo}}}bar"
- tpl := New(template, "{{{", "}}}")
- s := tpl.ExecuteString(map[string]interface{}{"foo": "111", "aaa": "bbb"})
- result := "foo111bar"
- if s != result {
- t.Fatalf("unexpected template value %q. Expected %q", s, result)
- }
- }
- func TestIdenticalDelimiter(t *testing.T) {
- template := "foo@foo@foo@aaa@"
- tpl := New(template, "@", "@")
- s := tpl.ExecuteString(map[string]interface{}{"foo": "111", "aaa": "bbb"})
- result := "foo111foobbb"
- if s != result {
- t.Fatalf("unexpected template value %q. Expected %q", s, result)
- }
- }
- func TestDlimitersWithDistinctSize(t *testing.T) {
- template := "foo<?phpaaa?>bar<?phpzzz?>"
- tpl := New(template, "<?php", "?>")
- s := tpl.ExecuteString(map[string]interface{}{"zzz": "111", "aaa": "bbb"})
- result := "foobbbbar111"
- if s != result {
- t.Fatalf("unexpected template value %q. Expected %q", s, result)
- }
- }
- func TestEmptyValue(t *testing.T) {
- template := "foobar[foo]"
- tpl := New(template, "[", "]")
- s := tpl.ExecuteString(map[string]interface{}{"foo": "", "aaa": "bbb"})
- result := "foobar"
- if s != result {
- t.Fatalf("unexpected template value %q. Expected %q", s, result)
- }
- }
- func TestNoValue(t *testing.T) {
- template := "foobar[foo]x[aaa]"
- tpl := New(template, "[", "]")
- s := tpl.ExecuteString(map[string]interface{}{"aaa": "bbb"})
- result := "foobarxbbb"
- if s != result {
- t.Fatalf("unexpected template value %q. Expected %q", s, result)
- }
- }
- func TestNoEndDelimiter(t *testing.T) {
- template := "foobar[foo"
- _, err := NewTemplate(template, "[", "]")
- if err == nil {
- t.Fatalf("expected non-nil error. got nil")
- }
- expectPanic(t, func() { New(template, "[", "]") })
- }
- func TestUnsupportedValue(t *testing.T) {
- template := "foobar[foo]"
- tpl := New(template, "[", "]")
- expectPanic(t, func() {
- tpl.ExecuteString(map[string]interface{}{"foo": 123, "aaa": "bbb"})
- })
- }
- func TestMixedValues(t *testing.T) {
- template := "foo[foo]bar[bar]baz[baz]"
- tpl := New(template, "[", "]")
- s := tpl.ExecuteString(map[string]interface{}{
- "foo": "111",
- "bar": []byte("bbb"),
- "baz": TagFunc(func(w io.Writer, tag string) (int, error) { return w.Write([]byte(tag)) }),
- })
- result := "foo111barbbbbazbaz"
- if s != result {
- t.Fatalf("unexpected template value %q. Expected %q", s, result)
- }
- }
- func expectPanic(t *testing.T, f func()) {
- defer func() {
- if r := recover(); r == nil {
- t.Fatalf("missing panic")
- }
- }()
- f()
- }
|