use maud::{html, Markup}; #[test] fn literals() { let result = html! { "du\tcks" "-23" "3.14\n" "geese" }; assert_eq!(result.into_string(), "du\tcks-233.14\ngeese"); } #[test] fn escaping() { let result = html! { "" }; assert_eq!(result.into_string(), "<flim&flam>"); } #[test] fn semicolons() { let result = html! { "one"; "two"; "three"; ;;;;;;;;;;;;;;;;;;;;;;;; "four"; }; assert_eq!(result.into_string(), "onetwothreefour"); } #[test] fn blocks() { let result = html! { "hello" { " ducks" " geese" } " swans" }; assert_eq!(result.into_string(), "hello ducks geese swans"); } #[test] fn simple_elements() { let result = html! { p { b { "pickle" } "barrel" i { "kumquat" } } }; assert_eq!( result.into_string(), "

picklebarrelkumquat

" ); } #[test] fn empty_elements() { let result = html! { "pinkie" br; "pie" }; assert_eq!(result.into_string(), "pinkie
pie"); } #[test] fn simple_attributes() { let result = html! { link rel="stylesheet" href="styles.css"; section id="midriff" { p class="hotpink" { "Hello!" } } }; assert_eq!( result.into_string(), concat!( r#""#, r#"

Hello!

"# ) ); } #[test] fn empty_attributes() { let result = html! { div readonly { input type="checkbox" checked; } }; assert_eq!( result.into_string(), r#"
"# ); } #[test] fn toggle_empty_attributes() { let rocks = true; let result = html! { input checked[true]; input checked[false]; input checked[rocks]; input checked[!rocks]; }; assert_eq!( result.into_string(), concat!( r#""#, r#""#, r#""#, r#""# ) ); } #[test] fn toggle_empty_attributes_braces() { struct Maud { rocks: bool, } let result = html! { input checked[Maud { rocks: true }.rocks]; }; assert_eq!(result.into_string(), r#""#); } #[test] fn empty_attributes_question_mark() { let result = html! { input checked? disabled?[true]; }; assert_eq!(result.into_string(), ""); } #[test] fn optional_attribute_some() { let result = html! { input value=[Some("value")]; }; assert_eq!(result.into_string(), r#""#); } #[test] fn optional_attribute_none() { let result = html! { input value=[None as Option<&str>]; }; assert_eq!(result.into_string(), r#""#); } #[test] fn optional_attribute_non_string_some() { let result = html! { input value=[Some(42)]; }; assert_eq!(result.into_string(), r#""#); } #[test] fn optional_attribute_variable() { let x = Some(42); let result = html! { input value=[x]; }; assert_eq!(result.into_string(), r#""#); } #[test] fn optional_attribute_inner_value_evaluated_only_once() { let mut count = 0; html! { input value=[{ count += 1; Some("picklebarrelkumquat") }]; }; assert_eq!(count, 1); } #[test] fn optional_attribute_braces() { struct Pony { cuteness: Option, } let result = html! { input value=[Pony { cuteness: Some(9000) }.cuteness]; }; assert_eq!(result.into_string(), r#""#); } #[test] fn colons_in_names() { let result = html! { pon-pon:controls-alpha { a on:click="yay()" { "Yay!" } } }; assert_eq!( result.into_string(), concat!( r#""#, r#"Yay!"#, r#""# ) ); } #[test] fn hyphens_in_element_names() { let result = html! { custom-element {} }; assert_eq!(result.into_string(), ""); } #[test] fn hyphens_in_attribute_names() { let result = html! { this sentence-is="false" of-course {} }; assert_eq!( result.into_string(), r#""# ); } #[test] fn class_shorthand() { let result = html! { p { "Hi, " span.name { "Lyra" } "!" } }; assert_eq!( result.into_string(), r#"

Hi, Lyra!

"# ); } #[test] fn class_shorthand_with_space() { let result = html! { p { "Hi, " span .name { "Lyra" } "!" } }; assert_eq!( result.into_string(), r#"

Hi, Lyra!

"# ); } #[test] fn classes_shorthand() { let result = html! { p { "Hi, " span.name.here { "Lyra" } "!" } }; assert_eq!( result.into_string(), r#"

Hi, Lyra!

"# ); } #[test] fn hyphens_in_class_names() { let result = html! { p.rocks-these.are--my--rocks { "yes" } }; assert_eq!( result.into_string(), r#"

yes

"# ); } #[test] fn class_string() { let result = html! { h1."pinkie-123" { "Pinkie Pie" } }; assert_eq!( result.into_string(), r#"

Pinkie Pie

"# ); } #[test] fn toggle_classes() { fn test(is_cupcake: bool, is_muffin: bool) -> Markup { html!(p.cupcake[is_cupcake].muffin[is_muffin] { "Testing!" }) } assert_eq!( test(true, true).into_string(), r#"

Testing!

"# ); assert_eq!( test(false, true).into_string(), r#"

Testing!

"# ); assert_eq!( test(true, false).into_string(), r#"

Testing!

"# ); assert_eq!( test(false, false).into_string(), r#"

Testing!

"# ); } #[test] fn toggle_classes_braces() { struct Maud { rocks: bool, } let result = html! { p.rocks[Maud { rocks: true }.rocks] { "Awesome!" } }; assert_eq!(result.into_string(), r#"

Awesome!

"#); } #[test] fn toggle_classes_string() { let is_cupcake = true; let is_muffin = false; let result = html! { p."cupcake"[is_cupcake]."is_muffin"[is_muffin] { "Testing!" } }; assert_eq!(result.into_string(), r#"

Testing!

"#); } #[test] fn mixed_classes() { fn test(is_muffin: bool) -> Markup { html!(p.cupcake.muffin[is_muffin].lamington { "Testing!" }) } assert_eq!( test(true).into_string(), r#"

Testing!

"# ); assert_eq!( test(false).into_string(), r#"

Testing!

"# ); } #[test] fn id_shorthand() { let result = html! { p { "Hi, " span #thing { "Lyra" } "!" } }; assert_eq!( result.into_string(), r#"

Hi, Lyra!

"# ); } #[test] fn id_string() { let result = html! { h1 #"pinkie-123" { "Pinkie Pie" } }; assert_eq!( result.into_string(), r#"

Pinkie Pie

"# ); } #[test] fn classes_attrs_ids_mixed_up() { let result = html! { p { "Hi, " span.name.here lang="en" #thing { "Lyra" } "!" } }; assert_eq!( result.into_string(), r#"

Hi, Lyra!

"# ); } #[test] fn div_shorthand_class() { let result = html! { .awesome-class {} }; assert_eq!(result.into_string(), r#"
"#); } #[test] fn div_shorthand_id() { let result = html! { #unique-id {} }; assert_eq!(result.into_string(), r#"
"#); } #[test] fn div_shorthand_class_with_attrs() { let result = html! { .awesome-class contenteditable dir="rtl" #unique-id {} }; assert_eq!( result.into_string(), r#"
"# ); } #[test] fn div_shorthand_id_with_attrs() { let result = html! { #unique-id contenteditable dir="rtl" .awesome-class {} }; assert_eq!( result.into_string(), r#"
"# ); }