maud/maud/tests/misc.rs
Chris Wong 6ebe6b1fe1
Clean up tests ()
- Call `.into_string()` later
- Rename UI test to match Rust convention
2020-11-07 22:44:47 +13:00

85 lines
1.7 KiB
Rust

use maud::{self, html};
#[test]
fn issue_13() {
let owned = String::from("yay");
let _ = html! { (owned) };
// Make sure the `html!` call didn't move it
let _owned = owned;
}
#[test]
fn issue_21() {
macro_rules! greet {
() => {{
let name = "Pinkie Pie";
html! {
p { "Hello, " (name) "!" }
}
}};
}
assert_eq!(greet!().into_string(), "<p>Hello, Pinkie Pie!</p>");
}
#[test]
fn issue_21_2() {
macro_rules! greet {
($name:expr) => {{
html! {
p { "Hello, " ($name) "!" }
}
}};
}
assert_eq!(
greet!("Pinkie Pie").into_string(),
"<p>Hello, Pinkie Pie!</p>"
);
}
#[test]
fn issue_23() {
macro_rules! wrapper {
($($x:tt)*) => {{
html! { $($x)* }
}}
}
let name = "Lyra";
let result = wrapper!(p { "Hi, " (name) "!" });
assert_eq!(result.into_string(), "<p>Hi, Lyra!</p>");
}
#[test]
fn render_impl() {
struct R(&'static str);
impl maud::Render for R {
fn render_to(&self, w: &mut String) {
w.push_str(self.0);
}
}
let r = R("pinkie");
// Since `R` is not `Copy`, this shows that Maud will auto-ref splice
// arguments to find a `Render` impl
let result_a = html! { (r) };
let result_b = html! { (r) };
assert_eq!(result_a.into_string(), "pinkie");
assert_eq!(result_b.into_string(), "pinkie");
}
#[test]
fn issue_97() {
use maud::Render;
struct Pinkie;
impl Render for Pinkie {
fn render(&self) -> maud::Markup {
let x = 42;
html! { (x) }
}
}
assert_eq!(html! { (Pinkie) }.into_string(), "42");
}