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
use std::collections::HashMap;
use ruma_events_macros::ruma_event;
use ruma_identifiers::{RoomId, UserId};
ruma_event! {
DirectEvent {
kind: Event,
event_type: "m.direct",
content_type_alias: {
HashMap<UserId, Vec<RoomId>>
},
}
}
#[cfg(test)]
mod tests {
use std::collections::HashMap;
use ruma_identifiers::{RoomId, UserId};
use serde_json::to_string;
use super::{DirectEvent, DirectEventContent};
use crate::EventResult;
#[test]
fn serialization() {
let mut content: DirectEventContent = HashMap::new();
let alice = UserId::new("ruma.io").unwrap();
let room = vec![RoomId::new("ruma.io").unwrap()];
content.insert(alice.clone(), room.clone());
let event = DirectEvent { content };
assert_eq!(
to_string(&event).unwrap(),
format!(
r#"{{"type":"m.direct","content":{{"{}":["{}"]}}}}"#,
alice.to_string(),
room[0].to_string()
)
);
}
#[test]
fn deserialization() {
let alice = UserId::new("ruma.io").unwrap();
let rooms = vec![
RoomId::new("ruma.io").unwrap(),
RoomId::new("ruma.io").unwrap(),
];
let json_data = format!(
r#"{{
"type": "m.direct",
"content": {{ "{}": ["{}", "{}"] }}
}}"#,
alice.to_string(),
rooms[0].to_string(),
rooms[1].to_string()
);
let event: DirectEvent = serde_json::from_str::<EventResult<_>>(&json_data)
.unwrap()
.into_result()
.unwrap();
let direct_rooms = event.content.get(&alice).unwrap();
assert!(direct_rooms.contains(&rooms[0]));
assert!(direct_rooms.contains(&rooms[1]));
}
}