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_preformatted")]
pub struct RichTextPreformatted {
#[builder(push_item = "element", validate("required"))]
pub(crate) elements: Option<Vec<RichTextElementType>>,
#[serde(skip_serializing_if = "Option::is_none")]
pub(crate) border: Option<i64>,
#[serde(skip_serializing_if = "Option::is_none")]
pub(crate) language: Option<String>,
}
#[cfg(test)]
mod tests {
use super::*;
use crate::blocks::rich_text::types::test_helpers::*;
use crate::errors::*;
#[test]
fn it_implements_builder() {
let expected = RichTextPreformatted {
elements: Some(vec![el_text("foo"), el_emoji("bar")]),
border: Some(3),
language: Some("python".into()),
};
let val = RichTextPreformatted::builder()
.set_elements(Some(vec![el_text("foo"), el_emoji("bar")]))
.set_border(Some(3))
.set_language(Some("python"))
.build()
.unwrap();
assert_eq!(val, expected);
let val = RichTextPreformatted::builder()
.elements(vec![el_text("foo"), el_emoji("bar")])
.border(3)
.language("python")
.build()
.unwrap();
assert_eq!(val, expected);
}
#[test]
fn it_implements_push_item_method() {
let expected = RichTextPreformatted {
elements: Some(vec![el_text("foo"), el_emoji("bar")]),
border: None,
language: None,
};
let val = RichTextPreformatted::builder()
.element(text("foo"))
.element(emoji("bar"))
.build()
.unwrap();
assert_eq!(val, expected);
}
#[test]
fn it_requres_elements_field() {
let err = RichTextPreformatted::builder().build().unwrap_err();
assert_eq!(err.object(), "RichTextPreformatted");
let errors = err.field("elements");
assert!(errors.includes(ValidationErrorKind::Required));
}
}