From 5403261e8213f68633a09fc3e9bc2e6e2cd777b2 Mon Sep 17 00:00:00 2001 From: Titus Wormer Date: Mon, 18 Jul 2022 16:31:14 +0200 Subject: Add support for turning off constructs --- tests/html_text.rs | 165 ++++++++++++++++++++++++++++------------------------- 1 file changed, 86 insertions(+), 79 deletions(-) (limited to 'tests/html_text.rs') diff --git a/tests/html_text.rs b/tests/html_text.rs index 0288af7..65030b2 100644 --- a/tests/html_text.rs +++ b/tests/html_text.rs @@ -1,14 +1,13 @@ extern crate micromark; -use micromark::{micromark, micromark_with_options, Options}; - -const DANGER: &Options = &Options { - allow_dangerous_html: true, - allow_dangerous_protocol: false, - default_line_ending: None, -}; +use micromark::{micromark, micromark_with_options, Constructs, Options}; #[test] fn html_text() { + let danger = Options { + allow_dangerous_html: true, + ..Options::default() + }; + assert_eq!( micromark("a c"), "

a <b> c

", @@ -16,19 +15,19 @@ fn html_text() { ); assert_eq!( - micromark_with_options("", DANGER), + micromark_with_options("", &danger), "

", "should support opening tags" ); assert_eq!( - micromark_with_options("", DANGER), + micromark_with_options("", &danger), "

", "should support self-closing tags" ); assert_eq!( - micromark_with_options("", DANGER), + micromark_with_options("", &danger), "

", "should support whitespace in tags" ); @@ -36,171 +35,171 @@ fn html_text() { assert_eq!( micromark_with_options( "", - DANGER + &danger ), "

", "should support attributes on tags" ); assert_eq!( - micromark_with_options("Foo ", DANGER), + micromark_with_options("Foo ", &danger), "

Foo

", "should support non-html tags" ); assert_eq!( - micromark_with_options("<33> <__>", DANGER), + micromark_with_options("<33> <__>", &danger), "

<33> <__>

", "should not support nonconforming tag names" ); assert_eq!( - micromark_with_options("
", DANGER), + micromark_with_options("", &danger), "

<a h*#ref="hi">

", "should not support nonconforming attribute names" ); assert_eq!( - micromark_with_options("
", DANGER), + micromark_with_options(" ", &danger), "

<a href="hi'> <a href=hi'>

", "should not support nonconforming attribute values" ); assert_eq!( - micromark_with_options("< a><\nfoo>\n", DANGER), + micromark_with_options("< a><\nfoo>\n", &danger), "

< a><\nfoo><bar/ >\n<foo bar=baz\nbim!bop />

", "should not support nonconforming whitespace" ); assert_eq!( - micromark_with_options("
", DANGER), + micromark_with_options("", &danger), "

<a href='bar'title=title>

", "should not support missing whitespace" ); assert_eq!( - micromark_with_options("
", DANGER), + micromark_with_options("", &danger), "

", "should support closing tags" ); assert_eq!( - micromark_with_options("", DANGER), + micromark_with_options("", &danger), "

</a href="foo">

", "should not support closing tags w/ attributes" ); assert_eq!( - micromark_with_options("foo ", DANGER), + micromark_with_options("foo ", &danger), "

foo

", "should support comments" ); assert_eq!( - micromark_with_options("foo ", DANGER), + micromark_with_options("foo ", &danger), "

foo <!-- not a comment -- two hyphens -->

", "should not support comments w/ two dashes inside" ); assert_eq!( - micromark_with_options("foo foo -->", DANGER), + micromark_with_options("foo foo -->", &danger), "

foo <!--> foo -->

", "should not support nonconforming comments (1)" ); assert_eq!( - micromark_with_options("foo ", DANGER), + micromark_with_options("foo ", &danger), "

foo <!-- foo--->

", "should not support nonconforming comments (2)" ); assert_eq!( - micromark_with_options("foo ", DANGER), + micromark_with_options("foo ", &danger), "

foo

", "should support instructions" ); assert_eq!( - micromark_with_options("foo ", DANGER), + micromark_with_options("foo ", &danger), "

foo

", "should support declarations" ); assert_eq!( - micromark_with_options("foo &<]]>", DANGER), + micromark_with_options("foo &<]]>", &danger), "

foo &<]]>

", "should support cdata" ); assert_eq!( - micromark_with_options("foo ", DANGER), + micromark_with_options("foo ", &danger), "

foo

", "should support (ignore) character references" ); assert_eq!( - micromark_with_options("foo ", DANGER), + micromark_with_options("foo ", &danger), "

foo

", "should not support character escapes (1)" ); assert_eq!( - micromark_with_options("", DANGER), + micromark_with_options("", &danger), "

<a href=""">

", "should not support character escapes (2)" ); // Extra: assert_eq!( - micromark_with_options("foo ", DANGER), + micromark_with_options("foo ", &danger), "

foo <!1>

", "should not support non-comment, non-cdata, and non-named declaration" ); assert_eq!( - micromark_with_options("foo ", DANGER), + micromark_with_options("foo ", &danger), "

foo <!-not enough!-->

", "should not support comments w/ not enough dashes" ); assert_eq!( - micromark_with_options("foo ", DANGER), + micromark_with_options("foo ", &danger), "

foo

", "should support comments that start w/ a dash, if it’s not followed by a greater than" ); assert_eq!( - micromark_with_options("foo ", DANGER), + micromark_with_options("foo ", &danger), "

foo <!--->

", "should not support comments that start w/ `->`" ); assert_eq!( - micromark_with_options("foo ", DANGER), + micromark_with_options("foo ", &danger), "

foo

", "should support `->` in a comment" ); assert_eq!( - micromark_with_options("foo