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
use crate::{datetime::Timestamp, guild::Permissions, id::RoleId, user::User};
use serde::{Deserialize, Serialize};
#[derive(Clone, Debug, Deserialize, Eq, Hash, PartialEq, Serialize)]
pub struct PartialMember {
pub deaf: bool,
pub joined_at: Option<Timestamp>,
pub mute: bool,
pub nick: Option<String>,
pub permissions: Option<Permissions>,
#[serde(skip_serializing_if = "Option::is_none")]
pub premium_since: Option<Timestamp>,
pub roles: Vec<RoleId>,
pub user: Option<User>,
}
#[cfg(test)]
mod tests {
use super::{PartialMember, RoleId};
use crate::datetime::{Timestamp, TimestampParseError};
use serde_test::Token;
use std::str::FromStr;
#[test]
fn test_partial_member() -> Result<(), TimestampParseError> {
let joined_at = Timestamp::from_str("2015-04-26T06:26:56.936000+00:00")?;
let value = PartialMember {
deaf: false,
joined_at: Some(joined_at),
mute: true,
nick: Some("a nickname".to_owned()),
permissions: None,
premium_since: None,
roles: vec![RoleId::new(1).expect("non zero")],
user: None,
};
serde_test::assert_tokens(
&value,
&[
Token::Struct {
name: "PartialMember",
len: 7,
},
Token::Str("deaf"),
Token::Bool(false),
Token::Str("joined_at"),
Token::Some,
Token::Str("2015-04-26T06:26:56.936000+00:00"),
Token::Str("mute"),
Token::Bool(true),
Token::Str("nick"),
Token::Some,
Token::Str("a nickname"),
Token::Str("permissions"),
Token::None,
Token::Str("roles"),
Token::Seq { len: Some(1) },
Token::NewtypeStruct { name: "RoleId" },
Token::Str("1"),
Token::SeqEnd,
Token::Str("user"),
Token::None,
Token::StructEnd,
],
);
Ok(())
}
}