liquid 4.0.0.rc3 → 5.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/History.md +93 -2
- data/README.md +8 -0
- data/lib/liquid.rb +18 -5
- data/lib/liquid/block.rb +47 -20
- data/lib/liquid/block_body.rb +190 -76
- data/lib/liquid/condition.rb +69 -29
- data/lib/liquid/context.rb +122 -76
- data/lib/liquid/document.rb +47 -9
- data/lib/liquid/drop.rb +4 -2
- data/lib/liquid/errors.rb +20 -25
- data/lib/liquid/expression.rb +30 -31
- data/lib/liquid/extensions.rb +8 -0
- data/lib/liquid/file_system.rb +6 -4
- data/lib/liquid/forloop_drop.rb +11 -4
- data/lib/liquid/i18n.rb +5 -3
- data/lib/liquid/interrupts.rb +3 -1
- data/lib/liquid/lexer.rb +35 -26
- data/lib/liquid/locales/en.yml +4 -2
- data/lib/liquid/parse_context.rb +17 -4
- data/lib/liquid/parse_tree_visitor.rb +42 -0
- data/lib/liquid/parser.rb +30 -18
- data/lib/liquid/parser_switching.rb +17 -3
- data/lib/liquid/partial_cache.rb +24 -0
- data/lib/liquid/profiler.rb +67 -86
- data/lib/liquid/profiler/hooks.rb +26 -14
- data/lib/liquid/range_lookup.rb +5 -3
- data/lib/liquid/register.rb +6 -0
- data/lib/liquid/resource_limits.rb +47 -8
- data/lib/liquid/standardfilters.rb +171 -57
- data/lib/liquid/static_registers.rb +44 -0
- data/lib/liquid/strainer_factory.rb +36 -0
- data/lib/liquid/strainer_template.rb +53 -0
- data/lib/liquid/tablerowloop_drop.rb +6 -4
- data/lib/liquid/tag.rb +28 -6
- data/lib/liquid/tag/disableable.rb +22 -0
- data/lib/liquid/tag/disabler.rb +21 -0
- data/lib/liquid/tags/assign.rb +32 -10
- data/lib/liquid/tags/break.rb +8 -3
- data/lib/liquid/tags/capture.rb +11 -8
- data/lib/liquid/tags/case.rb +41 -27
- data/lib/liquid/tags/comment.rb +5 -3
- data/lib/liquid/tags/continue.rb +8 -3
- data/lib/liquid/tags/cycle.rb +35 -16
- data/lib/liquid/tags/decrement.rb +6 -3
- data/lib/liquid/tags/echo.rb +26 -0
- data/lib/liquid/tags/for.rb +79 -47
- data/lib/liquid/tags/if.rb +53 -30
- data/lib/liquid/tags/ifchanged.rb +11 -10
- data/lib/liquid/tags/include.rb +42 -44
- data/lib/liquid/tags/increment.rb +7 -3
- data/lib/liquid/tags/raw.rb +14 -11
- data/lib/liquid/tags/render.rb +84 -0
- data/lib/liquid/tags/table_row.rb +32 -20
- data/lib/liquid/tags/unless.rb +15 -15
- data/lib/liquid/template.rb +60 -71
- data/lib/liquid/template_factory.rb +9 -0
- data/lib/liquid/tokenizer.rb +17 -9
- data/lib/liquid/usage.rb +8 -0
- data/lib/liquid/utils.rb +6 -4
- data/lib/liquid/variable.rb +55 -38
- data/lib/liquid/variable_lookup.rb +14 -6
- data/lib/liquid/version.rb +3 -1
- data/test/integration/assign_test.rb +74 -5
- data/test/integration/blank_test.rb +11 -8
- data/test/integration/block_test.rb +58 -0
- data/test/integration/capture_test.rb +18 -10
- data/test/integration/context_test.rb +608 -5
- data/test/integration/document_test.rb +4 -2
- data/test/integration/drop_test.rb +67 -83
- data/test/integration/error_handling_test.rb +90 -60
- data/test/integration/expression_test.rb +46 -0
- data/test/integration/filter_test.rb +53 -42
- data/test/integration/hash_ordering_test.rb +5 -3
- data/test/integration/output_test.rb +26 -24
- data/test/integration/parsing_quirks_test.rb +24 -8
- data/test/integration/{render_profiling_test.rb → profiler_test.rb} +84 -25
- data/test/integration/security_test.rb +41 -18
- data/test/integration/standard_filter_test.rb +523 -205
- data/test/integration/tag/disableable_test.rb +59 -0
- data/test/integration/tag_test.rb +45 -0
- data/test/integration/tags/break_tag_test.rb +4 -2
- data/test/integration/tags/continue_tag_test.rb +4 -2
- data/test/integration/tags/echo_test.rb +13 -0
- data/test/integration/tags/for_tag_test.rb +109 -53
- data/test/integration/tags/if_else_tag_test.rb +5 -3
- data/test/integration/tags/include_tag_test.rb +83 -52
- data/test/integration/tags/increment_tag_test.rb +4 -2
- data/test/integration/tags/liquid_tag_test.rb +116 -0
- data/test/integration/tags/raw_tag_test.rb +14 -11
- data/test/integration/tags/render_tag_test.rb +213 -0
- data/test/integration/tags/standard_tag_test.rb +38 -31
- data/test/integration/tags/statements_test.rb +23 -21
- data/test/integration/tags/table_row_test.rb +2 -0
- data/test/integration/tags/unless_else_tag_test.rb +4 -2
- data/test/integration/template_test.rb +128 -121
- data/test/integration/trim_mode_test.rb +82 -44
- data/test/integration/variable_test.rb +46 -31
- data/test/test_helper.rb +75 -23
- data/test/unit/block_unit_test.rb +19 -24
- data/test/unit/condition_unit_test.rb +82 -72
- data/test/unit/file_system_unit_test.rb +6 -4
- data/test/unit/i18n_unit_test.rb +7 -5
- data/test/unit/lexer_unit_test.rb +12 -10
- data/test/unit/parse_tree_visitor_test.rb +247 -0
- data/test/unit/parser_unit_test.rb +37 -35
- data/test/unit/partial_cache_unit_test.rb +128 -0
- data/test/unit/regexp_unit_test.rb +17 -15
- data/test/unit/static_registers_unit_test.rb +156 -0
- data/test/unit/strainer_factory_unit_test.rb +100 -0
- data/test/unit/strainer_template_unit_test.rb +82 -0
- data/test/unit/tag_unit_test.rb +5 -3
- data/test/unit/tags/case_tag_unit_test.rb +3 -1
- data/test/unit/tags/for_tag_unit_test.rb +4 -2
- data/test/unit/tags/if_tag_unit_test.rb +3 -1
- data/test/unit/template_factory_unit_test.rb +12 -0
- data/test/unit/template_unit_test.rb +19 -10
- data/test/unit/tokenizer_unit_test.rb +19 -17
- data/test/unit/variable_unit_test.rb +51 -49
- metadata +83 -50
- data/lib/liquid/strainer.rb +0 -65
- data/test/unit/context_unit_test.rb +0 -483
- data/test/unit/strainer_unit_test.rb +0 -136
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
require 'test_helper'
|
2
4
|
|
3
5
|
class IfElseTagTest < Minitest::Test
|
@@ -43,7 +45,7 @@ class IfElseTagTest < Minitest::Test
|
|
43
45
|
|
44
46
|
def test_comparison_of_strings_containing_and_or_or
|
45
47
|
awful_markup = "a == 'and' and b == 'or' and c == 'foo and bar' and d == 'bar or baz' and e == 'foo' and foo and bar"
|
46
|
-
assigns
|
48
|
+
assigns = { 'a' => 'and', 'b' => 'or', 'c' => 'foo and bar', 'd' => 'bar or baz', 'e' => 'foo', 'foo' => true, 'bar' => true }
|
47
49
|
assert_template_result(' YES ', "{% if #{awful_markup} %} YES {% endif %}", assigns)
|
48
50
|
end
|
49
51
|
|
@@ -132,7 +134,7 @@ class IfElseTagTest < Minitest::Test
|
|
132
134
|
end
|
133
135
|
|
134
136
|
def test_syntax_error_no_variable
|
135
|
-
assert_raises(SyntaxError){ assert_template_result('', '{% if jerry == 1 %}') }
|
137
|
+
assert_raises(SyntaxError) { assert_template_result('', '{% if jerry == 1 %}') }
|
136
138
|
end
|
137
139
|
|
138
140
|
def test_syntax_error_no_expression
|
@@ -182,7 +184,7 @@ class IfElseTagTest < Minitest::Test
|
|
182
184
|
tests.each do |vals, expected|
|
183
185
|
a, b, c = vals
|
184
186
|
assigns = { 'a' => a, 'b' => b, 'c' => c }
|
185
|
-
assert_template_result
|
187
|
+
assert_template_result(expected.to_s, tpl, assigns, assigns.to_s)
|
186
188
|
end
|
187
189
|
end
|
188
190
|
end
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
require 'test_helper'
|
2
4
|
|
3
5
|
class TestFileSystem
|
@@ -6,6 +8,9 @@ class TestFileSystem
|
|
6
8
|
when "product"
|
7
9
|
"Product: {{ product.title }} "
|
8
10
|
|
11
|
+
when "product_alias"
|
12
|
+
"Product: {{ product.title }} "
|
13
|
+
|
9
14
|
when "locale_variables"
|
10
15
|
"Locale: {{echo1}} {{echo2}}"
|
11
16
|
|
@@ -30,6 +35,9 @@ class TestFileSystem
|
|
30
35
|
when 'assignments'
|
31
36
|
"{% assign foo = 'bar' %}"
|
32
37
|
|
38
|
+
when 'break'
|
39
|
+
"{% break %}"
|
40
|
+
|
33
41
|
else
|
34
42
|
template_path
|
35
43
|
end
|
@@ -37,16 +45,16 @@ class TestFileSystem
|
|
37
45
|
end
|
38
46
|
|
39
47
|
class OtherFileSystem
|
40
|
-
def read_template_file(
|
48
|
+
def read_template_file(_template_path)
|
41
49
|
'from OtherFileSystem'
|
42
50
|
end
|
43
51
|
end
|
44
52
|
|
45
53
|
class CountingFileSystem
|
46
54
|
attr_reader :count
|
47
|
-
def read_template_file(
|
55
|
+
def read_template_file(_template_path)
|
48
56
|
@count ||= 0
|
49
|
-
@count
|
57
|
+
@count += 1
|
50
58
|
'from CountingFileSystem'
|
51
59
|
end
|
52
60
|
end
|
@@ -56,15 +64,16 @@ class CustomInclude < Liquid::Tag
|
|
56
64
|
|
57
65
|
def initialize(tag_name, markup, tokens)
|
58
66
|
markup =~ Syntax
|
59
|
-
@template_name =
|
67
|
+
@template_name = Regexp.last_match(1)
|
60
68
|
super
|
61
69
|
end
|
62
70
|
|
63
71
|
def parse(tokens)
|
64
72
|
end
|
65
73
|
|
66
|
-
def
|
67
|
-
@template_name[1..-2]
|
74
|
+
def render_to_output_buffer(_context, output)
|
75
|
+
output << @template_name[1..-2]
|
76
|
+
output
|
68
77
|
end
|
69
78
|
end
|
70
79
|
|
@@ -76,108 +85,118 @@ class IncludeTagTest < Minitest::Test
|
|
76
85
|
end
|
77
86
|
|
78
87
|
def test_include_tag_looks_for_file_system_in_registers_first
|
79
|
-
assert_equal
|
80
|
-
Template.parse("{% include 'pick_a_source' %}").render!({}, registers: { file_system: OtherFileSystem.new })
|
88
|
+
assert_equal('from OtherFileSystem',
|
89
|
+
Template.parse("{% include 'pick_a_source' %}").render!({}, registers: { file_system: OtherFileSystem.new }))
|
81
90
|
end
|
82
91
|
|
83
92
|
def test_include_tag_with
|
84
|
-
assert_template_result
|
85
|
-
"{% include 'product' with products[0] %}", "products" => [
|
93
|
+
assert_template_result("Product: Draft 151cm ",
|
94
|
+
"{% include 'product' with products[0] %}", "products" => [{ 'title' => 'Draft 151cm' }, { 'title' => 'Element 155cm' }])
|
95
|
+
end
|
96
|
+
|
97
|
+
def test_include_tag_with_alias
|
98
|
+
assert_template_result("Product: Draft 151cm ",
|
99
|
+
"{% include 'product_alias' with products[0] as product %}", "products" => [{ 'title' => 'Draft 151cm' }, { 'title' => 'Element 155cm' }])
|
100
|
+
end
|
101
|
+
|
102
|
+
def test_include_tag_for_alias
|
103
|
+
assert_template_result("Product: Draft 151cm Product: Element 155cm ",
|
104
|
+
"{% include 'product_alias' for products as product %}", "products" => [{ 'title' => 'Draft 151cm' }, { 'title' => 'Element 155cm' }])
|
86
105
|
end
|
87
106
|
|
88
107
|
def test_include_tag_with_default_name
|
89
|
-
assert_template_result
|
90
|
-
"{% include 'product' %}", "product" => { 'title' => 'Draft 151cm' }
|
108
|
+
assert_template_result("Product: Draft 151cm ",
|
109
|
+
"{% include 'product' %}", "product" => { 'title' => 'Draft 151cm' })
|
91
110
|
end
|
92
111
|
|
93
112
|
def test_include_tag_for
|
94
|
-
assert_template_result
|
95
|
-
"{% include 'product' for products %}", "products" => [
|
113
|
+
assert_template_result("Product: Draft 151cm Product: Element 155cm ",
|
114
|
+
"{% include 'product' for products %}", "products" => [{ 'title' => 'Draft 151cm' }, { 'title' => 'Element 155cm' }])
|
96
115
|
end
|
97
116
|
|
98
117
|
def test_include_tag_with_local_variables
|
99
|
-
assert_template_result
|
118
|
+
assert_template_result("Locale: test123 ", "{% include 'locale_variables' echo1: 'test123' %}")
|
100
119
|
end
|
101
120
|
|
102
121
|
def test_include_tag_with_multiple_local_variables
|
103
|
-
assert_template_result
|
104
|
-
"{% include 'locale_variables' echo1: 'test123', echo2: 'test321' %}"
|
122
|
+
assert_template_result("Locale: test123 test321",
|
123
|
+
"{% include 'locale_variables' echo1: 'test123', echo2: 'test321' %}")
|
105
124
|
end
|
106
125
|
|
107
126
|
def test_include_tag_with_multiple_local_variables_from_context
|
108
|
-
assert_template_result
|
127
|
+
assert_template_result("Locale: test123 test321",
|
109
128
|
"{% include 'locale_variables' echo1: echo1, echo2: more_echos.echo2 %}",
|
110
|
-
'echo1' => 'test123', 'more_echos' => { "echo2" => 'test321' }
|
129
|
+
'echo1' => 'test123', 'more_echos' => { "echo2" => 'test321' })
|
111
130
|
end
|
112
131
|
|
113
132
|
def test_included_templates_assigns_variables
|
114
|
-
assert_template_result
|
133
|
+
assert_template_result("bar", "{% include 'assignments' %}{{ foo }}")
|
115
134
|
end
|
116
135
|
|
117
136
|
def test_nested_include_tag
|
118
|
-
assert_template_result
|
137
|
+
assert_template_result("body body_detail", "{% include 'body' %}")
|
119
138
|
|
120
|
-
assert_template_result
|
139
|
+
assert_template_result("header body body_detail footer", "{% include 'nested_template' %}")
|
121
140
|
end
|
122
141
|
|
123
142
|
def test_nested_include_with_variable
|
124
|
-
assert_template_result
|
125
|
-
"{% include 'nested_product_template' with product %}", "product" => { "title" => 'Draft 151cm' }
|
143
|
+
assert_template_result("Product: Draft 151cm details ",
|
144
|
+
"{% include 'nested_product_template' with product %}", "product" => { "title" => 'Draft 151cm' })
|
126
145
|
|
127
|
-
assert_template_result
|
128
|
-
"{% include 'nested_product_template' for products %}", "products" => [{ "title" => 'Draft 151cm' }, { "title" => 'Element 155cm' }]
|
146
|
+
assert_template_result("Product: Draft 151cm details Product: Element 155cm details ",
|
147
|
+
"{% include 'nested_product_template' for products %}", "products" => [{ "title" => 'Draft 151cm' }, { "title" => 'Element 155cm' }])
|
129
148
|
end
|
130
149
|
|
131
150
|
def test_recursively_included_template_does_not_produce_endless_loop
|
132
151
|
infinite_file_system = Class.new do
|
133
|
-
def read_template_file(
|
152
|
+
def read_template_file(_template_path)
|
134
153
|
"-{% include 'loop' %}"
|
135
154
|
end
|
136
155
|
end
|
137
156
|
|
138
157
|
Liquid::Template.file_system = infinite_file_system.new
|
139
158
|
|
140
|
-
assert_raises(Liquid::StackLevelError
|
159
|
+
assert_raises(Liquid::StackLevelError) do
|
141
160
|
Template.parse("{% include 'loop' %}").render!
|
142
161
|
end
|
143
162
|
end
|
144
163
|
|
145
164
|
def test_dynamically_choosen_template
|
146
|
-
assert_template_result
|
147
|
-
assert_template_result
|
165
|
+
assert_template_result("Test123", "{% include template %}", "template" => 'Test123')
|
166
|
+
assert_template_result("Test321", "{% include template %}", "template" => 'Test321')
|
148
167
|
|
149
|
-
assert_template_result
|
150
|
-
"template" => 'product', 'product' => { 'title' => 'Draft 151cm' }
|
168
|
+
assert_template_result("Product: Draft 151cm ", "{% include template for product %}",
|
169
|
+
"template" => 'product', 'product' => { 'title' => 'Draft 151cm' })
|
151
170
|
end
|
152
171
|
|
153
172
|
def test_include_tag_caches_second_read_of_same_partial
|
154
173
|
file_system = CountingFileSystem.new
|
155
|
-
assert_equal
|
156
|
-
Template.parse("{% include 'pick_a_source' %}{% include 'pick_a_source' %}").render!({}, registers: { file_system: file_system })
|
157
|
-
assert_equal
|
174
|
+
assert_equal('from CountingFileSystemfrom CountingFileSystem',
|
175
|
+
Template.parse("{% include 'pick_a_source' %}{% include 'pick_a_source' %}").render!({}, registers: { file_system: file_system }))
|
176
|
+
assert_equal(1, file_system.count)
|
158
177
|
end
|
159
178
|
|
160
179
|
def test_include_tag_doesnt_cache_partials_across_renders
|
161
180
|
file_system = CountingFileSystem.new
|
162
|
-
assert_equal
|
163
|
-
Template.parse("{% include 'pick_a_source' %}").render!({}, registers: { file_system: file_system })
|
164
|
-
assert_equal
|
181
|
+
assert_equal('from CountingFileSystem',
|
182
|
+
Template.parse("{% include 'pick_a_source' %}").render!({}, registers: { file_system: file_system }))
|
183
|
+
assert_equal(1, file_system.count)
|
165
184
|
|
166
|
-
assert_equal
|
167
|
-
Template.parse("{% include 'pick_a_source' %}").render!({}, registers: { file_system: file_system })
|
168
|
-
assert_equal
|
185
|
+
assert_equal('from CountingFileSystem',
|
186
|
+
Template.parse("{% include 'pick_a_source' %}").render!({}, registers: { file_system: file_system }))
|
187
|
+
assert_equal(2, file_system.count)
|
169
188
|
end
|
170
189
|
|
171
190
|
def test_include_tag_within_if_statement
|
172
|
-
assert_template_result
|
191
|
+
assert_template_result("foo_if_true", "{% if true %}{% include 'foo_if_true' %}{% endif %}")
|
173
192
|
end
|
174
193
|
|
175
194
|
def test_custom_include_tag
|
176
195
|
original_tag = Liquid::Template.tags['include']
|
177
196
|
Liquid::Template.tags['include'] = CustomInclude
|
178
197
|
begin
|
179
|
-
assert_equal
|
180
|
-
Template.parse("{% include 'custom_foo' %}").render!
|
198
|
+
assert_equal("custom_foo",
|
199
|
+
Template.parse("{% include 'custom_foo' %}").render!)
|
181
200
|
ensure
|
182
201
|
Liquid::Template.tags['include'] = original_tag
|
183
202
|
end
|
@@ -187,8 +206,8 @@ class IncludeTagTest < Minitest::Test
|
|
187
206
|
original_tag = Liquid::Template.tags['include']
|
188
207
|
Liquid::Template.tags['include'] = CustomInclude
|
189
208
|
begin
|
190
|
-
assert_equal
|
191
|
-
Template.parse("{% if true %}{% include 'custom_foo_if_true' %}{% endif %}").render!
|
209
|
+
assert_equal("custom_foo_if_true",
|
210
|
+
Template.parse("{% if true %}{% include 'custom_foo_if_true' %}{% endif %}").render!)
|
192
211
|
ensure
|
193
212
|
Liquid::Template.tags['include'] = original_tag
|
194
213
|
end
|
@@ -199,7 +218,7 @@ class IncludeTagTest < Minitest::Test
|
|
199
218
|
|
200
219
|
a = Liquid::Template.parse(' {% include "nested_template" %}')
|
201
220
|
a.render!
|
202
|
-
assert_empty
|
221
|
+
assert_empty(a.errors)
|
203
222
|
end
|
204
223
|
|
205
224
|
def test_passing_options_to_included_templates
|
@@ -207,13 +226,13 @@ class IncludeTagTest < Minitest::Test
|
|
207
226
|
Template.parse("{% include template %}", error_mode: :strict).render!("template" => '{{ "X" || downcase }}')
|
208
227
|
end
|
209
228
|
with_error_mode(:lax) do
|
210
|
-
assert_equal
|
229
|
+
assert_equal('x', Template.parse("{% include template %}", error_mode: :strict, include_options_blacklist: true).render!("template" => '{{ "X" || downcase }}'))
|
211
230
|
end
|
212
231
|
assert_raises(Liquid::SyntaxError) do
|
213
232
|
Template.parse("{% include template %}", error_mode: :strict, include_options_blacklist: [:locale]).render!("template" => '{{ "X" || downcase }}')
|
214
233
|
end
|
215
234
|
with_error_mode(:lax) do
|
216
|
-
assert_equal
|
235
|
+
assert_equal('x', Template.parse("{% include template %}", error_mode: :strict, include_options_blacklist: [:error_mode]).render!("template" => '{{ "X" || downcase }}'))
|
217
236
|
end
|
218
237
|
end
|
219
238
|
|
@@ -229,10 +248,22 @@ class IncludeTagTest < Minitest::Test
|
|
229
248
|
end
|
230
249
|
|
231
250
|
def test_including_via_variable_value
|
232
|
-
assert_template_result
|
251
|
+
assert_template_result("from TestFileSystem", "{% assign page = 'pick_a_source' %}{% include page %}")
|
233
252
|
|
234
|
-
assert_template_result
|
253
|
+
assert_template_result("Product: Draft 151cm ", "{% assign page = 'product' %}{% include page %}", "product" => { 'title' => 'Draft 151cm' })
|
254
|
+
|
255
|
+
assert_template_result("Product: Draft 151cm ", "{% assign page = 'product' %}{% include page for foo %}", "foo" => { 'title' => 'Draft 151cm' })
|
256
|
+
end
|
257
|
+
|
258
|
+
def test_including_with_strict_variables
|
259
|
+
template = Liquid::Template.parse("{% include 'simple' %}", error_mode: :warn)
|
260
|
+
template.render(nil, strict_variables: true)
|
261
|
+
|
262
|
+
assert_equal([], template.errors)
|
263
|
+
end
|
235
264
|
|
236
|
-
|
265
|
+
def test_break_through_include
|
266
|
+
assert_template_result("1", "{% for i in (1..3) %}{{ i }}{% break %}{{ i }}{% endfor %}")
|
267
|
+
assert_template_result("1", "{% for i in (1..3) %}{{ i }}{% include 'break' %}{{ i }}{% endfor %}")
|
237
268
|
end
|
238
269
|
end # IncludeTagTest
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
require 'test_helper'
|
2
4
|
|
3
5
|
class IncrementTagTest < Minitest::Test
|
@@ -13,11 +15,11 @@ class IncrementTagTest < Minitest::Test
|
|
13
15
|
end
|
14
16
|
|
15
17
|
def test_dec
|
16
|
-
assert_template_result('9', '{%decrement port %}',
|
18
|
+
assert_template_result('9', '{%decrement port %}', 'port' => 10)
|
17
19
|
assert_template_result('-1 -2', '{%decrement port %} {%decrement port%}', {})
|
18
20
|
assert_template_result('1 5 2 2 5',
|
19
21
|
'{%increment port %} {%increment starboard%} ' \
|
20
22
|
'{%increment port %} {%decrement port%} ' \
|
21
|
-
'{%decrement starboard %}',
|
23
|
+
'{%decrement starboard %}', 'port' => 1, 'starboard' => 5)
|
22
24
|
end
|
23
25
|
end
|
@@ -0,0 +1,116 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'test_helper'
|
4
|
+
|
5
|
+
class LiquidTagTest < Minitest::Test
|
6
|
+
include Liquid
|
7
|
+
|
8
|
+
def test_liquid_tag
|
9
|
+
assert_template_result('1 2 3', <<~LIQUID, 'array' => [1, 2, 3])
|
10
|
+
{%- liquid
|
11
|
+
echo array | join: " "
|
12
|
+
-%}
|
13
|
+
LIQUID
|
14
|
+
|
15
|
+
assert_template_result('1 2 3', <<~LIQUID, 'array' => [1, 2, 3])
|
16
|
+
{%- liquid
|
17
|
+
for value in array
|
18
|
+
echo value
|
19
|
+
unless forloop.last
|
20
|
+
echo " "
|
21
|
+
endunless
|
22
|
+
endfor
|
23
|
+
-%}
|
24
|
+
LIQUID
|
25
|
+
|
26
|
+
assert_template_result('4 8 12 6', <<~LIQUID, 'array' => [1, 2, 3])
|
27
|
+
{%- liquid
|
28
|
+
for value in array
|
29
|
+
assign double_value = value | times: 2
|
30
|
+
echo double_value | times: 2
|
31
|
+
unless forloop.last
|
32
|
+
echo " "
|
33
|
+
endunless
|
34
|
+
endfor
|
35
|
+
|
36
|
+
echo " "
|
37
|
+
echo double_value
|
38
|
+
-%}
|
39
|
+
LIQUID
|
40
|
+
|
41
|
+
assert_template_result('abc', <<~LIQUID)
|
42
|
+
{%- liquid echo "a" -%}
|
43
|
+
b
|
44
|
+
{%- liquid echo "c" -%}
|
45
|
+
LIQUID
|
46
|
+
end
|
47
|
+
|
48
|
+
def test_liquid_tag_errors
|
49
|
+
assert_match_syntax_error("syntax error (line 1): Unknown tag 'error'", <<~LIQUID)
|
50
|
+
{%- liquid error no such tag -%}
|
51
|
+
LIQUID
|
52
|
+
|
53
|
+
assert_match_syntax_error("syntax error (line 7): Unknown tag 'error'", <<~LIQUID)
|
54
|
+
{{ test }}
|
55
|
+
|
56
|
+
{%-
|
57
|
+
liquid
|
58
|
+
for value in array
|
59
|
+
|
60
|
+
error no such tag
|
61
|
+
endfor
|
62
|
+
-%}
|
63
|
+
LIQUID
|
64
|
+
|
65
|
+
assert_match_syntax_error("syntax error (line 2): Unknown tag '!!! the guards are vigilant'", <<~LIQUID)
|
66
|
+
{%- liquid
|
67
|
+
!!! the guards are vigilant
|
68
|
+
-%}
|
69
|
+
LIQUID
|
70
|
+
|
71
|
+
assert_match_syntax_error("syntax error (line 4): 'for' tag was never closed", <<~LIQUID)
|
72
|
+
{%- liquid
|
73
|
+
for value in array
|
74
|
+
echo 'forgot to close the for tag'
|
75
|
+
-%}
|
76
|
+
LIQUID
|
77
|
+
end
|
78
|
+
|
79
|
+
def test_line_number_is_correct_after_a_blank_token
|
80
|
+
assert_match_syntax_error("syntax error (line 3): Unknown tag 'error'", "{% liquid echo ''\n\n error %}")
|
81
|
+
assert_match_syntax_error("syntax error (line 3): Unknown tag 'error'", "{% liquid echo ''\n \n error %}")
|
82
|
+
end
|
83
|
+
|
84
|
+
def test_nested_liquid_tag
|
85
|
+
assert_template_result('good', <<~LIQUID)
|
86
|
+
{%- if true %}
|
87
|
+
{%- liquid
|
88
|
+
echo "good"
|
89
|
+
%}
|
90
|
+
{%- endif -%}
|
91
|
+
LIQUID
|
92
|
+
end
|
93
|
+
|
94
|
+
def test_cannot_open_blocks_living_past_a_liquid_tag
|
95
|
+
assert_match_syntax_error("syntax error (line 3): 'if' tag was never closed", <<~LIQUID)
|
96
|
+
{%- liquid
|
97
|
+
if true
|
98
|
+
-%}
|
99
|
+
{%- endif -%}
|
100
|
+
LIQUID
|
101
|
+
end
|
102
|
+
|
103
|
+
def test_cannot_close_blocks_created_before_a_liquid_tag
|
104
|
+
assert_match_syntax_error("syntax error (line 3): 'endif' is not a valid delimiter for liquid tags. use %}", <<~LIQUID)
|
105
|
+
{%- if true -%}
|
106
|
+
42
|
107
|
+
{%- liquid endif -%}
|
108
|
+
LIQUID
|
109
|
+
end
|
110
|
+
|
111
|
+
def test_liquid_tag_in_raw
|
112
|
+
assert_template_result("{% liquid echo 'test' %}\n", <<~LIQUID)
|
113
|
+
{% raw %}{% liquid echo 'test' %}{% endraw %}
|
114
|
+
LIQUID
|
115
|
+
end
|
116
|
+
end
|
@@ -1,26 +1,29 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
require 'test_helper'
|
2
4
|
|
3
5
|
class RawTagTest < Minitest::Test
|
4
6
|
include Liquid
|
5
7
|
|
6
8
|
def test_tag_in_raw
|
7
|
-
assert_template_result
|
8
|
-
'{% raw %}{% comment %} test {% endcomment %}{% endraw %}'
|
9
|
+
assert_template_result('{% comment %} test {% endcomment %}',
|
10
|
+
'{% raw %}{% comment %} test {% endcomment %}{% endraw %}')
|
9
11
|
end
|
10
12
|
|
11
13
|
def test_output_in_raw
|
12
|
-
assert_template_result
|
14
|
+
assert_template_result('{{ test }}', '{% raw %}{{ test }}{% endraw %}')
|
13
15
|
end
|
14
16
|
|
15
17
|
def test_open_tag_in_raw
|
16
|
-
assert_template_result
|
17
|
-
assert_template_result
|
18
|
-
assert_template_result
|
19
|
-
assert_template_result
|
20
|
-
assert_template_result
|
21
|
-
assert_template_result
|
22
|
-
assert_template_result
|
23
|
-
assert_template_result
|
18
|
+
assert_template_result(' Foobar {% invalid ', '{% raw %} Foobar {% invalid {% endraw %}')
|
19
|
+
assert_template_result(' Foobar invalid %} ', '{% raw %} Foobar invalid %} {% endraw %}')
|
20
|
+
assert_template_result(' Foobar {{ invalid ', '{% raw %} Foobar {{ invalid {% endraw %}')
|
21
|
+
assert_template_result(' Foobar invalid }} ', '{% raw %} Foobar invalid }} {% endraw %}')
|
22
|
+
assert_template_result(' Foobar {% invalid {% {% endraw ', '{% raw %} Foobar {% invalid {% {% endraw {% endraw %}')
|
23
|
+
assert_template_result(' Foobar {% {% {% ', '{% raw %} Foobar {% {% {% {% endraw %}')
|
24
|
+
assert_template_result(' test {% raw %} {% endraw %}', '{% raw %} test {% raw %} {% {% endraw %}endraw %}')
|
25
|
+
assert_template_result(' Foobar {{ invalid 1', '{% raw %} Foobar {{ invalid {% endraw %}{{ 1 }}')
|
26
|
+
assert_template_result(' Foobar {% foo {% bar %}', '{% raw %} Foobar {% foo {% bar %}{% endraw %}')
|
24
27
|
end
|
25
28
|
|
26
29
|
def test_invalid_raw
|