use askama::Template;
#[derive(Template)]
#[template(path = "match-opt.html")]
struct MatchOptTemplate<'a> {
item: Option<&'a str>,
}
#[derive(Template)]
#[template(path = "match-opt.html")]
struct MatchOptRefTemplate<'a> {
item: &'a Option<&'a str>,
}
#[test]
fn test_match_option() {
let s = MatchOptTemplate { item: Some("foo") };
assert_eq!(s.render().unwrap(), "\nFound literal foo\n");
let s = MatchOptTemplate { item: Some("bar") };
assert_eq!(s.render().unwrap(), "\nFound bar\n");
let s = MatchOptTemplate { item: None };
assert_eq!(s.render().unwrap(), "\nNot Found\n");
}
#[derive(Template)]
#[template(path = "match-opt-bool.html")]
struct MatchOptBoolTemplate {
item: Option<bool>,
}
#[test]
fn test_match_option_bool() {
let s = MatchOptBoolTemplate { item: Some(true) };
assert_eq!(s.render().unwrap(), "\nFound Some(true)\n");
let s = MatchOptBoolTemplate { item: Some(false) };
assert_eq!(s.render().unwrap(), "\nFound Some(false)\n");
let s = MatchOptBoolTemplate { item: None };
assert_eq!(s.render().unwrap(), "\nNot Found\n");
}
#[test]
fn test_match_ref_deref() {
let s = MatchOptRefTemplate { item: &Some("foo") };
assert_eq!(s.render().unwrap(), "\nFound literal foo\n");
}
#[derive(Template)]
#[template(path = "match-literal.html")]
struct MatchLitTemplate<'a> {
item: &'a str,
}
#[test]
fn test_match_literal() {
let s = MatchLitTemplate { item: "bar" };
assert_eq!(s.render().unwrap(), "\nFound literal bar\n");
let s = MatchLitTemplate { item: "qux" };
assert_eq!(s.render().unwrap(), "\nElse found qux\n");
}
#[derive(Template)]
#[template(path = "match-literal-char.html")]
struct MatchLitCharTemplate {
item: char,
}
#[test]
fn test_match_literal_char() {
let s = MatchLitCharTemplate { item: 'b' };
assert_eq!(s.render().unwrap(), "\nFound literal b\n");
let s = MatchLitCharTemplate { item: 'c' };
assert_eq!(s.render().unwrap(), "\nElse found c\n");
}
#[derive(Template)]
#[template(path = "match-literal-num.html")]
struct MatchLitNumTemplate {
item: u32,
}
#[test]
fn test_match_literal_num() {
let s = MatchLitNumTemplate { item: 42 };
assert_eq!(s.render().unwrap(), "\nFound answer to everything\n");
let s = MatchLitNumTemplate { item: 23 };
assert_eq!(s.render().unwrap(), "\nElse found 23\n");
}
#[allow(dead_code)]
enum Color {
Rgb { r: u32, g: u32, b: u32 },
GrayScale(u32),
Cmyk(u32, u32, u32, u32),
}
#[derive(Template)]
#[template(path = "match-custom-enum.html")]
struct MatchCustomEnumTemplate {
color: Color,
}
#[test]
fn test_match_custom_enum() {
let s = MatchCustomEnumTemplate {
color: Color::Rgb {
r: 160,
g: 0,
b: 255,
},
};
assert_eq!(s.render().unwrap(), "\nColorful: #A000FF\n");
}
#[derive(Template)]
#[template(path = "match-no-ws.html")]
struct MatchNoWhitespace {
foo: Option<usize>,
}
#[test]
fn test_match_no_whitespace() {
let s = MatchNoWhitespace { foo: Some(1) };
assert_eq!(s.render().unwrap(), "1");
}
#[derive(Template)]
#[template(
source = "{% match foo %}{% when Some(bar) %}{{ bar }}{% when None %}{% endmatch %}",
ext = "txt"
)]
struct MatchWithoutWithKeyword {
foo: Option<usize>,
}
#[test]
fn test_match_without_with_keyword() {
let s = MatchWithoutWithKeyword { foo: Some(1) };
assert_eq!(s.render().unwrap(), "1");
let s = MatchWithoutWithKeyword { foo: None };
assert_eq!(s.render().unwrap(), "");
}
#[derive(Template)]
#[template(path = "match-option-result-option.html")]
struct MatchOptionResultOption {
foo: Option<Result<Option<usize>, &'static str>>,
}
#[test]
fn test_match_option_result_option() {
let s = MatchOptionResultOption { foo: None };
assert_eq!(s.render().unwrap(), "nothing");
let s = MatchOptionResultOption {
foo: Some(Err("fail")),
};
assert_eq!(s.render().unwrap(), "err=fail");
let s = MatchOptionResultOption {
foo: Some(Ok(None)),
};
assert_eq!(s.render().unwrap(), "num=absent");
let s = MatchOptionResultOption {
foo: Some(Ok(Some(4711))),
};
assert_eq!(s.render().unwrap(), "num=4711");
}
#[derive(Template)]
#[template(
ext = "txt",
source = r#"
{%- match good -%}
{#- when good, then good -#}
{%- when true -%}
good
{%- when _ -%}
bad
{%- endmatch -%}"#
)]
struct MatchWithComment {
good: bool,
}
#[test]
fn test_match_with_comment() {
let s = MatchWithComment { good: true };
assert_eq!(s.render().unwrap(), "good");
let s = MatchWithComment { good: false };
assert_eq!(s.render().unwrap(), "bad");
}