#![allow(clippy::useless_let_if_seq)]
use askama::Template;
#[derive(Template)]
#[template(source = "{% let v = s %}{{ v }}", ext = "txt")]
struct LetTemplate<'a> {
s: &'a str,
}
#[test]
fn test_let() {
let t = LetTemplate { s: "foo" };
assert_eq!(t.render().unwrap(), "foo");
}
#[derive(Template)]
#[template(path = "let.html")]
struct LetTupleTemplate<'a> {
s: &'a str,
t: (&'a str, &'a str),
}
#[test]
fn test_let_tuple() {
let t = LetTupleTemplate {
s: "foo",
t: ("bar", "bazz"),
};
assert_eq!(t.render().unwrap(), "foo\nbarbazz");
}
#[derive(Template)]
#[template(path = "let-decl.html")]
struct LetDeclTemplate<'a> {
cond: bool,
s: &'a str,
}
#[test]
fn test_let_decl() {
let t = LetDeclTemplate {
cond: false,
s: "bar",
};
assert_eq!(t.render().unwrap(), "bar");
}
#[derive(Template)]
#[template(path = "let-shadow.html")]
struct LetShadowTemplate {
cond: bool,
}
impl LetShadowTemplate {
fn tuple() -> (i32, i32) {
(4, 5)
}
}
#[test]
fn test_let_shadow() {
let t = LetShadowTemplate { cond: true };
assert_eq!(t.render().unwrap(), "22-1-33-11-22");
let t = LetShadowTemplate { cond: false };
assert_eq!(t.render().unwrap(), "222-1-333-4-5-11-222");
}
#[derive(Template)]
#[template(source = "{% for v in self.0 %}{{ v }}{% endfor %}", ext = "txt")]
struct SelfIterTemplate(Vec<usize>);
#[test]
fn test_self_iter() {
let t = SelfIterTemplate(vec![1, 2, 3]);
assert_eq!(t.render().unwrap(), "123");
}
#[derive(Template)]
#[template(
source = "{% if true %}{% let t = a.unwrap() %}{{ t }}{% endif %}",
ext = "txt"
)]
struct IfLet {
a: Option<&'static str>,
}
#[test]
fn test_if_let() {
let t = IfLet { a: Some("foo") };
assert_eq!(t.render().unwrap(), "foo");
}
#[derive(Template)]
#[template(path = "let-destruct-tuple.html")]
struct LetDestructTupleTemplate {
abcd: (char, ((char, char), char)),
}
#[test]
fn test_destruct_tuple() {
let t = LetDestructTupleTemplate {
abcd: ('w', (('x', 'y'), 'z')),
};
assert_eq!(t.render().unwrap(), "wxyz\nwz\nw");
}