1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
use serde_derive::{Deserialize, Serialize};
#[derive(Debug, Default, Clone, Serialize, Deserialize)]
pub struct EmailAddress {
pub email: String,
#[serde(skip_serializing_if = "Option::is_none")]
pub name: Option<String>,
}
impl EmailAddress {
pub fn new<T>(email: T) -> EmailAddress
where
T: Into<String>,
{
EmailAddress {
email: email.into(),
name: None,
}
}
pub fn new_with_name<T, U>(email: T, name: U) -> EmailAddress
where
T: Into<String>,
U: Into<String>,
{
EmailAddress {
email: email.into(),
name: Some(name.into()),
}
}
}
impl<T> From<T> for EmailAddress
where
T: Into<String>,
{
fn from(email: T) -> Self {
EmailAddress::new(email)
}
}
#[cfg(test)]
mod tests {
use super::*;
use serde_json::to_string;
#[test]
fn it_serializes_to_json() {
let json = to_string(&EmailAddress {
email: "foo@example.com".to_owned(),
name: None,
})
.unwrap();
assert_eq!(json, r#"{"email":"foo@example.com"}"#);
let json = to_string(&EmailAddress {
email: "foo@example.com".to_owned(),
name: Some("Foo Example".to_owned()),
})
.unwrap();
assert_eq!(json, r#"{"email":"foo@example.com","name":"Foo Example"}"#);
}
#[test]
fn it_converts_from_string() {
let address: EmailAddress = "foo@example.com".into();
assert_eq!(address.email, "foo@example.com");
assert_eq!(address.name, None);
}
}