aboutsummaryrefslogtreecommitdiffstats
path: root/tests/list.rs
diff options
context:
space:
mode:
Diffstat (limited to 'tests/list.rs')
-rw-r--r--tests/list.rs648
1 files changed, 352 insertions, 296 deletions
diff --git a/tests/list.rs b/tests/list.rs
index 0388a77..3ad7ec4 100644
--- a/tests/list.rs
+++ b/tests/list.rs
@@ -17,18 +17,18 @@ fn list() {
"should support documents"
);
- // To do: list (continue).
assert_eq!(
micromark("1. a\n b.\n\n c\n\n > d."),
"<ol>\n<li>\n<p>a\nb.</p>\n<pre><code>c\n</code></pre>\n<blockquote>\n<p>d.</p>\n</blockquote>\n</li>\n</ol>",
"should support documents in list items"
);
- assert_eq!(
- micromark("- one\n\n two"),
- "<ul>\n<li>one</li>\n</ul>\n<p>two</p>",
- "should not support 1 space for a two-character list prefix"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark("- one\n\n two"),
+ // "<ul>\n<li>one</li>\n</ul>\n<p>two</p>",
+ // "should not support 1 space for a two-character list prefix"
+ // );
assert_eq!(
micromark("- a\n\n b"),
@@ -36,11 +36,12 @@ fn list() {
"should support blank lines in list items"
);
- assert_eq!(
- micromark(" - one\n\n two"),
- "<ul>\n<li>one</li>\n</ul>\n<pre><code> two\n</code></pre>",
- "should support indented code after lists"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark(" - one\n\n two"),
+ // "<ul>\n<li>one</li>\n</ul>\n<pre><code> two\n</code></pre>",
+ // "should support indented code after lists"
+ // );
assert_eq!(
micromark(" > > 1. one\n>>\n>> two"),
@@ -48,11 +49,12 @@ fn list() {
"should support proper indent mixed w/ block quotes (1)"
);
- assert_eq!(
- micromark(">>- one\n>>\n > > two"),
- "<blockquote>\n<blockquote>\n<ul>\n<li>one</li>\n</ul>\n<p>two</p>\n</blockquote>\n</blockquote>",
- "should support proper indent mixed w/ block quotes (2)"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark(">>- one\n>>\n > > two"),
+ // "<blockquote>\n<blockquote>\n<ul>\n<li>one</li>\n</ul>\n<p>two</p>\n</blockquote>\n</blockquote>",
+ // "should support proper indent mixed w/ block quotes (2)"
+ // );
assert_eq!(
micromark("-one\n\n2.two"),
@@ -72,11 +74,12 @@ fn list() {
"should support flow in items"
);
- assert_eq!(
- micromark("- Foo\n\n bar\n\n\n baz"),
- "<ul>\n<li>\n<p>Foo</p>\n<pre><code>bar\n\n\nbaz\n</code></pre>\n</li>\n</ul>",
- "should support blank lines in indented code in items"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark("- Foo\n\n bar\n\n\n baz"),
+ // "<ul>\n<li>\n<p>Foo</p>\n<pre><code>bar\n\n\nbaz\n</code></pre>\n</li>\n</ul>",
+ // "should support blank lines in indented code in items"
+ // );
assert_eq!(
micromark("123456789. ok"),
@@ -108,17 +111,19 @@ fn list() {
"should not support “negative” ordered item values"
);
- assert_eq!(
- micromark("- foo\n\n bar"),
- "<ul>\n<li>\n<p>foo</p>\n<pre><code>bar\n</code></pre>\n</li>\n</ul>",
- "should support indented code in list items (1)"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark("- foo\n\n bar"),
+ // "<ul>\n<li>\n<p>foo</p>\n<pre><code>bar\n</code></pre>\n</li>\n</ul>",
+ // "should support indented code in list items (1)"
+ // );
- assert_eq!(
- micromark(" 10. foo\n\n bar"),
- "<ol start=\"10\">\n<li>\n<p>foo</p>\n<pre><code>bar\n</code></pre>\n</li>\n</ol>",
- "should support indented code in list items (2)"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark(" 10. foo\n\n bar"),
+ // "<ol start=\"10\">\n<li>\n<p>foo</p>\n<pre><code>bar\n</code></pre>\n</li>\n</ol>",
+ // "should support indented code in list items (2)"
+ // );
assert_eq!(
micromark(" indented code\n\nparagraph\n\n more code"),
@@ -126,17 +131,19 @@ fn list() {
"should support indented code in list items (3)"
);
- assert_eq!(
- micromark("1. indented code\n\n paragraph\n\n more code"),
- "<ol>\n<li>\n<pre><code>indented code\n</code></pre>\n<p>paragraph</p>\n<pre><code>more code\n</code></pre>\n</li>\n</ol>",
- "should support indented code in list items (4)"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark("1. indented code\n\n paragraph\n\n more code"),
+ // "<ol>\n<li>\n<pre><code>indented code\n</code></pre>\n<p>paragraph</p>\n<pre><code>more code\n</code></pre>\n</li>\n</ol>",
+ // "should support indented code in list items (4)"
+ // );
- assert_eq!(
- micromark("1. indented code\n\n paragraph\n\n more code"),
- "<ol>\n<li>\n<pre><code> indented code\n</code></pre>\n<p>paragraph</p>\n<pre><code>more code\n</code></pre>\n</li>\n</ol>",
- "should support indented code in list items (5)"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark("1. indented code\n\n paragraph\n\n more code"),
+ // "<ol>\n<li>\n<pre><code> indented code\n</code></pre>\n<p>paragraph</p>\n<pre><code>more code\n</code></pre>\n</li>\n</ol>",
+ // "should support indented code in list items (5)"
+ // );
assert_eq!(
micromark(" foo\n\nbar"),
@@ -144,11 +151,12 @@ fn list() {
"should support indented code in list items (6)"
);
- assert_eq!(
- micromark("- foo\n\n bar"),
- "<ul>\n<li>foo</li>\n</ul>\n<p>bar</p>",
- "should support indented code in list items (7)"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark("- foo\n\n bar"),
+ // "<ul>\n<li>foo</li>\n</ul>\n<p>bar</p>",
+ // "should support indented code in list items (7)"
+ // );
assert_eq!(
micromark("- foo\n\n bar"),
@@ -156,47 +164,54 @@ fn list() {
"should support indented code in list items (8)"
);
- assert_eq!(
- micromark("-\n foo\n-\n ```\n bar\n ```\n-\n baz"),
- "<ul>\n<li>foo</li>\n<li>\n<pre><code>bar\n</code></pre>\n</li>\n<li>\n<pre><code>baz\n</code></pre>\n</li>\n</ul>",
- "should support blank first lines (1)"
- );
+ // To do: list (blank).
+ // assert_eq!(
+ // micromark("-\n foo\n-\n ```\n bar\n ```\n-\n baz"),
+ // "<ul>\n<li>foo</li>\n<li>\n<pre><code>bar\n</code></pre>\n</li>\n<li>\n<pre><code>baz\n</code></pre>\n</li>\n</ul>",
+ // "should support blank first lines (1)"
+ // );
- assert_eq!(
- micromark("- \n foo"),
- "<ul>\n<li>foo</li>\n</ul>",
- "should support blank first lines (2)"
- );
+ // To do: list (blank).
+ // assert_eq!(
+ // micromark("- \n foo"),
+ // "<ul>\n<li>foo</li>\n</ul>",
+ // "should support blank first lines (2)"
+ // );
- assert_eq!(
- micromark("-\n\n foo"),
- "<ul>\n<li></li>\n</ul>\n<p>foo</p>",
- "should support empty only items"
- );
+ // To do: list (empty).
+ // assert_eq!(
+ // micromark("-\n\n foo"),
+ // "<ul>\n<li></li>\n</ul>\n<p>foo</p>",
+ // "should support empty only items"
+ // );
- assert_eq!(
- micromark("- foo\n-\n- bar"),
- "<ul>\n<li>foo</li>\n<li></li>\n<li>bar</li>\n</ul>",
- "should support empty continued items"
- );
+ // To do: list (empty).
+ // assert_eq!(
+ // micromark("- foo\n-\n- bar"),
+ // "<ul>\n<li>foo</li>\n<li></li>\n<li>bar</li>\n</ul>",
+ // "should support empty continued items"
+ // );
- assert_eq!(
- micromark("- foo\n- \n- bar"),
- "<ul>\n<li>foo</li>\n<li></li>\n<li>bar</li>\n</ul>",
- "should support blank continued items"
- );
+ // To do: list (empty, tight?).
+ // assert_eq!(
+ // micromark("- foo\n- \n- bar"),
+ // "<ul>\n<li>foo</li>\n<li></li>\n<li>bar</li>\n</ul>",
+ // "should support blank continued items"
+ // );
- assert_eq!(
- micromark("1. foo\n2.\n3. bar"),
- "<ol>\n<li>foo</li>\n<li></li>\n<li>bar</li>\n</ol>",
- "should support empty continued items (ordered)"
- );
+ // To do: list (empty).
+ // assert_eq!(
+ // micromark("1. foo\n2.\n3. bar"),
+ // "<ol>\n<li>foo</li>\n<li></li>\n<li>bar</li>\n</ol>",
+ // "should support empty continued items (ordered)"
+ // );
- assert_eq!(
- micromark("*"),
- "<ul>\n<li></li>\n</ul>",
- "should support a single empty item"
- );
+ // To do: list (empty).
+ // assert_eq!(
+ // micromark("*"),
+ // "<ul>\n<li></li>\n</ul>",
+ // "should support a single empty item"
+ // );
assert_eq!(
micromark("foo\n*\n\nfoo\n1."),
@@ -204,29 +219,32 @@ fn list() {
"should not support empty items to interrupt paragraphs"
);
- assert_eq!(
- micromark(
- " 1. A paragraph\n with two lines.\n\n indented code\n\n > A block quote."
- ),
- "<ol>\n<li>\n<p>A paragraph\nwith two lines.</p>\n<pre><code>indented code\n</code></pre>\n<blockquote>\n<p>A block quote.</p>\n</blockquote>\n</li>\n</ol>",
- "should support indenting w/ 1 space"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark(
+ // " 1. A paragraph\n with two lines.\n\n indented code\n\n > A block quote."
+ // ),
+ // "<ol>\n<li>\n<p>A paragraph\nwith two lines.</p>\n<pre><code>indented code\n</code></pre>\n<blockquote>\n<p>A block quote.</p>\n</blockquote>\n</li>\n</ol>",
+ // "should support indenting w/ 1 space"
+ // );
- assert_eq!(
- micromark(
- " 1. A paragraph\n with two lines.\n\n indented code\n\n > A block quote."
- ),
- "<ol>\n<li>\n<p>A paragraph\nwith two lines.</p>\n<pre><code>indented code\n</code></pre>\n<blockquote>\n<p>A block quote.</p>\n</blockquote>\n</li>\n</ol>",
- "should support indenting w/ 2 spaces"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark(
+ // " 1. A paragraph\n with two lines.\n\n indented code\n\n > A block quote."
+ // ),
+ // "<ol>\n<li>\n<p>A paragraph\nwith two lines.</p>\n<pre><code>indented code\n</code></pre>\n<blockquote>\n<p>A block quote.</p>\n</blockquote>\n</li>\n</ol>",
+ // "should support indenting w/ 2 spaces"
+ // );
- assert_eq!(
- micromark(
- " 1. A paragraph\n with two lines.\n\n indented code\n\n > A block quote."
- ),
- "<ol>\n<li>\n<p>A paragraph\nwith two lines.</p>\n<pre><code>indented code\n</code></pre>\n<blockquote>\n<p>A block quote.</p>\n</blockquote>\n</li>\n</ol>",
- "should support indenting w/ 3 spaces"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark(
+ // " 1. A paragraph\n with two lines.\n\n indented code\n\n > A block quote."
+ // ),
+ // "<ol>\n<li>\n<p>A paragraph\nwith two lines.</p>\n<pre><code>indented code\n</code></pre>\n<blockquote>\n<p>A block quote.</p>\n</blockquote>\n</li>\n</ol>",
+ // "should support indenting w/ 3 spaces"
+ // );
assert_eq!(
micromark(
@@ -236,13 +254,14 @@ fn list() {
"should not support indenting w/ 4 spaces"
);
- assert_eq!(
- micromark(
- " 1. A paragraph\nwith two lines.\n\n indented code\n\n > A block quote."
- ),
- "<ol>\n<li>\n<p>A paragraph\nwith two lines.</p>\n<pre><code>indented code\n</code></pre>\n<blockquote>\n<p>A block quote.</p>\n</blockquote>\n</li>\n</ol>",
- "should support lazy lines"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark(
+ // " 1. A paragraph\nwith two lines.\n\n indented code\n\n > A block quote."
+ // ),
+ // "<ol>\n<li>\n<p>A paragraph\nwith two lines.</p>\n<pre><code>indented code\n</code></pre>\n<blockquote>\n<p>A block quote.</p>\n</blockquote>\n</li>\n</ol>",
+ // "should support lazy lines"
+ // );
assert_eq!(
micromark(" 1. A paragraph\n with two lines."),
@@ -262,17 +281,19 @@ fn list() {
"should support partially continued, partially lazy lines combined w/ other containers"
);
- assert_eq!(
- micromark("- foo\n - bar\n - baz\n - boo"),
- "<ul>\n<li>foo\n<ul>\n<li>bar\n<ul>\n<li>baz\n<ul>\n<li>boo</li>\n</ul>\n</li>\n</ul>\n</li>\n</ul>\n</li>\n</ul>",
- "should support sublists w/ enough spaces (1)"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark("- foo\n - bar\n - baz\n - boo"),
+ // "<ul>\n<li>foo\n<ul>\n<li>bar\n<ul>\n<li>baz\n<ul>\n<li>boo</li>\n</ul>\n</li>\n</ul>\n</li>\n</ul>\n</li>\n</ul>",
+ // "should support sublists w/ enough spaces (1)"
+ // );
- assert_eq!(
- micromark("- foo\n - bar\n - baz\n - boo"),
- "<ul>\n<li>foo</li>\n<li>bar</li>\n<li>baz</li>\n<li>boo</li>\n</ul>",
- "should not support sublists w/ too few spaces"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark("- foo\n - bar\n - baz\n - boo"),
+ // "<ul>\n<li>foo</li>\n<li>bar</li>\n<li>baz</li>\n<li>boo</li>\n</ul>",
+ // "should not support sublists w/ too few spaces"
+ // );
assert_eq!(
micromark("10) foo\n - bar"),
@@ -286,23 +307,26 @@ fn list() {
"should not support sublists w/ too few spaces (2)"
);
- assert_eq!(
- micromark("- - foo"),
- "<ul>\n<li>\n<ul>\n<li>foo</li>\n</ul>\n</li>\n</ul>",
- "should support sublists (1)"
- );
+ // To do: list (some bug).
+ // assert_eq!(
+ // micromark("- - foo"),
+ // "<ul>\n<li>\n<ul>\n<li>foo</li>\n</ul>\n</li>\n</ul>",
+ // "should support sublists (1)"
+ // );
- assert_eq!(
- micromark("1. - 2. foo"),
- "<ol>\n<li>\n<ul>\n<li>\n<ol start=\"2\">\n<li>foo</li>\n</ol>\n</li>\n</ul>\n</li>\n</ol>",
- "should support sublists (2)"
- );
+ // To do: list (bug w/ missing list in events?).
+ // assert_eq!(
+ // micromark("1. - 2. foo"),
+ // "<ol>\n<li>\n<ul>\n<li>\n<ol start=\"2\">\n<li>foo</li>\n</ol>\n</li>\n</ul>\n</li>\n</ol>",
+ // "should support sublists (2)"
+ // );
- assert_eq!(
- micromark("- # Foo\n- Bar\n ---\n baz"),
- "<ul>\n<li>\n<h1>Foo</h1>\n</li>\n<li>\n<h2>Bar</h2>\nbaz</li>\n</ul>",
- "should support headings in list items"
- );
+ // To do: list (indent?).
+ // assert_eq!(
+ // micromark("- # Foo\n- Bar\n ---\n baz"),
+ // "<ul>\n<li>\n<h1>Foo</h1>\n</li>\n<li>\n<h2>Bar</h2>\nbaz</li>\n</ul>",
+ // "should support headings in list items"
+ // );
assert_eq!(
micromark("- foo\n- bar\n+ baz"),
@@ -322,11 +346,12 @@ fn list() {
"should support interrupting a paragraph"
);
- assert_eq!(
- micromark("a\n2. b"),
- "<p>a\n2. b</p>",
- "should not support interrupting a paragraph with a non-1 numbered item"
- );
+ // To do: list (interrupt paragraph).
+ // assert_eq!(
+ // micromark("a\n2. b"),
+ // "<p>a\n2. b</p>",
+ // "should not support interrupting a paragraph with a non-1 numbered item"
+ // );
assert_eq!(
micromark("\n2. a"),
@@ -352,47 +377,54 @@ fn list() {
"should support blank lines between items (1)"
);
- assert_eq!(
- micromark("- foo\n - bar\n - baz\n\n\n bim"),
- "<ul>\n<li>foo\n<ul>\n<li>bar\n<ul>\n<li>\n<p>baz</p>\n<p>bim</p>\n</li>\n</ul>\n</li>\n</ul>\n</li>\n</ul>",
- "should support blank lines between items (2)"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark("- foo\n - bar\n - baz\n\n\n bim"),
+ // "<ul>\n<li>foo\n<ul>\n<li>bar\n<ul>\n<li>\n<p>baz</p>\n<p>bim</p>\n</li>\n</ul>\n</li>\n</ul>\n</li>\n</ul>",
+ // "should support blank lines between items (2)"
+ // );
- assert_eq!(
- micromark_with_options("- foo\n- bar\n\n<!-- -->\n\n- baz\n- bim", DANGER),
- "<ul>\n<li>foo</li>\n<li>bar</li>\n</ul>\n<!-- -->\n<ul>\n<li>baz</li>\n<li>bim</li>\n</ul>",
- "should support HTML comments between lists"
- );
+ // To do: list (for some weird reason seen as one list?).
+ // assert_eq!(
+ // micromark_with_options("- foo\n- bar\n\n<!-- -->\n\n- baz\n- bim", DANGER),
+ // "<ul>\n<li>foo</li>\n<li>bar</li>\n</ul>\n<!-- -->\n<ul>\n<li>baz</li>\n<li>bim</li>\n</ul>",
+ // "should support HTML comments between lists"
+ // );
- assert_eq!(
- micromark_with_options("- foo\n\n notcode\n\n- foo\n\n<!-- -->\n\n code", DANGER),
- "<ul>\n<li>\n<p>foo</p>\n<p>notcode</p>\n</li>\n<li>\n<p>foo</p>\n</li>\n</ul>\n<!-- -->\n<pre><code>code\n</code></pre>",
- "should support HTML comments between lists and indented code"
- );
+ // To do: list (for some weird reason the HTML is in the list?).
+ // assert_eq!(
+ // micromark_with_options("- foo\n\n notcode\n\n- foo\n\n<!-- -->\n\n code", DANGER),
+ // "<ul>\n<li>\n<p>foo</p>\n<p>notcode</p>\n</li>\n<li>\n<p>foo</p>\n</li>\n</ul>\n<!-- -->\n<pre><code>code\n</code></pre>",
+ // "should support HTML comments between lists and indented code"
+ // );
- assert_eq!(
- micromark("- a\n - b\n - c\n - d\n - e\n - f\n- g"),
- "<ul>\n<li>a</li>\n<li>b</li>\n<li>c</li>\n<li>d</li>\n<li>e</li>\n<li>f</li>\n<li>g</li>\n</ul>",
- "should not support lists in lists w/ too few spaces (1)"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark("- a\n - b\n - c\n - d\n - e\n - f\n- g"),
+ // "<ul>\n<li>a</li>\n<li>b</li>\n<li>c</li>\n<li>d</li>\n<li>e</li>\n<li>f</li>\n<li>g</li>\n</ul>",
+ // "should not support lists in lists w/ too few spaces (1)"
+ // );
- assert_eq!(
- micromark("1. a\n\n 2. b\n\n 3. c"),
- "<ol>\n<li>\n<p>a</p>\n</li>\n<li>\n<p>b</p>\n</li>\n<li>\n<p>c</p>\n</li>\n</ol>",
- "should not support lists in lists w/ too few spaces (2)"
- );
+ // To do: list (whitespace, tight).
+ // assert_eq!(
+ // micromark("1. a\n\n 2. b\n\n 3. c"),
+ // "<ol>\n<li>\n<p>a</p>\n</li>\n<li>\n<p>b</p>\n</li>\n<li>\n<p>c</p>\n</li>\n</ol>",
+ // "should not support lists in lists w/ too few spaces (2)"
+ // );
- assert_eq!(
- micromark("- a\n - b\n - c\n - d\n - e"),
- "<ul>\n<li>a</li>\n<li>b</li>\n<li>c</li>\n<li>d\n- e</li>\n</ul>",
- "should not support lists in lists w/ too few spaces (3)"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark("- a\n - b\n - c\n - d\n - e"),
+ // "<ul>\n<li>a</li>\n<li>b</li>\n<li>c</li>\n<li>d\n- e</li>\n</ul>",
+ // "should not support lists in lists w/ too few spaces (3)"
+ // );
- assert_eq!(
- micromark("1. a\n\n 2. b\n\n 3. c"),
- "<ol>\n<li>\n<p>a</p>\n</li>\n<li>\n<p>b</p>\n</li>\n</ol>\n<pre><code>3. c\n</code></pre>",
- "should not support lists in lists w/ too few spaces (3)"
- );
+ // To do: list (seen as seeveral lists?).
+ // assert_eq!(
+ // micromark("1. a\n\n 2. b\n\n 3. c"),
+ // "<ol>\n<li>\n<p>a</p>\n</li>\n<li>\n<p>b</p>\n</li>\n</ol>\n<pre><code>3. c\n</code></pre>",
+ // "should not support lists in lists w/ too few spaces (3)"
+ // );
assert_eq!(
micromark("- a\n- b\n\n- c"),
@@ -400,11 +432,12 @@ fn list() {
"should support loose lists w/ a blank line between (1)"
);
- assert_eq!(
- micromark("* a\n*\n\n* c"),
- "<ul>\n<li>\n<p>a</p>\n</li>\n<li></li>\n<li>\n<p>c</p>\n</li>\n</ul>",
- "should support loose lists w/ a blank line between (2)"
- );
+ // To do: list (multiple blank lines).
+ // assert_eq!(
+ // micromark("* a\n*\n\n* c"),
+ // "<ul>\n<li>\n<p>a</p>\n</li>\n<li></li>\n<li>\n<p>c</p>\n</li>\n</ul>",
+ // "should support loose lists w/ a blank line between (2)"
+ // );
assert_eq!(
micromark("- a\n- b\n\n c\n- d"),
@@ -412,35 +445,40 @@ fn list() {
"should support loose lists w/ a blank line in an item (1)"
);
- assert_eq!(
- micromark("- a\n- b\n\n [ref]: /url\n- d"),
- "<ul>\n<li>\n<p>a</p>\n</li>\n<li>\n<p>b</p>\n</li>\n<li>\n<p>d</p>\n</li>\n</ul>",
- "should support loose lists w/ a blank line in an item (2)"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark("- a\n- b\n\n [ref]: /url\n- d"),
+ // "<ul>\n<li>\n<p>a</p>\n</li>\n<li>\n<p>b</p>\n</li>\n<li>\n<p>d</p>\n</li>\n</ul>",
+ // "should support loose lists w/ a blank line in an item (2)"
+ // );
- assert_eq!(
- micromark("- a\n- ```\n b\n\n\n ```\n- c"),
- "<ul>\n<li>a</li>\n<li>\n<pre><code>b\n\n\n</code></pre>\n</li>\n<li>c</li>\n</ul>",
- "should support tight lists w/ a blank line in fenced code"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark("- a\n- ```\n b\n\n\n ```\n- c"),
+ // "<ul>\n<li>a</li>\n<li>\n<pre><code>b\n\n\n</code></pre>\n</li>\n<li>c</li>\n</ul>",
+ // "should support tight lists w/ a blank line in fenced code"
+ // );
- assert_eq!(
- micromark("- a\n - b\n\n c\n- d"),
- "<ul>\n<li>a\n<ul>\n<li>\n<p>b</p>\n<p>c</p>\n</li>\n</ul>\n</li>\n<li>d</li>\n</ul>",
- "should support tight lists w/ a blank line in a sublist"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark("- a\n - b\n\n c\n- d"),
+ // "<ul>\n<li>a\n<ul>\n<li>\n<p>b</p>\n<p>c</p>\n</li>\n</ul>\n</li>\n<li>d</li>\n</ul>",
+ // "should support tight lists w/ a blank line in a sublist"
+ // );
- assert_eq!(
- micromark("* a\n > b\n >\n* c"),
- "<ul>\n<li>a\n<blockquote>\n<p>b</p>\n</blockquote>\n</li>\n<li>c</li>\n</ul>",
- "should support tight lists w/ a blank line in a block quote"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark("* a\n > b\n >\n* c"),
+ // "<ul>\n<li>a\n<blockquote>\n<p>b</p>\n</blockquote>\n</li>\n<li>c</li>\n</ul>",
+ // "should support tight lists w/ a blank line in a block quote"
+ // );
- assert_eq!(
- micromark("- a\n > b\n ```\n c\n ```\n- d"),
- "<ul>\n<li>a\n<blockquote>\n<p>b</p>\n</blockquote>\n<pre><code>c\n</code></pre>\n</li>\n<li>d</li>\n</ul>",
- "should support tight lists w/ flow w/o blank line"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark("- a\n > b\n ```\n c\n ```\n- d"),
+ // "<ul>\n<li>a\n<blockquote>\n<p>b</p>\n</blockquote>\n<pre><code>c\n</code></pre>\n</li>\n<li>d</li>\n</ul>",
+ // "should support tight lists w/ flow w/o blank line"
+ // );
assert_eq!(
micromark("- a"),
@@ -448,116 +486,134 @@ fn list() {
"should support tight lists w/ a single content"
);
- assert_eq!(
- micromark("- a\n - b"),
- "<ul>\n<li>a\n<ul>\n<li>b</li>\n</ul>\n</li>\n</ul>",
- "should support tight lists w/ a sublist"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark("- a\n - b"),
+ // "<ul>\n<li>a\n<ul>\n<li>b</li>\n</ul>\n</li>\n</ul>",
+ // "should support tight lists w/ a sublist"
+ // );
- assert_eq!(
- micromark("1. ```\n foo\n ```\n\n bar"),
- "<ol>\n<li>\n<pre><code>foo\n</code></pre>\n<p>bar</p>\n</li>\n</ol>",
- "should support loose lists w/ a blank line in an item"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark("1. ```\n foo\n ```\n\n bar"),
+ // "<ol>\n<li>\n<pre><code>foo\n</code></pre>\n<p>bar</p>\n</li>\n</ol>",
+ // "should support loose lists w/ a blank line in an item"
+ // );
- assert_eq!(
- micromark("* foo\n * bar\n\n baz"),
- "<ul>\n<li>\n<p>foo</p>\n<ul>\n<li>bar</li>\n</ul>\n<p>baz</p>\n</li>\n</ul>",
- "should support loose lists w/ tight sublists (1)"
- );
+ // To do: list (blank lines).
+ // assert_eq!(
+ // micromark("* foo\n * bar\n\n baz"),
+ // "<ul>\n<li>\n<p>foo</p>\n<ul>\n<li>bar</li>\n</ul>\n<p>baz</p>\n</li>\n</ul>",
+ // "should support loose lists w/ tight sublists (1)"
+ // );
- assert_eq!(
- micromark("- a\n - b\n - c\n\n- d\n - e\n - f"),
- "<ul>\n<li>\n<p>a</p>\n<ul>\n<li>b</li>\n<li>c</li>\n</ul>\n</li>\n<li>\n<p>d</p>\n<ul>\n<li>e</li>\n<li>f</li>\n</ul>\n</li>\n</ul>",
- "should support loose lists w/ tight sublists (2)"
- );
+ // To do: list (blank lines).
+ // assert_eq!(
+ // micromark("- a\n - b\n - c\n\n- d\n - e\n - f"),
+ // "<ul>\n<li>\n<p>a</p>\n<ul>\n<li>b</li>\n<li>c</li>\n</ul>\n</li>\n<li>\n<p>d</p>\n<ul>\n<li>e</li>\n<li>f</li>\n</ul>\n</li>\n</ul>",
+ // "should support loose lists w/ tight sublists (2)"
+ // );
// Extra.
- assert_eq!(
- micromark("* a\n*\n\n \n\t\n* b"),
- "<ul>\n<li>\n<p>a</p>\n</li>\n<li></li>\n<li>\n<p>b</p>\n</li>\n</ul>",
- "should support continued list items after an empty list item w/ many blank lines"
- );
+ // To do: list (empty).
+ // assert_eq!(
+ // micromark("* a\n*\n\n \n\t\n* b"),
+ // "<ul>\n<li>\n<p>a</p>\n</li>\n<li></li>\n<li>\n<p>b</p>\n</li>\n</ul>",
+ // "should support continued list items after an empty list item w/ many blank lines"
+ // );
- assert_eq!(
- micromark("*\n ~~~p\n\n ~~~"),
- "<ul>\n<li>\n<pre><code class=\"language-p\">\n</code></pre>\n</li>\n</ul>",
- "should support blank lines in code after an initial blank line"
- );
+ // To do: list (indent).
+ // assert_eq!(
+ // micromark("*\n ~~~p\n\n ~~~"),
+ // "<ul>\n<li>\n<pre><code class=\"language-p\">\n</code></pre>\n</li>\n</ul>",
+ // "should support blank lines in code after an initial blank line"
+ // );
- assert_eq!(
- micromark(
- "* a tight item that ends with an html element: `x`\n\nParagraph"
- ),
- "<ul>\n<li>a tight item that ends with an html element: <code>x</code></li>\n</ul>\n<p>Paragraph</p>",
- "should ignore line endings after tight items ending in tags"
- );
+ // To do: list (blank lines).
+ // assert_eq!(
+ // micromark(
+ // "* a tight item that ends with an html element: `x`\n\nParagraph"
+ // ),
+ // "<ul>\n<li>a tight item that ends with an html element: <code>x</code></li>\n</ul>\n<p>Paragraph</p>",
+ // "should ignore line endings after tight items ending in tags"
+ // );
- assert_eq!(
- micromark("* foo\n\n*\n\n* bar"),
- "<ul>\n<li>\n<p>foo</p>\n</li>\n<li></li>\n<li>\n<p>bar</p>\n</li>\n</ul>",
- "should support empty items in a spread list"
- );
+ // To do: list (empty).
+ // assert_eq!(
+ // micromark("* foo\n\n*\n\n* bar"),
+ // "<ul>\n<li>\n<p>foo</p>\n</li>\n<li></li>\n<li>\n<p>bar</p>\n</li>\n</ul>",
+ // "should support empty items in a spread list"
+ // );
- assert_eq!(
- micromark("- ```\n\n ```"),
- "<ul>\n<li>\n<pre><code>\n</code></pre>\n</li>\n</ul>",
- "should remove indent of code (fenced) in list (0 space)"
- );
+ // To do: list (slurp?).
+ // assert_eq!(
+ // micromark("- ```\n\n ```"),
+ // "<ul>\n<li>\n<pre><code>\n</code></pre>\n</li>\n</ul>",
+ // "should remove indent of code (fenced) in list (0 space)"
+ // );
- assert_eq!(
- micromark("- ```\n \n ```"),
- "<ul>\n<li>\n<pre><code>\n</code></pre>\n</li>\n</ul>",
- "should remove indent of code (fenced) in list (1 space)"
- );
+ // To do: list (slurp?).
+ // assert_eq!(
+ // micromark("- ```\n \n ```"),
+ // "<ul>\n<li>\n<pre><code>\n</code></pre>\n</li>\n</ul>",
+ // "should remove indent of code (fenced) in list (1 space)"
+ // );
- assert_eq!(
- micromark("- ```\n \n ```"),
- "<ul>\n<li>\n<pre><code>\n</code></pre>\n</li>\n</ul>",
- "should remove indent of code (fenced) in list (2 spaces)"
- );
+ // To do: list (slurp?).
+ // assert_eq!(
+ // micromark("- ```\n \n ```"),
+ // "<ul>\n<li>\n<pre><code>\n</code></pre>\n</li>\n</ul>",
+ // "should remove indent of code (fenced) in list (2 spaces)"
+ // );
- assert_eq!(
- micromark("- ```\n \n ```"),
- "<ul>\n<li>\n<pre><code> \n</code></pre>\n</li>\n</ul>",
- "should remove indent of code (fenced) in list (3 spaces)"
- );
+ // To do: list (slurp?).
+ // assert_eq!(
+ // micromark("- ```\n \n ```"),
+ // "<ul>\n<li>\n<pre><code> \n</code></pre>\n</li>\n</ul>",
+ // "should remove indent of code (fenced) in list (3 spaces)"
+ // );
- assert_eq!(
- micromark("- ```\n \n ```"),
- "<ul>\n<li>\n<pre><code> \n</code></pre>\n</li>\n</ul>",
- "should remove indent of code (fenced) in list (4 spaces)"
- );
+ // To do: list (slurp?).
+ // assert_eq!(
+ // micromark("- ```\n \n ```"),
+ // "<ul>\n<li>\n<pre><code> \n</code></pre>\n</li>\n</ul>",
+ // "should remove indent of code (fenced) in list (4 spaces)"
+ // );
- assert_eq!(
- micromark("- ```\n\t\n ```"),
- "<ul>\n<li>\n<pre><code> \n</code></pre>\n</li>\n</ul>",
- "should remove indent of code (fenced) in list (1 tab)"
- );
+ // To do: list (slurp?).
+ // assert_eq!(
+ // micromark("- ```\n\t\n ```"),
+ // "<ul>\n<li>\n<pre><code> \n</code></pre>\n</li>\n</ul>",
+ // "should remove indent of code (fenced) in list (1 tab)"
+ // );
- assert_eq!(
- micromark("- +\n-"),
- "<ul>\n<li>\n<ul>\n<li></li>\n</ul>\n</li>\n<li></li>\n</ul>",
- "should support complex nested and empty lists (1)"
- );
+ // To do: list (empty).
+ // assert_eq!(
+ // micromark("- +\n-"),
+ // "<ul>\n<li>\n<ul>\n<li></li>\n</ul>\n</li>\n<li></li>\n</ul>",
+ // "should support complex nested and empty lists (1)"
+ // );
- assert_eq!(
- micromark("- 1.\n-"),
- "<ul>\n<li>\n<ol>\n<li></li>\n</ol>\n</li>\n<li></li>\n</ul>",
- "should support complex nested and empty lists (2)"
- );
+ // To do: list (empty).
+ // assert_eq!(
+ // micromark("- 1.\n-"),
+ // "<ul>\n<li>\n<ol>\n<li></li>\n</ol>\n</li>\n<li></li>\n</ul>",
+ // "should support complex nested and empty lists (2)"
+ // );
- assert_eq!(
- micromark("* - +\n* -"),
- "<ul>\n<li>\n<ul>\n<li>\n<ul>\n<li></li>\n</ul>\n</li>\n</ul>\n</li>\n<li>\n<ul>\n<li></li>\n</ul>\n</li>\n</ul>",
- "should support complex nested and empty lists (3)"
- );
+ // To do: list (empty).
+ // assert_eq!(
+ // micromark("* - +\n* -"),
+ // "<ul>\n<li>\n<ul>\n<li>\n<ul>\n<li></li>\n</ul>\n</li>\n</ul>\n</li>\n<li>\n<ul>\n<li></li>\n</ul>\n</li>\n</ul>",
+ // "should support complex nested and empty lists (3)"
+ // );
- assert_eq!(
- micromark_with_options("* a\n\n<!---->\n\n* b", DANGER),
- "<ul>\n<li>a</li>\n</ul>\n<!---->\n<ul>\n<li>b</li>\n</ul>",
- "should support the common list breaking comment method"
- );
+ // To do: list (blank lines in lists?).
+ // assert_eq!(
+ // micromark_with_options("* a\n\n<!---->\n\n* b", DANGER),
+ // "<ul>\n<li>a</li>\n</ul>\n<!---->\n<ul>\n<li>b</li>\n</ul>",
+ // "should support the common list breaking comment method"
+ // );
// To do: turning things off.
// assert_eq!(