use crate::blocks::rich_text::types::RichTextElementType;
use crate::validators::*;
use serde::Serialize;
use slack_messaging_derive::Builder;
#[derive(Debug, Clone, Serialize, PartialEq, Builder)]
#[serde(tag = "type", rename = "rich_text_quote")]
pub struct RichTextQuote {
#[builder(push_item = "element", validate("required"))]
pub(crate) elements: Option<Vec<RichTextElementType>>,
#[serde(skip_serializing_if = "Option::is_none")]
pub(crate) border: Option<i64>,
}
#[cfg(test)]
mod tests {
use super::*;
use crate::blocks::rich_text::types::test_helpers::*;
use crate::errors::*;
#[test]
fn it_implements_builder() {
let expected = RichTextQuote {
elements: Some(vec![el_text("foo"), el_emoji("bar")]),
border: Some(3),
};
let val = RichTextQuote::builder()
.set_elements(Some(vec![el_text("foo"), el_emoji("bar")]))
.set_border(Some(3))
.build()
.unwrap();
assert_eq!(val, expected);
let val = RichTextQuote::builder()
.elements(vec![el_text("foo"), el_emoji("bar")])
.border(3)
.build()
.unwrap();
assert_eq!(val, expected);
}
#[test]
fn it_implements_push_item_method() {
let expected = RichTextQuote {
elements: Some(vec![el_text("foo"), el_emoji("bar")]),
border: None,
};
let val = RichTextQuote::builder()
.element(text("foo"))
.element(emoji("bar"))
.build()
.unwrap();
assert_eq!(val, expected);
}
#[test]
fn it_requres_elements_field() {
let err = RichTextQuote::builder().build().unwrap_err();
assert_eq!(err.object(), "RichTextQuote");
let errors = err.field("elements");
assert!(errors.includes(ValidationErrorKind::Required));
}
}