wordify_liquid 2.5.1
Sign up to get free protection for your applications and to get access to all the features.
- data/History.md +75 -0
- data/MIT-LICENSE +20 -0
- data/README.md +44 -0
- data/lib/extras/liquid_view.rb +51 -0
- data/lib/liquid.rb +68 -0
- data/lib/liquid/block.rb +115 -0
- data/lib/liquid/condition.rb +120 -0
- data/lib/liquid/context.rb +259 -0
- data/lib/liquid/document.rb +17 -0
- data/lib/liquid/drop.rb +61 -0
- data/lib/liquid/errors.rb +11 -0
- data/lib/liquid/extensions.rb +62 -0
- data/lib/liquid/file_system.rb +62 -0
- data/lib/liquid/htmltags.rb +74 -0
- data/lib/liquid/interrupts.rb +17 -0
- data/lib/liquid/module_ex.rb +62 -0
- data/lib/liquid/standardfilters.rb +245 -0
- data/lib/liquid/strainer.rb +53 -0
- data/lib/liquid/tag.rb +26 -0
- data/lib/liquid/tags/assign.rb +33 -0
- data/lib/liquid/tags/break.rb +21 -0
- data/lib/liquid/tags/capture.rb +35 -0
- data/lib/liquid/tags/case.rb +79 -0
- data/lib/liquid/tags/comment.rb +9 -0
- data/lib/liquid/tags/continue.rb +21 -0
- data/lib/liquid/tags/cycle.rb +59 -0
- data/lib/liquid/tags/decrement.rb +39 -0
- data/lib/liquid/tags/for.rb +142 -0
- data/lib/liquid/tags/if.rb +79 -0
- data/lib/liquid/tags/ifchanged.rb +20 -0
- data/lib/liquid/tags/include.rb +65 -0
- data/lib/liquid/tags/increment.rb +35 -0
- data/lib/liquid/tags/raw.rb +21 -0
- data/lib/liquid/tags/unless.rb +33 -0
- data/lib/liquid/template.rb +150 -0
- data/lib/liquid/utils.rb +31 -0
- data/lib/liquid/variable.rb +57 -0
- data/lib/wordify_liquid.rb +1 -0
- data/test/liquid/assign_test.rb +21 -0
- data/test/liquid/block_test.rb +58 -0
- data/test/liquid/capture_test.rb +40 -0
- data/test/liquid/condition_test.rb +127 -0
- data/test/liquid/context_test.rb +478 -0
- data/test/liquid/drop_test.rb +169 -0
- data/test/liquid/error_handling_test.rb +81 -0
- data/test/liquid/file_system_test.rb +29 -0
- data/test/liquid/filter_test.rb +125 -0
- data/test/liquid/module_ex_test.rb +87 -0
- data/test/liquid/output_test.rb +116 -0
- data/test/liquid/parsing_quirks_test.rb +52 -0
- data/test/liquid/regexp_test.rb +44 -0
- data/test/liquid/security_test.rb +64 -0
- data/test/liquid/standard_filter_test.rb +195 -0
- data/test/liquid/strainer_test.rb +52 -0
- data/test/liquid/tags/break_tag_test.rb +16 -0
- data/test/liquid/tags/continue_tag_test.rb +16 -0
- data/test/liquid/tags/for_tag_test.rb +284 -0
- data/test/liquid/tags/html_tag_test.rb +63 -0
- data/test/liquid/tags/if_else_tag_test.rb +160 -0
- data/test/liquid/tags/include_tag_test.rb +139 -0
- data/test/liquid/tags/increment_tag_test.rb +24 -0
- data/test/liquid/tags/raw_tag_test.rb +15 -0
- data/test/liquid/tags/standard_tag_test.rb +295 -0
- data/test/liquid/tags/statements_test.rb +134 -0
- data/test/liquid/tags/unless_else_tag_test.rb +26 -0
- data/test/liquid/template_test.rb +74 -0
- data/test/liquid/variable_test.rb +180 -0
- data/test/test_helper.rb +29 -0
- metadata +145 -0
@@ -0,0 +1,134 @@
|
|
1
|
+
require 'test_helper'
|
2
|
+
|
3
|
+
class StatementsTest < Test::Unit::TestCase
|
4
|
+
include Liquid
|
5
|
+
|
6
|
+
def test_true_eql_true
|
7
|
+
text = %| {% if true == true %} true {% else %} false {% endif %} |
|
8
|
+
expected = %| true |
|
9
|
+
assert_equal expected, Template.parse(text).render
|
10
|
+
end
|
11
|
+
|
12
|
+
def test_true_not_eql_true
|
13
|
+
text = %| {% if true != true %} true {% else %} false {% endif %} |
|
14
|
+
expected = %| false |
|
15
|
+
assert_equal expected, Template.parse(text).render
|
16
|
+
end
|
17
|
+
|
18
|
+
def test_true_lq_true
|
19
|
+
text = %| {% if 0 > 0 %} true {% else %} false {% endif %} |
|
20
|
+
expected = %| false |
|
21
|
+
assert_equal expected, Template.parse(text).render
|
22
|
+
end
|
23
|
+
|
24
|
+
def test_one_lq_zero
|
25
|
+
text = %| {% if 1 > 0 %} true {% else %} false {% endif %} |
|
26
|
+
expected = %| true |
|
27
|
+
assert_equal expected, Template.parse(text).render
|
28
|
+
end
|
29
|
+
|
30
|
+
def test_zero_lq_one
|
31
|
+
text = %| {% if 0 < 1 %} true {% else %} false {% endif %} |
|
32
|
+
expected = %| true |
|
33
|
+
assert_equal expected, Template.parse(text).render
|
34
|
+
end
|
35
|
+
|
36
|
+
def test_zero_lq_or_equal_one
|
37
|
+
text = %| {% if 0 <= 0 %} true {% else %} false {% endif %} |
|
38
|
+
expected = %| true |
|
39
|
+
assert_equal expected, Template.parse(text).render
|
40
|
+
end
|
41
|
+
|
42
|
+
def test_zero_lq_or_equal_one_involving_nil
|
43
|
+
text = %| {% if null <= 0 %} true {% else %} false {% endif %} |
|
44
|
+
expected = %| false |
|
45
|
+
assert_equal expected, Template.parse(text).render
|
46
|
+
|
47
|
+
|
48
|
+
text = %| {% if 0 <= null %} true {% else %} false {% endif %} |
|
49
|
+
expected = %| false |
|
50
|
+
assert_equal expected, Template.parse(text).render
|
51
|
+
end
|
52
|
+
|
53
|
+
def test_zero_lqq_or_equal_one
|
54
|
+
text = %| {% if 0 >= 0 %} true {% else %} false {% endif %} |
|
55
|
+
expected = %| true |
|
56
|
+
assert_equal expected, Template.parse(text).render
|
57
|
+
end
|
58
|
+
|
59
|
+
def test_strings
|
60
|
+
text = %| {% if 'test' == 'test' %} true {% else %} false {% endif %} |
|
61
|
+
expected = %| true |
|
62
|
+
assert_equal expected, Template.parse(text).render
|
63
|
+
end
|
64
|
+
|
65
|
+
def test_strings_not_equal
|
66
|
+
text = %| {% if 'test' != 'test' %} true {% else %} false {% endif %} |
|
67
|
+
expected = %| false |
|
68
|
+
assert_equal expected, Template.parse(text).render
|
69
|
+
end
|
70
|
+
|
71
|
+
def test_var_strings_equal
|
72
|
+
text = %| {% if var == "hello there!" %} true {% else %} false {% endif %} |
|
73
|
+
expected = %| true |
|
74
|
+
assert_equal expected, Template.parse(text).render('var' => 'hello there!')
|
75
|
+
end
|
76
|
+
|
77
|
+
def test_var_strings_are_not_equal
|
78
|
+
text = %| {% if "hello there!" == var %} true {% else %} false {% endif %} |
|
79
|
+
expected = %| true |
|
80
|
+
assert_equal expected, Template.parse(text).render('var' => 'hello there!')
|
81
|
+
end
|
82
|
+
|
83
|
+
def test_var_and_long_string_are_equal
|
84
|
+
text = %| {% if var == 'hello there!' %} true {% else %} false {% endif %} |
|
85
|
+
expected = %| true |
|
86
|
+
assert_equal expected, Template.parse(text).render('var' => 'hello there!')
|
87
|
+
end
|
88
|
+
|
89
|
+
|
90
|
+
def test_var_and_long_string_are_equal_backwards
|
91
|
+
text = %| {% if 'hello there!' == var %} true {% else %} false {% endif %} |
|
92
|
+
expected = %| true |
|
93
|
+
assert_equal expected, Template.parse(text).render('var' => 'hello there!')
|
94
|
+
end
|
95
|
+
|
96
|
+
#def test_is_nil
|
97
|
+
# text = %| {% if var != nil %} true {% else %} false {% end %} |
|
98
|
+
# @template.assigns = { 'var' => 'hello there!'}
|
99
|
+
# expected = %| true |
|
100
|
+
# assert_equal expected, @template.parse(text)
|
101
|
+
#end
|
102
|
+
|
103
|
+
def test_is_collection_empty
|
104
|
+
text = %| {% if array == empty %} true {% else %} false {% endif %} |
|
105
|
+
expected = %| true |
|
106
|
+
assert_equal expected, Template.parse(text).render('array' => [])
|
107
|
+
end
|
108
|
+
|
109
|
+
def test_is_not_collection_empty
|
110
|
+
text = %| {% if array == empty %} true {% else %} false {% endif %} |
|
111
|
+
expected = %| false |
|
112
|
+
assert_equal expected, Template.parse(text).render('array' => [1,2,3])
|
113
|
+
end
|
114
|
+
|
115
|
+
def test_nil
|
116
|
+
text = %| {% if var == nil %} true {% else %} false {% endif %} |
|
117
|
+
expected = %| true |
|
118
|
+
assert_equal expected, Template.parse(text).render('var' => nil)
|
119
|
+
|
120
|
+
text = %| {% if var == null %} true {% else %} false {% endif %} |
|
121
|
+
expected = %| true |
|
122
|
+
assert_equal expected, Template.parse(text).render('var' => nil)
|
123
|
+
end
|
124
|
+
|
125
|
+
def test_not_nil
|
126
|
+
text = %| {% if var != nil %} true {% else %} false {% endif %} |
|
127
|
+
expected = %| true |
|
128
|
+
assert_equal expected, Template.parse(text).render('var' => 1 )
|
129
|
+
|
130
|
+
text = %| {% if var != null %} true {% else %} false {% endif %} |
|
131
|
+
expected = %| true |
|
132
|
+
assert_equal expected, Template.parse(text).render('var' => 1 )
|
133
|
+
end
|
134
|
+
end # StatementsTest
|
@@ -0,0 +1,26 @@
|
|
1
|
+
require 'test_helper'
|
2
|
+
|
3
|
+
class UnlessElseTagTest < Test::Unit::TestCase
|
4
|
+
include Liquid
|
5
|
+
|
6
|
+
def test_unless
|
7
|
+
assert_template_result(' ',' {% unless true %} this text should not go into the output {% endunless %} ')
|
8
|
+
assert_template_result(' this text should go into the output ',
|
9
|
+
' {% unless false %} this text should go into the output {% endunless %} ')
|
10
|
+
assert_template_result(' you rock ?','{% unless true %} you suck {% endunless %} {% unless false %} you rock {% endunless %}?')
|
11
|
+
end
|
12
|
+
|
13
|
+
def test_unless_else
|
14
|
+
assert_template_result(' YES ','{% unless true %} NO {% else %} YES {% endunless %}')
|
15
|
+
assert_template_result(' YES ','{% unless false %} YES {% else %} NO {% endunless %}')
|
16
|
+
assert_template_result(' YES ','{% unless "foo" %} NO {% else %} YES {% endunless %}')
|
17
|
+
end
|
18
|
+
|
19
|
+
def test_unless_in_loop
|
20
|
+
assert_template_result '23', '{% for i in choices %}{% unless i %}{{ forloop.index }}{% endunless %}{% endfor %}', 'choices' => [1, nil, false]
|
21
|
+
end
|
22
|
+
|
23
|
+
def test_unless_else_in_loop
|
24
|
+
assert_template_result ' TRUE 2 3 ', '{% for i in choices %}{% unless i %} {{ forloop.index }} {% else %} TRUE {% endunless %}{% endfor %}', 'choices' => [1, nil, false]
|
25
|
+
end
|
26
|
+
end # UnlessElseTest
|
@@ -0,0 +1,74 @@
|
|
1
|
+
require 'test_helper'
|
2
|
+
|
3
|
+
class TemplateTest < Test::Unit::TestCase
|
4
|
+
include Liquid
|
5
|
+
|
6
|
+
def test_tokenize_strings
|
7
|
+
assert_equal [' '], Template.new.send(:tokenize, ' ')
|
8
|
+
assert_equal ['hello world'], Template.new.send(:tokenize, 'hello world')
|
9
|
+
end
|
10
|
+
|
11
|
+
def test_tokenize_variables
|
12
|
+
assert_equal ['{{funk}}'], Template.new.send(:tokenize, '{{funk}}')
|
13
|
+
assert_equal [' ', '{{funk}}', ' '], Template.new.send(:tokenize, ' {{funk}} ')
|
14
|
+
assert_equal [' ', '{{funk}}', ' ', '{{so}}', ' ', '{{brother}}', ' '], Template.new.send(:tokenize, ' {{funk}} {{so}} {{brother}} ')
|
15
|
+
assert_equal [' ', '{{ funk }}', ' '], Template.new.send(:tokenize, ' {{ funk }} ')
|
16
|
+
end
|
17
|
+
|
18
|
+
def test_tokenize_blocks
|
19
|
+
assert_equal ['{%comment%}'], Template.new.send(:tokenize, '{%comment%}')
|
20
|
+
assert_equal [' ', '{%comment%}', ' '], Template.new.send(:tokenize, ' {%comment%} ')
|
21
|
+
|
22
|
+
assert_equal [' ', '{%comment%}', ' ', '{%endcomment%}', ' '], Template.new.send(:tokenize, ' {%comment%} {%endcomment%} ')
|
23
|
+
assert_equal [' ', '{% comment %}', ' ', '{% endcomment %}', ' '], Template.new.send(:tokenize, " {% comment %} {% endcomment %} ")
|
24
|
+
end
|
25
|
+
|
26
|
+
def test_instance_assigns_persist_on_same_template_object_between_parses
|
27
|
+
t = Template.new
|
28
|
+
assert_equal 'from instance assigns', t.parse("{% assign foo = 'from instance assigns' %}{{ foo }}").render
|
29
|
+
assert_equal 'from instance assigns', t.parse("{{ foo }}").render
|
30
|
+
end
|
31
|
+
|
32
|
+
def test_instance_assigns_persist_on_same_template_parsing_between_renders
|
33
|
+
t = Template.new.parse("{{ foo }}{% assign foo = 'foo' %}{{ foo }}")
|
34
|
+
assert_equal 'foo', t.render
|
35
|
+
assert_equal 'foofoo', t.render
|
36
|
+
end
|
37
|
+
|
38
|
+
def test_custom_assigns_do_not_persist_on_same_template
|
39
|
+
t = Template.new
|
40
|
+
assert_equal 'from custom assigns', t.parse("{{ foo }}").render('foo' => 'from custom assigns')
|
41
|
+
assert_equal '', t.parse("{{ foo }}").render
|
42
|
+
end
|
43
|
+
|
44
|
+
def test_custom_assigns_squash_instance_assigns
|
45
|
+
t = Template.new
|
46
|
+
assert_equal 'from instance assigns', t.parse("{% assign foo = 'from instance assigns' %}{{ foo }}").render
|
47
|
+
assert_equal 'from custom assigns', t.parse("{{ foo }}").render('foo' => 'from custom assigns')
|
48
|
+
end
|
49
|
+
|
50
|
+
def test_persistent_assigns_squash_instance_assigns
|
51
|
+
t = Template.new
|
52
|
+
assert_equal 'from instance assigns', t.parse("{% assign foo = 'from instance assigns' %}{{ foo }}").render
|
53
|
+
t.assigns['foo'] = 'from persistent assigns'
|
54
|
+
assert_equal 'from persistent assigns', t.parse("{{ foo }}").render
|
55
|
+
end
|
56
|
+
|
57
|
+
def test_lambda_is_called_once_from_persistent_assigns_over_multiple_parses_and_renders
|
58
|
+
t = Template.new
|
59
|
+
t.assigns['number'] = lambda { @global ||= 0; @global += 1 }
|
60
|
+
assert_equal '1', t.parse("{{number}}").render
|
61
|
+
assert_equal '1', t.parse("{{number}}").render
|
62
|
+
assert_equal '1', t.render
|
63
|
+
@global = nil
|
64
|
+
end
|
65
|
+
|
66
|
+
def test_lambda_is_called_once_from_custom_assigns_over_multiple_parses_and_renders
|
67
|
+
t = Template.new
|
68
|
+
assigns = {'number' => lambda { @global ||= 0; @global += 1 }}
|
69
|
+
assert_equal '1', t.parse("{{number}}").render(assigns)
|
70
|
+
assert_equal '1', t.parse("{{number}}").render(assigns)
|
71
|
+
assert_equal '1', t.render(assigns)
|
72
|
+
@global = nil
|
73
|
+
end
|
74
|
+
end # TemplateTest
|
@@ -0,0 +1,180 @@
|
|
1
|
+
require 'test_helper'
|
2
|
+
|
3
|
+
class VariableTest < Test::Unit::TestCase
|
4
|
+
include Liquid
|
5
|
+
|
6
|
+
def test_variable
|
7
|
+
var = Variable.new('hello')
|
8
|
+
assert_equal 'hello', var.name
|
9
|
+
end
|
10
|
+
|
11
|
+
def test_filters
|
12
|
+
var = Variable.new('hello | textileze')
|
13
|
+
assert_equal 'hello', var.name
|
14
|
+
assert_equal [["textileze",[]]], var.filters
|
15
|
+
|
16
|
+
var = Variable.new('hello | textileze | paragraph')
|
17
|
+
assert_equal 'hello', var.name
|
18
|
+
assert_equal [["textileze",[]], ["paragraph",[]]], var.filters
|
19
|
+
|
20
|
+
var = Variable.new(%! hello | strftime: '%Y'!)
|
21
|
+
assert_equal 'hello', var.name
|
22
|
+
assert_equal [["strftime",["'%Y'"]]], var.filters
|
23
|
+
|
24
|
+
var = Variable.new(%! 'typo' | link_to: 'Typo', true !)
|
25
|
+
assert_equal %!'typo'!, var.name
|
26
|
+
assert_equal [["link_to",["'Typo'", "true"]]], var.filters
|
27
|
+
|
28
|
+
var = Variable.new(%! 'typo' | link_to: 'Typo', false !)
|
29
|
+
assert_equal %!'typo'!, var.name
|
30
|
+
assert_equal [["link_to",["'Typo'", "false"]]], var.filters
|
31
|
+
|
32
|
+
var = Variable.new(%! 'foo' | repeat: 3 !)
|
33
|
+
assert_equal %!'foo'!, var.name
|
34
|
+
assert_equal [["repeat",["3"]]], var.filters
|
35
|
+
|
36
|
+
var = Variable.new(%! 'foo' | repeat: 3, 3 !)
|
37
|
+
assert_equal %!'foo'!, var.name
|
38
|
+
assert_equal [["repeat",["3","3"]]], var.filters
|
39
|
+
|
40
|
+
var = Variable.new(%! 'foo' | repeat: 3, 3, 3 !)
|
41
|
+
assert_equal %!'foo'!, var.name
|
42
|
+
assert_equal [["repeat",["3","3","3"]]], var.filters
|
43
|
+
|
44
|
+
var = Variable.new(%! hello | strftime: '%Y, okay?'!)
|
45
|
+
assert_equal 'hello', var.name
|
46
|
+
assert_equal [["strftime",["'%Y, okay?'"]]], var.filters
|
47
|
+
|
48
|
+
var = Variable.new(%! hello | things: "%Y, okay?", 'the other one'!)
|
49
|
+
assert_equal 'hello', var.name
|
50
|
+
assert_equal [["things",["\"%Y, okay?\"","'the other one'"]]], var.filters
|
51
|
+
end
|
52
|
+
|
53
|
+
def test_filter_with_date_parameter
|
54
|
+
|
55
|
+
var = Variable.new(%! '2006-06-06' | date: "%m/%d/%Y"!)
|
56
|
+
assert_equal "'2006-06-06'", var.name
|
57
|
+
assert_equal [["date",["\"%m/%d/%Y\""]]], var.filters
|
58
|
+
|
59
|
+
end
|
60
|
+
|
61
|
+
def test_filters_without_whitespace
|
62
|
+
var = Variable.new('hello | textileze | paragraph')
|
63
|
+
assert_equal 'hello', var.name
|
64
|
+
assert_equal [["textileze",[]], ["paragraph",[]]], var.filters
|
65
|
+
|
66
|
+
var = Variable.new('hello|textileze|paragraph')
|
67
|
+
assert_equal 'hello', var.name
|
68
|
+
assert_equal [["textileze",[]], ["paragraph",[]]], var.filters
|
69
|
+
|
70
|
+
var = Variable.new("hello|replace:'foo','bar'|textileze")
|
71
|
+
assert_equal 'hello', var.name
|
72
|
+
assert_equal [["replace", ["'foo'", "'bar'"]], ["textileze", []]], var.filters
|
73
|
+
end
|
74
|
+
|
75
|
+
def test_symbol
|
76
|
+
var = Variable.new("http://disney.com/logo.gif | image: 'med' ")
|
77
|
+
assert_equal 'http://disney.com/logo.gif', var.name
|
78
|
+
assert_equal [["image",["'med'"]]], var.filters
|
79
|
+
end
|
80
|
+
|
81
|
+
def test_string_single_quoted
|
82
|
+
var = Variable.new(%| "hello" |)
|
83
|
+
assert_equal '"hello"', var.name
|
84
|
+
end
|
85
|
+
|
86
|
+
def test_string_double_quoted
|
87
|
+
var = Variable.new(%| 'hello' |)
|
88
|
+
assert_equal "'hello'", var.name
|
89
|
+
end
|
90
|
+
|
91
|
+
def test_integer
|
92
|
+
var = Variable.new(%| 1000 |)
|
93
|
+
assert_equal "1000", var.name
|
94
|
+
end
|
95
|
+
|
96
|
+
def test_float
|
97
|
+
var = Variable.new(%| 1000.01 |)
|
98
|
+
assert_equal "1000.01", var.name
|
99
|
+
end
|
100
|
+
|
101
|
+
def test_string_with_special_chars
|
102
|
+
var = Variable.new(%| 'hello! $!@.;"ddasd" ' |)
|
103
|
+
assert_equal %|'hello! $!@.;"ddasd" '|, var.name
|
104
|
+
end
|
105
|
+
|
106
|
+
def test_string_dot
|
107
|
+
var = Variable.new(%| test.test |)
|
108
|
+
assert_equal 'test.test', var.name
|
109
|
+
end
|
110
|
+
|
111
|
+
def test_filter_with_keyword_arguments
|
112
|
+
var = Variable.new(%! hello | things: greeting: "world", farewell: 'goodbye'!)
|
113
|
+
assert_equal 'hello', var.name
|
114
|
+
assert_equal [['things',["greeting: \"world\"","farewell: 'goodbye'"]]], var.filters
|
115
|
+
end
|
116
|
+
end
|
117
|
+
|
118
|
+
|
119
|
+
class VariableResolutionTest < Test::Unit::TestCase
|
120
|
+
include Liquid
|
121
|
+
|
122
|
+
def test_simple_variable
|
123
|
+
template = Template.parse(%|{{test}}|)
|
124
|
+
assert_equal 'worked', template.render('test' => 'worked')
|
125
|
+
assert_equal 'worked wonderfully', template.render('test' => 'worked wonderfully')
|
126
|
+
end
|
127
|
+
|
128
|
+
def test_simple_with_whitespaces
|
129
|
+
template = Template.parse(%| {{ test }} |)
|
130
|
+
assert_equal ' worked ', template.render('test' => 'worked')
|
131
|
+
assert_equal ' worked wonderfully ', template.render('test' => 'worked wonderfully')
|
132
|
+
end
|
133
|
+
|
134
|
+
def test_ignore_unknown
|
135
|
+
template = Template.parse(%|{{ test }}|)
|
136
|
+
assert_equal '', template.render
|
137
|
+
end
|
138
|
+
|
139
|
+
def test_hash_scoping
|
140
|
+
template = Template.parse(%|{{ test.test }}|)
|
141
|
+
assert_equal 'worked', template.render('test' => {'test' => 'worked'})
|
142
|
+
end
|
143
|
+
|
144
|
+
def test_preset_assigns
|
145
|
+
template = Template.parse(%|{{ test }}|)
|
146
|
+
template.assigns['test'] = 'worked'
|
147
|
+
assert_equal 'worked', template.render
|
148
|
+
end
|
149
|
+
|
150
|
+
def test_reuse_parsed_template
|
151
|
+
template = Template.parse(%|{{ greeting }} {{ name }}|)
|
152
|
+
template.assigns['greeting'] = 'Goodbye'
|
153
|
+
assert_equal 'Hello Tobi', template.render('greeting' => 'Hello', 'name' => 'Tobi')
|
154
|
+
assert_equal 'Hello ', template.render('greeting' => 'Hello', 'unknown' => 'Tobi')
|
155
|
+
assert_equal 'Hello Brian', template.render('greeting' => 'Hello', 'name' => 'Brian')
|
156
|
+
assert_equal 'Goodbye Brian', template.render('name' => 'Brian')
|
157
|
+
assert_equal({'greeting'=>'Goodbye'}, template.assigns)
|
158
|
+
end
|
159
|
+
|
160
|
+
def test_assigns_not_polluted_from_template
|
161
|
+
template = Template.parse(%|{{ test }}{% assign test = 'bar' %}{{ test }}|)
|
162
|
+
template.assigns['test'] = 'baz'
|
163
|
+
assert_equal 'bazbar', template.render
|
164
|
+
assert_equal 'bazbar', template.render
|
165
|
+
assert_equal 'foobar', template.render('test' => 'foo')
|
166
|
+
assert_equal 'bazbar', template.render
|
167
|
+
end
|
168
|
+
|
169
|
+
def test_hash_with_default_proc
|
170
|
+
template = Template.parse(%|Hello {{ test }}|)
|
171
|
+
assigns = Hash.new { |h,k| raise "Unknown variable '#{k}'" }
|
172
|
+
assigns['test'] = 'Tobi'
|
173
|
+
assert_equal 'Hello Tobi', template.render!(assigns)
|
174
|
+
assigns.delete('test')
|
175
|
+
e = assert_raises(RuntimeError) {
|
176
|
+
template.render!(assigns)
|
177
|
+
}
|
178
|
+
assert_equal "Unknown variable 'test'", e.message
|
179
|
+
end
|
180
|
+
end # VariableTest
|
data/test/test_helper.rb
ADDED
@@ -0,0 +1,29 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
|
3
|
+
require 'test/unit'
|
4
|
+
require 'test/unit/assertions'
|
5
|
+
begin
|
6
|
+
require 'ruby-debug'
|
7
|
+
rescue LoadError
|
8
|
+
puts "Couldn't load ruby-debug. gem install ruby-debug if you need it."
|
9
|
+
end
|
10
|
+
require File.join(File.dirname(__FILE__), '..', 'lib', 'wordify_liquid')
|
11
|
+
|
12
|
+
|
13
|
+
module Test
|
14
|
+
module Unit
|
15
|
+
module Assertions
|
16
|
+
include Liquid
|
17
|
+
|
18
|
+
def assert_template_result(expected, template, assigns = {}, message = nil)
|
19
|
+
assert_equal expected, Template.parse(template).render(assigns)
|
20
|
+
end
|
21
|
+
|
22
|
+
def assert_template_result_matches(expected, template, assigns = {}, message = nil)
|
23
|
+
return assert_template_result(expected, template, assigns, message) unless expected.is_a? Regexp
|
24
|
+
|
25
|
+
assert_match expected, Template.parse(template).render(assigns)
|
26
|
+
end
|
27
|
+
end # Assertions
|
28
|
+
end # Unit
|
29
|
+
end # Test
|