#[derive(
Debug,
Clone,
PartialEq,
Eq,
PartialOrd,
Ord,
Hash,
derive_more::AsRef,
derive_more::Display,
derive_more::From,
derive_more::FromStr,
derive_more::Into,
serde::Serialize,
serde::Deserialize,
)]
pub struct Name(String);
impl From<&str> for Name {
fn from(value: &str) -> Self {
Self(value.into())
}
}
impl Name {
pub fn as_str(&self) -> &str {
self.0.as_str()
}
}
#[cfg(test)]
mod tests {
use super::Name;
use pretty_assertions::assert_eq;
#[test]
fn from_str() {
assert_eq!(
Name("Beispiel-System".to_string()),
"Beispiel-System"
.parse()
.expect("value must be a parseable name")
);
}
}
#[cfg(test)]
mod serde_tests {
use super::Name;
use pretty_assertions::assert_eq;
use serde_json::json;
#[test]
fn serialize() {
assert_eq!(
json!(Name("Beispiel-System".to_string())),
json!("Beispiel-System")
);
}
#[test]
fn deserialize_good() {
let deserialized: Name = serde_json::from_value(json!("Beispiel-System"))
.expect("value must be deserializable as Name");
assert_eq!(deserialized, Name::from("Beispiel-System"));
}
#[test]
fn deserialize_bad() {
assert!(serde_json::from_value::<Name>(json!([])).is_err());
assert!(serde_json::from_value::<Name>(json!({})).is_err());
assert!(serde_json::from_value::<Name>(json!(true)).is_err());
assert!(serde_json::from_value::<Name>(json!(123)).is_err());
}
}