aboutsummaryrefslogtreecommitdiffstats
path: root/tests/link_resource.rs
diff options
context:
space:
mode:
Diffstat (limited to 'tests/link_resource.rs')
-rw-r--r--tests/link_resource.rs156
1 files changed, 78 insertions, 78 deletions
diff --git a/tests/link_resource.rs b/tests/link_resource.rs
index 4554d86..5f9cddc 100644
--- a/tests/link_resource.rs
+++ b/tests/link_resource.rs
@@ -1,7 +1,7 @@
-extern crate micromark;
-use micromark::{
+extern crate markdown;
+use markdown::{
mdast::{Link, Node, Paragraph, Root, Text},
- micromark, micromark_to_mdast, micromark_with_options,
+ to_html, to_html_with_options, to_mdast,
unist::Position,
CompileOptions, Options, ParseOptions,
};
@@ -19,455 +19,455 @@ fn link_resource() -> Result<(), String> {
};
assert_eq!(
- micromark("[link](/uri \"title\")"),
+ to_html("[link](/uri \"title\")"),
"<p><a href=\"/uri\" title=\"title\">link</a></p>",
"should support links"
);
assert_eq!(
- micromark("[link](/uri)"),
+ to_html("[link](/uri)"),
"<p><a href=\"/uri\">link</a></p>",
"should support links w/o title"
);
assert_eq!(
- micromark("[link]()"),
+ to_html("[link]()"),
"<p><a href=\"\">link</a></p>",
"should support links w/o destination"
);
assert_eq!(
- micromark("[link](<>)"),
+ to_html("[link](<>)"),
"<p><a href=\"\">link</a></p>",
"should support links w/ empty enclosed destination"
);
assert_eq!(
- micromark("[link](/my uri)"),
+ to_html("[link](/my uri)"),
"<p>[link](/my uri)</p>",
"should not support links w/ spaces in destination"
);
assert_eq!(
- micromark("[link](</my uri>)"),
+ to_html("[link](</my uri>)"),
"<p><a href=\"/my%20uri\">link</a></p>",
"should support links w/ spaces in enclosed destination"
);
assert_eq!(
- micromark("[link](foo\nbar)"),
+ to_html("[link](foo\nbar)"),
"<p>[link](foo\nbar)</p>",
"should not support links w/ line endings in destination"
);
assert_eq!(
- micromark_with_options("[link](<foo\nbar>)", &danger)?,
+ to_html_with_options("[link](<foo\nbar>)", &danger)?,
"<p>[link](<foo\nbar>)</p>",
"should not support links w/ line endings in enclosed destination"
);
assert_eq!(
- micromark("[a](<b)c>)"),
+ to_html("[a](<b)c>)"),
"<p><a href=\"b)c\">a</a></p>",
"should support links w/ closing parens in destination"
);
assert_eq!(
- micromark("[link](<foo\\>)"),
+ to_html("[link](<foo\\>)"),
"<p>[link](&lt;foo&gt;)</p>",
"should not support links w/ enclosed destinations w/o end"
);
assert_eq!(
- micromark_with_options("[a](<b)c\n[a](<b)c>\n[a](<b>c)", &danger)?,
+ to_html_with_options("[a](<b)c\n[a](<b)c>\n[a](<b>c)", &danger)?,
"<p>[a](&lt;b)c\n[a](&lt;b)c&gt;\n[a](<b>c)</p>",
"should not support links w/ unmatched enclosed destinations"
);
assert_eq!(
- micromark("[link](\\(foo\\))"),
+ to_html("[link](\\(foo\\))"),
"<p><a href=\"(foo)\">link</a></p>",
"should support links w/ destinations w/ escaped parens"
);
assert_eq!(
- micromark("[link](foo(and(bar)))"),
+ to_html("[link](foo(and(bar)))"),
"<p><a href=\"foo(and(bar))\">link</a></p>",
"should support links w/ destinations w/ balanced parens"
);
assert_eq!(
- micromark("[link](foo\\(and\\(bar\\))"),
+ to_html("[link](foo\\(and\\(bar\\))"),
"<p><a href=\"foo(and(bar)\">link</a></p>",
"should support links w/ destinations w/ escaped parens"
);
assert_eq!(
- micromark("[link](<foo(and(bar)>)"),
+ to_html("[link](<foo(and(bar)>)"),
"<p><a href=\"foo(and(bar)\">link</a></p>",
"should support links w/ enclosed destinations w/ parens"
);
assert_eq!(
- micromark_with_options("[link](foo\\)\\:)", &danger)?,
+ to_html_with_options("[link](foo\\)\\:)", &danger)?,
"<p><a href=\"foo):\">link</a></p>",
"should support links w/ escapes in destinations"
);
assert_eq!(
- micromark("[link](#fragment)"),
+ to_html("[link](#fragment)"),
"<p><a href=\"#fragment\">link</a></p>",
"should support links w/ destinations to fragments"
);
assert_eq!(
- micromark("[link](http://example.com#fragment)"),
+ to_html("[link](http://example.com#fragment)"),
"<p><a href=\"http://example.com#fragment\">link</a></p>",
"should support links w/ destinations to URLs w/ fragments"
);
assert_eq!(
- micromark("[link](http://example.com?foo=3#frag)"),
+ to_html("[link](http://example.com?foo=3#frag)"),
"<p><a href=\"http://example.com?foo=3#frag\">link</a></p>",
"should support links w/ destinations to URLs w/ search and fragments"
);
assert_eq!(
- micromark("[link](foo\\bar)"),
+ to_html("[link](foo\\bar)"),
"<p><a href=\"foo%5Cbar\">link</a></p>",
"should not support non-punctuation character escapes in links"
);
assert_eq!(
- micromark("[link](foo%20b&auml;)"),
+ to_html("[link](foo%20b&auml;)"),
"<p><a href=\"foo%20b%C3%A4\">link</a></p>",
"should support character references in links"
);
assert_eq!(
- micromark("[link](\"title\")"),
+ to_html("[link](\"title\")"),
"<p><a href=\"%22title%22\">link</a></p>",
"should not support links w/ only a title"
);
assert_eq!(
- micromark("[link](/url \"title\")"),
+ to_html("[link](/url \"title\")"),
"<p><a href=\"/url\" title=\"title\">link</a></p>",
"should support titles w/ double quotes"
);
assert_eq!(
- micromark("[link](/url 'title')"),
+ to_html("[link](/url 'title')"),
"<p><a href=\"/url\" title=\"title\">link</a></p>",
"should support titles w/ single quotes"
);
assert_eq!(
- micromark("[link](/url (title))"),
+ to_html("[link](/url (title))"),
"<p><a href=\"/url\" title=\"title\">link</a></p>",
"should support titles w/ parens"
);
assert_eq!(
- micromark("[link](/url \"title \\\"&quot;\")"),
+ to_html("[link](/url \"title \\\"&quot;\")"),
"<p><a href=\"/url\" title=\"title &quot;&quot;\">link</a></p>",
"should support character references and escapes in titles"
);
assert_eq!(
- micromark("[link](/url \"title\")"),
+ to_html("[link](/url \"title\")"),
"<p><a href=\"/url%C2%A0%22title%22\">link</a></p>",
"should not support unicode whitespace between destination and title"
);
assert_eq!(
- micromark("[link](/url \"title \"and\" title\")"),
+ to_html("[link](/url \"title \"and\" title\")"),
"<p>[link](/url &quot;title &quot;and&quot; title&quot;)</p>",
"should not support nested balanced quotes in title"
);
assert_eq!(
- micromark("[link](/url 'title \"and\" title')"),
+ to_html("[link](/url 'title \"and\" title')"),
"<p><a href=\"/url\" title=\"title &quot;and&quot; title\">link</a></p>",
"should support the other quotes in titles"
);
assert_eq!(
- micromark("[link]( /uri\n \"title\" )"),
+ to_html("[link]( /uri\n \"title\" )"),
"<p><a href=\"/uri\" title=\"title\">link</a></p>",
"should support whitespace around destination and title (1)"
);
assert_eq!(
- micromark("[link](\t\n/uri \"title\")"),
+ to_html("[link](\t\n/uri \"title\")"),
"<p><a href=\"/uri\" title=\"title\">link</a></p>",
"should support whitespace around destination and title (2)"
);
assert_eq!(
- micromark("[link](/uri \"title\"\t\n)"),
+ to_html("[link](/uri \"title\"\t\n)"),
"<p><a href=\"/uri\" title=\"title\">link</a></p>",
"should support whitespace around destination and title (3)"
);
assert_eq!(
- micromark("[link] (/uri)"),
+ to_html("[link] (/uri)"),
"<p>[link] (/uri)</p>",
"should not support whitespace between label and resource"
);
assert_eq!(
- micromark("[link [foo [bar]]](/uri)"),
+ to_html("[link [foo [bar]]](/uri)"),
"<p><a href=\"/uri\">link [foo [bar]]</a></p>",
"should support balanced brackets"
);
assert_eq!(
- micromark("[link] bar](/uri)"),
+ to_html("[link] bar](/uri)"),
"<p>[link] bar](/uri)</p>",
"should not support unbalanced brackets (1)"
);
assert_eq!(
- micromark("[link [bar](/uri)"),
+ to_html("[link [bar](/uri)"),
"<p>[link <a href=\"/uri\">bar</a></p>",
"should not support unbalanced brackets (2)"
);
assert_eq!(
- micromark("[link \\[bar](/uri)"),
+ to_html("[link \\[bar](/uri)"),
"<p><a href=\"/uri\">link [bar</a></p>",
"should support characer escapes"
);
assert_eq!(
- micromark("[link *foo **bar** `#`*](/uri)"),
+ to_html("[link *foo **bar** `#`*](/uri)"),
"<p><a href=\"/uri\">link <em>foo <strong>bar</strong> <code>#</code></em></a></p>",
"should support content"
);
assert_eq!(
- micromark("[![moon](moon.jpg)](/uri)"),
+ to_html("[![moon](moon.jpg)](/uri)"),
"<p><a href=\"/uri\"><img src=\"moon.jpg\" alt=\"moon\" /></a></p>",
"should support an image as content"
);
assert_eq!(
- micromark("[foo [bar](/uri)](/uri)"),
+ to_html("[foo [bar](/uri)](/uri)"),
"<p>[foo <a href=\"/uri\">bar</a>](/uri)</p>",
"should not support links in links (1)"
);
assert_eq!(
- micromark("[foo *[bar [baz](/uri)](/uri)*](/uri)"),
+ to_html("[foo *[bar [baz](/uri)](/uri)*](/uri)"),
"<p>[foo <em>[bar <a href=\"/uri\">baz</a>](/uri)</em>](/uri)</p>",
"should not support links in links (2)"
);
assert_eq!(
- micromark("![[[foo](uri1)](uri2)](uri3)"),
+ to_html("![[[foo](uri1)](uri2)](uri3)"),
"<p><img src=\"uri3\" alt=\"[foo](uri2)\" /></p>",
"should not support links in links (3)"
);
assert_eq!(
- micromark("*[foo*](/uri)"),
+ to_html("*[foo*](/uri)"),
"<p>*<a href=\"/uri\">foo*</a></p>",
"should prefer links over emphasis (1)"
);
assert_eq!(
- micromark("[foo *bar](baz*)"),
+ to_html("[foo *bar](baz*)"),
"<p><a href=\"baz*\">foo *bar</a></p>",
"should prefer links over emphasis (2)"
);
assert_eq!(
- micromark_with_options("[foo <bar attr=\"](baz)\">", &danger)?,
+ to_html_with_options("[foo <bar attr=\"](baz)\">", &danger)?,
"<p>[foo <bar attr=\"](baz)\"></p>",
"should prefer HTML over links"
);
assert_eq!(
- micromark("[foo`](/uri)`"),
+ to_html("[foo`](/uri)`"),
"<p>[foo<code>](/uri)</code></p>",
"should prefer code over links"
);
assert_eq!(
- micromark("[foo<http://example.com/?search=](uri)>"),
+ to_html("[foo<http://example.com/?search=](uri)>"),
"<p>[foo<a href=\"http://example.com/?search=%5D(uri)\">http://example.com/?search=](uri)</a></p>",
"should prefer autolinks over links"
);
assert_eq!(
- micromark("[foo<http://example.com/?search=](uri)>"),
+ to_html("[foo<http://example.com/?search=](uri)>"),
"<p>[foo<a href=\"http://example.com/?search=%5D(uri)\">http://example.com/?search=](uri)</a></p>",
"should prefer autolinks over links"
);
// Extra
assert_eq!(
- micromark("[]()"),
+ to_html("[]()"),
"<p><a href=\"\"></a></p>",
"should support an empty link"
);
// See: <https://github.com/commonmark/commonmark.js/issues/192>
assert_eq!(
- micromark("[](<> \"\")"),
+ to_html("[](<> \"\")"),
"<p><a href=\"\"></a></p>",
"should ignore an empty title"
);
assert_eq!(
- micromark_with_options("[a](<b>\"c\")", &danger)?,
+ to_html_with_options("[a](<b>\"c\")", &danger)?,
"<p>[a](<b>&quot;c&quot;)</p>",
"should require whitespace between enclosed destination and title"
);
assert_eq!(
- micromark("[](<"),
+ to_html("[](<"),
"<p>[](&lt;</p>",
"should not support an unclosed enclosed destination"
);
assert_eq!(
- micromark("[]("),
+ to_html("[]("),
"<p>[](</p>",
"should not support an unclosed destination"
);
assert_eq!(
- micromark("[](\\<)"),
+ to_html("[](\\<)"),
"<p><a href=\"%3C\"></a></p>",
"should support unenclosed link destination starting w/ escapes"
);
assert_eq!(
- micromark("[](<\\<>)"),
+ to_html("[](<\\<>)"),
"<p><a href=\"%3C\"></a></p>",
"should support enclosed link destination starting w/ escapes"
);
assert_eq!(
- micromark("[](\\"),
+ to_html("[](\\"),
"<p>[](\\</p>",
"should not support unenclosed link destination starting w/ an incorrect escape"
);
assert_eq!(
- micromark("[](<\\"),
+ to_html("[](<\\"),
"<p>[](&lt;\\</p>",
"should not support enclosed link destination starting w/ an incorrect escape"
);
assert_eq!(
- micromark("[](a \""),
+ to_html("[](a \""),
"<p>[](a &quot;</p>",
"should not support an eof in a link title (1)"
);
assert_eq!(
- micromark("[](a '"),
+ to_html("[](a '"),
"<p>[](a '</p>",
"should not support an eof in a link title (2)"
);
assert_eq!(
- micromark("[](a ("),
+ to_html("[](a ("),
"<p>[](a (</p>",
"should not support an eof in a link title (3)"
);
assert_eq!(
- micromark("[](a \"\\"),
+ to_html("[](a \"\\"),
"<p>[](a &quot;\\</p>",
"should not support an eof in a link title escape (1)"
);
assert_eq!(
- micromark("[](a '\\"),
+ to_html("[](a '\\"),
"<p>[](a '\\</p>",
"should not support an eof in a link title escape (2)"
);
assert_eq!(
- micromark("[](a (\\"),
+ to_html("[](a (\\"),
"<p>[](a (\\</p>",
"should not support an eof in a link title escape (3)"
);
assert_eq!(
- micromark("[](a \"\\\"\")"),
+ to_html("[](a \"\\\"\")"),
"<p><a href=\"a\" title=\"&quot;\"></a></p>",
"should support a character escape to start a link title (1)"
);
assert_eq!(
- micromark("[](a '\\'')"),
+ to_html("[](a '\\'')"),
"<p><a href=\"a\" title=\"\'\"></a></p>",
"should support a character escape to start a link title (2)"
);
assert_eq!(
- micromark("[](a (\\)))"),
+ to_html("[](a (\\)))"),
"<p><a href=\"a\" title=\")\"></a></p>",
"should support a character escape to start a link title (3)"
);
assert_eq!(
- micromark("[&amp;&copy;&](example.com/&amp;&copy;& \"&amp;&copy;&\")"),
+ to_html("[&amp;&copy;&](example.com/&amp;&copy;& \"&amp;&copy;&\")"),
"<p><a href=\"example.com/&amp;%C2%A9&amp;\" title=\"&amp;©&amp;\">&amp;©&amp;</a></p>",
"should support character references in links"
);
assert_eq!(
- micromark("[a](1())"),
+ to_html("[a](1())"),
"<p><a href=\"1()\">a</a></p>",
"should support 1 set of parens"
);
assert_eq!(
- micromark("[a](1(2()))"),
+ to_html("[a](1(2()))"),
"<p><a href=\"1(2())\">a</a></p>",
"should support 2 sets of parens"
);
assert_eq!(
- micromark(
+ to_html(
"[a](1(2(3(4(5(6(7(8(9(10(11(12(13(14(15(16(17(18(19(20(21(22(23(24(25(26(27(28(29(30(31(32()))))))))))))))))))))))))))))))))"),
"<p><a href=\"1(2(3(4(5(6(7(8(9(10(11(12(13(14(15(16(17(18(19(20(21(22(23(24(25(26(27(28(29(30(31(32())))))))))))))))))))))))))))))))\">a</a></p>",
"should support 32 sets of parens"
);
assert_eq!(
- micromark(
+ to_html(
"[a](1(2(3(4(5(6(7(8(9(10(11(12(13(14(15(16(17(18(19(20(21(22(23(24(25(26(27(28(29(30(31(32(33())))))))))))))))))))))))))))))))))"),
"<p>[a](1(2(3(4(5(6(7(8(9(10(11(12(13(14(15(16(17(18(19(20(21(22(23(24(25(26(27(28(29(30(31(32(33())))))))))))))))))))))))))))))))))</p>",
"should not support 33 or more sets of parens"
);
assert_eq!(
- micromark("[a](b \"\n c\")"),
+ to_html("[a](b \"\n c\")"),
"<p><a href=\"b\" title=\"\nc\">a</a></p>",
"should support an eol at the start of a title"
);
assert_eq!(
- micromark("[a](b( \"c\")"),
+ to_html("[a](b( \"c\")"),
"<p>[a](b( &quot;c&quot;)</p>",
"should not support whitespace when unbalanced in a raw destination"
);
assert_eq!(
- micromark("[a](\0)"),
+ to_html("[a](\0)"),
"<p><a href=\"%EF%BF%BD\">a</a></p>",
"should support a single NUL character as a link resource"
);
assert_eq!(
- micromark_to_mdast(
+ to_mdast(
"a [alpha]() b [bravo](charlie 'delta') c.",
&ParseOptions::default()
)?,