forked from karlseguin/liquid
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathoutput_test.go
97 lines (81 loc) · 3.21 KB
/
output_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
package liquid
import (
"strconv"
"testing"
"github.com/karlseguin/gspec"
"github.com/syreclabs/liquid/core"
)
func TestOutputHandlesEmptyOutput(t *testing.T) {
spec := gspec.New(t)
output, err := newOutput(core.NewParser([]byte("{{}}")))
spec.Expect(output).ToBeNil()
spec.Expect(err).ToBeNil()
}
func TestOutputHandlesSpaceOnlyOutput(t *testing.T) {
spec := gspec.New(t)
output, err := newOutput(core.NewParser([]byte("{{ }}")))
spec.Expect(output).ToBeNil()
spec.Expect(err).ToBeNil()
}
func TestOutputExtractsASimpleStatic(t *testing.T) {
output, _ := newOutput(core.NewParser([]byte("{{ 'over 9000'}}")))
assertRender(t, output, nil, "over 9000")
}
func TestOutputExtractsAComplexStatic(t *testing.T) {
output, _ := newOutput(core.NewParser([]byte("{{'it\\'s over \\9000'}}")))
assertRender(t, output, nil, "it's over \\9000")
}
func TestOutputExtractsAStaticWithAnEndingQuote(t *testing.T) {
output, _ := newOutput(core.NewParser([]byte("{{'it\\''}}")))
assertRender(t, output, nil, "it'")
}
func TestOutputExtractionGivesErrorForUnclosedStatic(t *testing.T) {
spec := gspec.New(t)
output, err := newOutput(core.NewParser([]byte("{{ 'failure }}")))
spec.Expect(output).ToBeNil()
spec.Expect(err.Error()).ToEqual(`Invalid value, a single quote might be missing ("{{ 'failure }}" - line 1)`)
}
func TestOutputNoFiltersForStatic(t *testing.T) {
spec := gspec.New(t)
output, _ := newOutput(core.NewParser([]byte("{{'fun'}}")))
spec.Expect(len(output.(*Output).Filters)).ToEqual(0)
}
func TestOutputGeneratesErrorOnUnknownFilter(t *testing.T) {
spec := gspec.New(t)
_, err := newOutput(core.NewParser([]byte("{{'fun' | unknown }}")))
spec.Expect(err.Error()).ToEqual(`Unknown filter "unknown" ("{{'fun' | unknown }}" - line 1)`)
}
func TestOutputGeneratesErrorOnInvalidParameter(t *testing.T) {
spec := gspec.New(t)
_, err := newOutput(core.NewParser([]byte("{{'fun' | debug: 'missing }}")))
spec.Expect(err.Error()).ToEqual(`Invalid value, a single quote might be missing ("{{'fun' | debug: 'missing }}" - line 1)`)
}
func TestOutputWithASingleFilter(t *testing.T) {
output, _ := newOutput(core.NewParser([]byte("{{'fun' | debug }}")))
assertFilters(t, output, "debug(0)")
}
func TestOutputWithMultipleFilters(t *testing.T) {
output, _ := newOutput(core.NewParser([]byte("{{'fun' | debug | debug}}")))
assertFilters(t, output, "debug(0)", "debug(1)")
}
func TestOutputWithMultipleFiltersHavingParameters(t *testing.T) {
spec := gspec.New(t)
output, err := newOutput(core.NewParser([]byte("{{'fun' | debug:1,2 | debug:'test' | debug : 'test' , 5}}")))
spec.Expect(err).ToBeNil()
assertFilters(t, output, "debug(0, 1, 2)", "debug(1, test)", "debug(2, test, 5)")
}
func TestOutputWithAnEscapeParameter(t *testing.T) {
spec := gspec.New(t)
output, err := newOutput(core.NewParser([]byte("{{'fun' | debug: 'te\\'st'}}")))
spec.Expect(err).ToBeNil()
assertFilters(t, output, "debug(0, te'st)")
}
func assertFilters(t *testing.T, output core.Code, expected ...string) {
spec := gspec.New(t)
filters := output.(*Output).Filters
spec.Expect(len(filters)).ToEqual(len(expected))
for index, filter := range filters {
actual := string(filter(strconv.Itoa(index), nil).([]byte))
spec.Expect(actual).ToEqual(expected[index])
}
}