qiita_marker 0.23.2.1 → 0.23.5.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/LICENSE.txt +19 -17
- data/README.md +2 -0
- data/Rakefile +57 -56
- data/bin/qiita_marker +2 -7
- data/ext/qiita_marker/autolink.c +57 -10
- data/ext/qiita_marker/cmark-gfm_version.h +2 -2
- data/ext/qiita_marker/html.c +1 -1
- data/ext/qiita_marker/qfm.h +3 -0
- data/ext/qiita_marker/qfm_custom_block.c +1 -14
- data/ext/qiita_marker/qfm_mention_no_emphasis.c +1 -1
- data/ext/qiita_marker/qiita_marker.c +30 -44
- data/ext/qiita_marker/scanners.c +2438 -2450
- data/ext/qiita_marker/table.c +28 -2
- data/lib/qiita_marker/config.rb +5 -3
- data/lib/qiita_marker/node/inspect.rb +8 -18
- data/lib/qiita_marker/node.rb +6 -6
- data/lib/qiita_marker/renderer/html_renderer.rb +39 -39
- data/lib/qiita_marker/renderer.rb +5 -5
- data/lib/qiita_marker/version.rb +1 -1
- data/lib/qiita_marker.rb +9 -11
- data/qiita_marker.gemspec +27 -29
- metadata +3 -61
- data/test/benchmark.rb +0 -32
- data/test/fixtures/curly.md +0 -1
- data/test/fixtures/dingus.md +0 -10
- data/test/fixtures/strong.md +0 -1
- data/test/fixtures/table.md +0 -10
- data/test/test_attributes.rb +0 -24
- data/test/test_basics.rb +0 -35
- data/test/test_commands.rb +0 -72
- data/test/test_commonmark.rb +0 -36
- data/test/test_doc.rb +0 -130
- data/test/test_encoding.rb +0 -23
- data/test/test_extensions.rb +0 -116
- data/test/test_footnotes.rb +0 -60
- data/test/test_gc.rb +0 -47
- data/test/test_helper.rb +0 -71
- data/test/test_linebreaks.rb +0 -15
- data/test/test_maliciousness.rb +0 -262
- data/test/test_node.rb +0 -89
- data/test/test_options.rb +0 -37
- data/test/test_pathological_inputs.rb +0 -94
- data/test/test_plaintext.rb +0 -46
- data/test/test_qfm_code_data_metadata.rb +0 -26
- data/test/test_qfm_custom_block.rb +0 -23
- data/test/test_qfm_mention_no_emphasis.rb +0 -60
- data/test/test_renderer.rb +0 -47
- data/test/test_smartpunct.rb +0 -27
- data/test/test_spec.rb +0 -30
- data/test/test_tasklists.rb +0 -43
- data/test/test_xml.rb +0 -107
data/test/test_linebreaks.rb
DELETED
@@ -1,15 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'test_helper'
|
4
|
-
|
5
|
-
class TestLinebreaks < Minitest::Test
|
6
|
-
def test_hardbreak_no_spaces
|
7
|
-
doc = QiitaMarker.render_doc("foo\nbaz")
|
8
|
-
assert_equal "<p>foo<br />\nbaz</p>\n", doc.to_html(:HARDBREAKS)
|
9
|
-
end
|
10
|
-
|
11
|
-
def test_hardbreak_with_spaces
|
12
|
-
doc = QiitaMarker.render_doc("foo \nbaz")
|
13
|
-
assert_equal "<p>foo<br />\nbaz</p>\n", doc.to_html(:HARDBREAKS)
|
14
|
-
end
|
15
|
-
end
|
data/test/test_maliciousness.rb
DELETED
@@ -1,262 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'test_helper'
|
4
|
-
|
5
|
-
module QiitaMarker
|
6
|
-
class TestMaliciousness < Minitest::Test
|
7
|
-
def setup
|
8
|
-
@doc = QiitaMarker.render_doc('Hi *there*')
|
9
|
-
end
|
10
|
-
|
11
|
-
def test_init_with_bad_type
|
12
|
-
assert_raises TypeError do
|
13
|
-
Node.new(123)
|
14
|
-
end
|
15
|
-
|
16
|
-
assert_raises NodeError do
|
17
|
-
Node.new(:totes_fake)
|
18
|
-
end
|
19
|
-
|
20
|
-
assert_raises TypeError do
|
21
|
-
Node.new([])
|
22
|
-
end
|
23
|
-
|
24
|
-
assert_raises TypeError do
|
25
|
-
Node.new([23])
|
26
|
-
end
|
27
|
-
|
28
|
-
assert_raises TypeError do
|
29
|
-
Node.new(nil)
|
30
|
-
end
|
31
|
-
end
|
32
|
-
|
33
|
-
def test_rendering_with_bad_type
|
34
|
-
assert_raises TypeError do
|
35
|
-
QiitaMarker.render_html("foo \n baz", 123)
|
36
|
-
end
|
37
|
-
|
38
|
-
assert_raises TypeError do
|
39
|
-
QiitaMarker.render_html("foo \n baz", :totes_fake)
|
40
|
-
end
|
41
|
-
|
42
|
-
assert_raises TypeError do
|
43
|
-
QiitaMarker.render_html("foo \n baz", [])
|
44
|
-
end
|
45
|
-
|
46
|
-
assert_raises TypeError do
|
47
|
-
QiitaMarker.render_html("foo \n baz", [23])
|
48
|
-
end
|
49
|
-
|
50
|
-
assert_raises TypeError do
|
51
|
-
QiitaMarker.render_html("foo \n baz", nil)
|
52
|
-
end
|
53
|
-
|
54
|
-
assert_raises TypeError do
|
55
|
-
QiitaMarker.render_html("foo \n baz", [:SMART, 'totes_fake'])
|
56
|
-
end
|
57
|
-
|
58
|
-
assert_raises TypeError do
|
59
|
-
QiitaMarker.render_html(123)
|
60
|
-
end
|
61
|
-
|
62
|
-
assert_raises TypeError do
|
63
|
-
QiitaMarker.render_html([123])
|
64
|
-
end
|
65
|
-
|
66
|
-
assert_raises TypeError do
|
67
|
-
QiitaMarker.render_html(nil)
|
68
|
-
end
|
69
|
-
|
70
|
-
assert_raises TypeError do
|
71
|
-
QiitaMarker.render_doc("foo \n baz", 123)
|
72
|
-
end
|
73
|
-
|
74
|
-
err = assert_raises TypeError do
|
75
|
-
QiitaMarker.render_doc("foo \n baz", :safe)
|
76
|
-
end
|
77
|
-
assert_equal('option \':safe\' does not exist for QiitaMarker::Config::OPTS[:parse]', err.message)
|
78
|
-
|
79
|
-
assert_raises TypeError do
|
80
|
-
QiitaMarker.render_doc("foo \n baz", :totes_fake)
|
81
|
-
end
|
82
|
-
|
83
|
-
assert_raises TypeError do
|
84
|
-
QiitaMarker.render_doc("foo \n baz", [])
|
85
|
-
end
|
86
|
-
|
87
|
-
assert_raises TypeError do
|
88
|
-
QiitaMarker.render_doc("foo \n baz", [23])
|
89
|
-
end
|
90
|
-
|
91
|
-
assert_raises TypeError do
|
92
|
-
QiitaMarker.render_doc("foo \n baz", nil)
|
93
|
-
end
|
94
|
-
|
95
|
-
assert_raises TypeError do
|
96
|
-
QiitaMarker.render_doc("foo \n baz", [:SMART, 'totes_fake'])
|
97
|
-
end
|
98
|
-
|
99
|
-
assert_raises TypeError do
|
100
|
-
QiitaMarker.render_doc(123)
|
101
|
-
end
|
102
|
-
|
103
|
-
assert_raises TypeError do
|
104
|
-
QiitaMarker.render_doc([123])
|
105
|
-
end
|
106
|
-
|
107
|
-
assert_raises TypeError do
|
108
|
-
QiitaMarker.render_doc(nil)
|
109
|
-
end
|
110
|
-
end
|
111
|
-
|
112
|
-
def test_bad_set_string_content
|
113
|
-
assert_raises TypeError do
|
114
|
-
@doc.string_content = 123
|
115
|
-
end
|
116
|
-
end
|
117
|
-
|
118
|
-
def test_bad_walking
|
119
|
-
assert_nil @doc.parent
|
120
|
-
assert_nil @doc.previous
|
121
|
-
end
|
122
|
-
|
123
|
-
def test_bad_insertion
|
124
|
-
code = Node.new(:code)
|
125
|
-
assert_raises NodeError do
|
126
|
-
@doc.insert_before(code)
|
127
|
-
end
|
128
|
-
|
129
|
-
paragraph = Node.new(:paragraph)
|
130
|
-
assert_raises NodeError do
|
131
|
-
@doc.insert_after(paragraph)
|
132
|
-
end
|
133
|
-
|
134
|
-
document = Node.new(:document)
|
135
|
-
assert_raises NodeError do
|
136
|
-
@doc.prepend_child(document)
|
137
|
-
end
|
138
|
-
|
139
|
-
assert_raises NodeError do
|
140
|
-
@doc.append_child(document)
|
141
|
-
end
|
142
|
-
end
|
143
|
-
|
144
|
-
def test_bad_url_get
|
145
|
-
assert_raises NodeError do
|
146
|
-
@doc.url
|
147
|
-
end
|
148
|
-
end
|
149
|
-
|
150
|
-
def test_bad_url_set
|
151
|
-
assert_raises NodeError do
|
152
|
-
@doc.url = '123'
|
153
|
-
end
|
154
|
-
|
155
|
-
link = QiitaMarker.render_doc('[GitHub](https://www.github.com)').first_child.first_child
|
156
|
-
assert_raises TypeError do
|
157
|
-
link.url = 123
|
158
|
-
end
|
159
|
-
end
|
160
|
-
|
161
|
-
def test_bad_title_get
|
162
|
-
assert_raises NodeError do
|
163
|
-
@doc.title
|
164
|
-
end
|
165
|
-
end
|
166
|
-
|
167
|
-
def test_bad_title_set
|
168
|
-
assert_raises NodeError do
|
169
|
-
@doc.title = '123'
|
170
|
-
end
|
171
|
-
|
172
|
-
image = QiitaMarker.render_doc('![alt text](https://github.com/favicon.ico "Favicon")')
|
173
|
-
image = image.first_child.first_child
|
174
|
-
assert_raises TypeError do
|
175
|
-
image.title = 123
|
176
|
-
end
|
177
|
-
end
|
178
|
-
|
179
|
-
def test_bad_header_level_get
|
180
|
-
assert_raises NodeError do
|
181
|
-
@doc.header_level
|
182
|
-
end
|
183
|
-
end
|
184
|
-
|
185
|
-
def test_bad_header_level_set
|
186
|
-
assert_raises NodeError do
|
187
|
-
@doc.header_level = 1
|
188
|
-
end
|
189
|
-
|
190
|
-
header = QiitaMarker.render_doc('### Header Three').first_child
|
191
|
-
assert_raises TypeError do
|
192
|
-
header.header_level = '123'
|
193
|
-
end
|
194
|
-
end
|
195
|
-
|
196
|
-
def test_bad_list_type_get
|
197
|
-
assert_raises NodeError do
|
198
|
-
@doc.list_type
|
199
|
-
end
|
200
|
-
end
|
201
|
-
|
202
|
-
def test_bad_list_type_set
|
203
|
-
assert_raises NodeError do
|
204
|
-
@doc.list_type = :bullet_list
|
205
|
-
end
|
206
|
-
|
207
|
-
ul_list = QiitaMarker.render_doc("* Bullet\n*Bullet").first_child
|
208
|
-
assert_raises NodeError do
|
209
|
-
ul_list.list_type = :fake
|
210
|
-
end
|
211
|
-
assert_raises TypeError do
|
212
|
-
ul_list.list_type = 1234
|
213
|
-
end
|
214
|
-
end
|
215
|
-
|
216
|
-
def test_bad_list_start_get
|
217
|
-
assert_raises NodeError do
|
218
|
-
@doc.list_start
|
219
|
-
end
|
220
|
-
end
|
221
|
-
|
222
|
-
def test_bad_list_start_set
|
223
|
-
assert_raises NodeError do
|
224
|
-
@doc.list_start = 12
|
225
|
-
end
|
226
|
-
|
227
|
-
ol_list = QiitaMarker.render_doc("1. One\n2. Two").first_child
|
228
|
-
assert_raises TypeError do
|
229
|
-
ol_list.list_start = :fake
|
230
|
-
end
|
231
|
-
end
|
232
|
-
|
233
|
-
def test_bad_list_tight_get
|
234
|
-
assert_raises NodeError do
|
235
|
-
@doc.list_tight
|
236
|
-
end
|
237
|
-
end
|
238
|
-
|
239
|
-
def test_bad_list_tight_set
|
240
|
-
assert_raises NodeError do
|
241
|
-
@doc.list_tight = false
|
242
|
-
end
|
243
|
-
end
|
244
|
-
|
245
|
-
def test_bad_fence_info_get
|
246
|
-
assert_raises NodeError do
|
247
|
-
@doc.fence_info
|
248
|
-
end
|
249
|
-
end
|
250
|
-
|
251
|
-
def test_bad_fence_info_set
|
252
|
-
assert_raises NodeError do
|
253
|
-
@doc.fence_info = 'ruby'
|
254
|
-
end
|
255
|
-
|
256
|
-
fence = QiitaMarker.render_doc("``` ruby\nputs 'wow'\n```").first_child
|
257
|
-
assert_raises TypeError do
|
258
|
-
fence.fence_info = 123
|
259
|
-
end
|
260
|
-
end
|
261
|
-
end
|
262
|
-
end
|
data/test/test_node.rb
DELETED
@@ -1,89 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'test_helper'
|
4
|
-
|
5
|
-
class TestNode < Minitest::Test
|
6
|
-
def setup
|
7
|
-
@doc = QiitaMarker.render_doc('Hi *there*, I am mostly text!')
|
8
|
-
end
|
9
|
-
|
10
|
-
def test_walk
|
11
|
-
nodes = []
|
12
|
-
@doc.walk do |node|
|
13
|
-
nodes << node.type
|
14
|
-
end
|
15
|
-
assert_equal %i[document paragraph text emph text text], nodes
|
16
|
-
end
|
17
|
-
|
18
|
-
def test_each
|
19
|
-
nodes = []
|
20
|
-
@doc.first_child.each do |node|
|
21
|
-
nodes << node.type
|
22
|
-
end
|
23
|
-
assert_equal %i[text emph text], nodes
|
24
|
-
end
|
25
|
-
|
26
|
-
def test_deprecated_each_child
|
27
|
-
nodes = []
|
28
|
-
_, err = capture_io do
|
29
|
-
@doc.first_child.each_child do |node|
|
30
|
-
nodes << node.type
|
31
|
-
end
|
32
|
-
end
|
33
|
-
assert_equal %i[text emph text], nodes
|
34
|
-
assert_match(/`each_child` is deprecated/, err)
|
35
|
-
end
|
36
|
-
|
37
|
-
def test_select
|
38
|
-
nodes = @doc.first_child.select { |node| node.type == :text }
|
39
|
-
assert_equal QiitaMarker::Node, nodes.first.class
|
40
|
-
assert_equal %i[text text], nodes.map(&:type)
|
41
|
-
end
|
42
|
-
|
43
|
-
def test_map
|
44
|
-
nodes = @doc.first_child.map(&:type)
|
45
|
-
assert_equal %i[text emph text], nodes
|
46
|
-
end
|
47
|
-
|
48
|
-
def test_insert_illegal
|
49
|
-
assert_raises NodeError do
|
50
|
-
@doc.insert_before(@doc)
|
51
|
-
end
|
52
|
-
end
|
53
|
-
|
54
|
-
def test_to_html
|
55
|
-
assert_equal "<p>Hi <em>there</em>, I am mostly text!</p>\n", @doc.to_html
|
56
|
-
end
|
57
|
-
|
58
|
-
def test_html_renderer
|
59
|
-
renderer = HtmlRenderer.new
|
60
|
-
result = renderer.render(@doc)
|
61
|
-
assert_equal "<p>Hi <em>there</em>, I am mostly text!</p>\n", result
|
62
|
-
end
|
63
|
-
|
64
|
-
def test_walk_and_set_string_content
|
65
|
-
@doc.walk do |node|
|
66
|
-
node.string_content = 'world' if node.type == :text && node.string_content == 'there'
|
67
|
-
end
|
68
|
-
result = HtmlRenderer.new.render(@doc)
|
69
|
-
assert_equal "<p>Hi <em>world</em>, I am mostly text!</p>\n", result
|
70
|
-
end
|
71
|
-
|
72
|
-
def test_walk_and_delete_node
|
73
|
-
@doc.walk do |node|
|
74
|
-
if node.type == :emph
|
75
|
-
node.insert_before(node.first_child)
|
76
|
-
node.delete
|
77
|
-
end
|
78
|
-
end
|
79
|
-
assert_equal "<p>Hi there, I am mostly text!</p>\n", @doc.to_html
|
80
|
-
end
|
81
|
-
|
82
|
-
def test_inspect
|
83
|
-
assert_match(/#<QiitaMarker::Node\(document\):/, @doc.inspect)
|
84
|
-
end
|
85
|
-
|
86
|
-
def test_pretty_print
|
87
|
-
assert_match(/#<QiitaMarker::Node\(document\):/, PP.pp(@doc, +''))
|
88
|
-
end
|
89
|
-
end
|
data/test/test_options.rb
DELETED
@@ -1,37 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'test_helper'
|
4
|
-
|
5
|
-
class TestExtensions < Minitest::Test
|
6
|
-
def test_full_info_string
|
7
|
-
md = <<~MD
|
8
|
-
```ruby
|
9
|
-
module Foo
|
10
|
-
```
|
11
|
-
MD
|
12
|
-
|
13
|
-
QiitaMarker.render_html(md, :FULL_INFO_STRING).tap do |out|
|
14
|
-
assert_includes out, '<pre><code class="language-ruby">'
|
15
|
-
end
|
16
|
-
|
17
|
-
md = <<~MD
|
18
|
-
```ruby my info string
|
19
|
-
module Foo
|
20
|
-
```
|
21
|
-
MD
|
22
|
-
|
23
|
-
QiitaMarker.render_html(md, :FULL_INFO_STRING).tap do |out|
|
24
|
-
assert_includes out, '<pre><code class="language-ruby" data-meta="my info string">'
|
25
|
-
end
|
26
|
-
|
27
|
-
md = <<~MD
|
28
|
-
```ruby my \x00 string
|
29
|
-
module Foo
|
30
|
-
```
|
31
|
-
MD
|
32
|
-
|
33
|
-
QiitaMarker.render_html(md, :FULL_INFO_STRING).tap do |out|
|
34
|
-
assert_includes out, %(<pre><code class="language-ruby" data-meta="my � string">)
|
35
|
-
end
|
36
|
-
end
|
37
|
-
end
|
@@ -1,94 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'test_helper'
|
4
|
-
require 'minitest/benchmark' if ENV['BENCH']
|
5
|
-
|
6
|
-
def markdown(str)
|
7
|
-
QiitaMarker.render_doc(str).to_html
|
8
|
-
end
|
9
|
-
|
10
|
-
# list of pairs consisting of input and a regex that must match the output.
|
11
|
-
pathological = {
|
12
|
-
'nested strong emph' =>
|
13
|
-
["#{'*a **a ' * 65_000}b#{' a** a*' * 65_000}",
|
14
|
-
Regexp.compile('(<em>a <strong>a ){65_000}b( a</strong> a</em>){65_000}')],
|
15
|
-
'many emph closers with no openers' =>
|
16
|
-
[('a_ ' * 65_000),
|
17
|
-
Regexp.compile('(a[_] ){64999}a_')],
|
18
|
-
'many emph openers with no closers' =>
|
19
|
-
[('_a ' * 65_000),
|
20
|
-
Regexp.compile('(_a ){64999}_a')],
|
21
|
-
'many link closers with no openers' =>
|
22
|
-
[('a]' * 65_000),
|
23
|
-
Regexp.compile('(a\]){65_000}')],
|
24
|
-
'many link openers with no closers' =>
|
25
|
-
[('[a' * 65_000),
|
26
|
-
Regexp.compile('(\[a){65_000}')],
|
27
|
-
'mismatched openers and closers' =>
|
28
|
-
[('*a_ ' * 50_000),
|
29
|
-
Regexp.compile('([*]a[_] ){49999}[*]a_')],
|
30
|
-
'link openers and emph closers' =>
|
31
|
-
[('[ a_' * 50_000),
|
32
|
-
Regexp.compile('(\[ a_){50000}')],
|
33
|
-
'hard link/emph case' =>
|
34
|
-
['**x [a*b**c*](d)',
|
35
|
-
Regexp.compile('\\*\\*x <a href=\'d\'>a<em>b</em><em>c</em></a>')],
|
36
|
-
'nested brackets' =>
|
37
|
-
["#{'[' * 50_000}a#{']' * 50_000}",
|
38
|
-
Regexp.compile('\[{50000}a\]{50000}')],
|
39
|
-
'nested block quotes' =>
|
40
|
-
["#{'> ' * 50_000}a",
|
41
|
-
Regexp.compile('(<blockquote>\n){50000}')],
|
42
|
-
'U+0000 in input' =>
|
43
|
-
['abc\u0000de\u0000',
|
44
|
-
Regexp.compile('abc\ufffd?de\ufffd?')]
|
45
|
-
}
|
46
|
-
|
47
|
-
pathological.each_pair do |name, description|
|
48
|
-
define_method("test_#{name}") do
|
49
|
-
input, = description
|
50
|
-
assert markdown(input)
|
51
|
-
end
|
52
|
-
end
|
53
|
-
|
54
|
-
if ENV['BENCH']
|
55
|
-
class PathologicalInputsPerformanceTest < Minitest::Benchmark
|
56
|
-
def test_bench_pathological_one
|
57
|
-
assert_performance_linear 0.99 do |n|
|
58
|
-
star = '*' * (n * 10)
|
59
|
-
markdown("#{star}#{star}hi#{star}#{star}")
|
60
|
-
end
|
61
|
-
end
|
62
|
-
|
63
|
-
def test_bench_pathological_two
|
64
|
-
assert_performance_linear 0.99 do |n|
|
65
|
-
c = '`t`t`t`t`t`t' * (n * 10)
|
66
|
-
markdown(c)
|
67
|
-
end
|
68
|
-
end
|
69
|
-
|
70
|
-
def test_bench_pathological_three
|
71
|
-
assert_performance_linear 0.99 do |n|
|
72
|
-
markdown(" [a]: #{'A' * n}\n\n#{'[a][]' * n}\n")
|
73
|
-
end
|
74
|
-
end
|
75
|
-
|
76
|
-
def test_bench_pathological_four
|
77
|
-
assert_performance_linear 0.5 do |n|
|
78
|
-
markdown("#{'[' * n}a#{']' * n}")
|
79
|
-
end
|
80
|
-
end
|
81
|
-
|
82
|
-
def test_bench_pathological_five
|
83
|
-
assert_performance_linear 0.99 do |n|
|
84
|
-
markdown("#{'**a *a ' * n}#{'a* a**' * n}")
|
85
|
-
end
|
86
|
-
end
|
87
|
-
|
88
|
-
def test_bench_unbound_recursion
|
89
|
-
assert_performance_linear 0.99 do |n|
|
90
|
-
markdown("#{'[' * n}foo#{'](bar)' * n}")
|
91
|
-
end
|
92
|
-
end
|
93
|
-
end
|
94
|
-
end
|
data/test/test_plaintext.rb
DELETED
@@ -1,46 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'test_helper'
|
4
|
-
|
5
|
-
class TestPlaintext < Minitest::Test
|
6
|
-
def setup
|
7
|
-
@markdown = <<~MD
|
8
|
-
Hi *there*!
|
9
|
-
|
10
|
-
1. I am a numeric list.
|
11
|
-
2. I continue the list.
|
12
|
-
* Suddenly, an unordered list!
|
13
|
-
* What fun!
|
14
|
-
|
15
|
-
Okay, _enough_.
|
16
|
-
|
17
|
-
| a | b |
|
18
|
-
| --- | --- |
|
19
|
-
| c | d |
|
20
|
-
MD
|
21
|
-
end
|
22
|
-
|
23
|
-
def render_doc(doc)
|
24
|
-
QiitaMarker.render_doc(doc, :DEFAULT, %i[table])
|
25
|
-
end
|
26
|
-
|
27
|
-
def test_to_commonmark
|
28
|
-
compare = render_doc(@markdown).to_plaintext
|
29
|
-
|
30
|
-
assert_equal <<~PLAINTEXT, compare
|
31
|
-
Hi there!
|
32
|
-
|
33
|
-
1. I am a numeric list.
|
34
|
-
2. I continue the list.
|
35
|
-
|
36
|
-
- Suddenly, an unordered list!
|
37
|
-
- What fun!
|
38
|
-
|
39
|
-
Okay, enough.
|
40
|
-
|
41
|
-
| a | b |
|
42
|
-
| --- | --- |
|
43
|
-
| c | d |
|
44
|
-
PLAINTEXT
|
45
|
-
end
|
46
|
-
end
|
@@ -1,26 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require('test_helper')
|
4
|
-
|
5
|
-
class TestQfmCodeDataMetadata < Minitest::Test
|
6
|
-
def setup
|
7
|
-
text = <<~MD
|
8
|
-
```ruby:example.rb
|
9
|
-
puts :foo
|
10
|
-
```
|
11
|
-
MD
|
12
|
-
@doc = QiitaMarker.render_doc(text, :DEFAULT, [])
|
13
|
-
@expected = <<~HTML
|
14
|
-
<pre><code data-metadata="ruby:example.rb">puts :foo
|
15
|
-
</code></pre>
|
16
|
-
HTML
|
17
|
-
end
|
18
|
-
|
19
|
-
def test_to_html
|
20
|
-
assert_equal(@expected, @doc.to_html(:CODE_DATA_METADATA))
|
21
|
-
end
|
22
|
-
|
23
|
-
def test_html_renderer
|
24
|
-
assert_equal(@expected, QiitaMarker::HtmlRenderer.new(options: :CODE_DATA_METADATA).render(@doc))
|
25
|
-
end
|
26
|
-
end
|
@@ -1,23 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require('test_helper')
|
4
|
-
|
5
|
-
class TestQfmCustomBlock < Minitest::Test
|
6
|
-
def setup
|
7
|
-
text = <<~MD
|
8
|
-
:::foo bar
|
9
|
-
message
|
10
|
-
:::
|
11
|
-
MD
|
12
|
-
@doc = QiitaMarker.render_doc(text, :DEFAULT, %i[custom_block])
|
13
|
-
@expected = <<~HTML
|
14
|
-
<div data-type="customblock" data-metadata="foo bar">
|
15
|
-
<p>message</p>
|
16
|
-
</div>
|
17
|
-
HTML
|
18
|
-
end
|
19
|
-
|
20
|
-
def test_to_html
|
21
|
-
assert_equal(@expected, @doc.to_html(:DEFAULT, %i[custom_block]))
|
22
|
-
end
|
23
|
-
end
|
@@ -1,60 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'test_helper'
|
4
|
-
|
5
|
-
class TestQfmMentionNoEmphasis < Minitest::Test
|
6
|
-
describe 'with mention_no_emphasis option' do
|
7
|
-
[
|
8
|
-
['@_username_', false],
|
9
|
-
['@__username__', false],
|
10
|
-
['@___username___', false],
|
11
|
-
['@user__name__', false],
|
12
|
-
['@some__user__name__', false],
|
13
|
-
[' @_username_', false],
|
14
|
-
['あ@_username_', false],
|
15
|
-
['A@_username_', true],
|
16
|
-
['@*username*', true],
|
17
|
-
['_foo_', true],
|
18
|
-
['_', false],
|
19
|
-
['_foo @username_', false],
|
20
|
-
['__foo @username__', false],
|
21
|
-
['___foo @username___', false]
|
22
|
-
].each do |text, emphasize|
|
23
|
-
describe "with text #{text.inspect}" do
|
24
|
-
if emphasize
|
25
|
-
it 'emphasizes the text' do
|
26
|
-
QiitaMarker.render_html(text, :MENTION_NO_EMPHASIS).tap do |out|
|
27
|
-
assert_match(/(<em>|<strong>)/, out.chomp)
|
28
|
-
end
|
29
|
-
end
|
30
|
-
else
|
31
|
-
it 'does not emphasize the text' do
|
32
|
-
QiitaMarker.render_html(text, :MENTION_NO_EMPHASIS).tap do |out|
|
33
|
-
assert_match "<p>#{text.strip}</p>", out.chomp
|
34
|
-
end
|
35
|
-
end
|
36
|
-
end
|
37
|
-
end
|
38
|
-
end
|
39
|
-
end
|
40
|
-
|
41
|
-
describe 'without mention_no_emphasis option' do
|
42
|
-
describe 'with text "@_username_"' do
|
43
|
-
text = '@_username_'
|
44
|
-
it 'emphasizes the text' do
|
45
|
-
QiitaMarker.render_html(text, :DEFAULT, %i[]).tap do |out|
|
46
|
-
assert_match(/<em>/, out.chomp)
|
47
|
-
end
|
48
|
-
end
|
49
|
-
end
|
50
|
-
|
51
|
-
describe 'with text "_foo @username_"' do
|
52
|
-
text = '_foo @username_'
|
53
|
-
it 'emphasizes the text' do
|
54
|
-
QiitaMarker.render_html(text, :DEFAULT, %i[]).tap do |out|
|
55
|
-
assert_match(/<em>/, out.chomp)
|
56
|
-
end
|
57
|
-
end
|
58
|
-
end
|
59
|
-
end
|
60
|
-
end
|
data/test/test_renderer.rb
DELETED
@@ -1,47 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'test_helper'
|
4
|
-
|
5
|
-
class TestRenderer < Minitest::Test
|
6
|
-
def setup
|
7
|
-
@doc = QiitaMarker.render_doc('Hi *there*')
|
8
|
-
end
|
9
|
-
|
10
|
-
def test_html_renderer
|
11
|
-
renderer = HtmlRenderer.new
|
12
|
-
result = renderer.render(@doc)
|
13
|
-
assert_equal "<p>Hi <em>there</em></p>\n", result
|
14
|
-
end
|
15
|
-
|
16
|
-
def test_multiple_tables
|
17
|
-
content = <<~DOC
|
18
|
-
| Input | Expected | Actual |
|
19
|
-
| ----------- | ---------------- | --------- |
|
20
|
-
| One | Two | Three |
|
21
|
-
|
22
|
-
| Header | Row | Example |
|
23
|
-
| :------: | ---: | :------ |
|
24
|
-
| Foo | Bar | Baz |
|
25
|
-
DOC
|
26
|
-
doc = QiitaMarker.render_doc(content, :DEFAULT, %i[autolink table tagfilter])
|
27
|
-
results = QiitaMarker::HtmlRenderer.new.render(doc)
|
28
|
-
assert_equal 2, results.scan(/<tbody>/).size
|
29
|
-
end
|
30
|
-
|
31
|
-
def test_escape_html_encoding
|
32
|
-
my_renderer = Class.new(HtmlRenderer) do
|
33
|
-
attr_reader :input_encoding, :output_encoding
|
34
|
-
|
35
|
-
def text(node)
|
36
|
-
@input_encoding = node.string_content.encoding
|
37
|
-
escape_html(node.string_content).tap do |escaped|
|
38
|
-
@output_encoding = escaped.encoding
|
39
|
-
end
|
40
|
-
end
|
41
|
-
end
|
42
|
-
|
43
|
-
renderer = my_renderer.new
|
44
|
-
assert_equal Encoding::UTF_8, renderer.render(@doc).encoding
|
45
|
-
assert_equal renderer.input_encoding, renderer.output_encoding
|
46
|
-
end
|
47
|
-
end
|