events: Clean up location event tests
This commit is contained in:
parent
8912182c56
commit
31d526ebfd
@ -6,10 +6,7 @@ use js_int::uint;
|
||||
use ruma_common::{
|
||||
event_id,
|
||||
events::{
|
||||
location::{
|
||||
AssetContent, AssetType, LocationContent, LocationEventContent, ZoomLevel,
|
||||
ZoomLevelError,
|
||||
},
|
||||
location::{AssetType, LocationContent, LocationEventContent, ZoomLevel, ZoomLevelError},
|
||||
message::MessageContent,
|
||||
room::message::{
|
||||
InReplyTo, LocationMessageEventContent, MessageType, Relation, RoomMessageEventContent,
|
||||
@ -113,28 +110,15 @@ fn plain_content_deserialization() {
|
||||
},
|
||||
});
|
||||
|
||||
assert_matches!(
|
||||
from_json_value::<LocationEventContent>(json_data)
|
||||
.unwrap(),
|
||||
LocationEventContent {
|
||||
message,
|
||||
location: LocationContent {
|
||||
uri,
|
||||
description: None,
|
||||
zoom_level: None,
|
||||
..
|
||||
},
|
||||
asset: AssetContent {
|
||||
type_: AssetType::Self_,
|
||||
..
|
||||
},
|
||||
ts: None,
|
||||
..
|
||||
}
|
||||
if message.find_plain() == Some("Alice was at geo:51.5008,0.1247;u=35")
|
||||
&& message.find_html().is_none()
|
||||
&& uri == "geo:51.5008,0.1247;u=35"
|
||||
);
|
||||
let ev = from_json_value::<LocationEventContent>(json_data).unwrap();
|
||||
|
||||
assert_eq!(ev.message.find_plain(), Some("Alice was at geo:51.5008,0.1247;u=35"));
|
||||
assert_eq!(ev.message.find_html(), None);
|
||||
assert_eq!(ev.location.uri, "geo:51.5008,0.1247;u=35");
|
||||
assert_eq!(ev.location.description, None);
|
||||
assert_matches!(ev.location.zoom_level, None);
|
||||
assert_eq!(ev.asset.type_, AssetType::Self_);
|
||||
assert_eq!(ev.ts, None);
|
||||
}
|
||||
|
||||
#[test]
|
||||
@ -160,12 +144,9 @@ fn zoomlevel_deserialization_too_high() {
|
||||
"zoom_level": 30,
|
||||
});
|
||||
|
||||
assert_matches!(
|
||||
from_json_value::<LocationContent>(json_data),
|
||||
Err(err)
|
||||
if err.is_data()
|
||||
&& format!("{err}") == format!("{}", ZoomLevelError::TooHigh)
|
||||
);
|
||||
let err = from_json_value::<LocationContent>(json_data).unwrap_err();
|
||||
assert!(err.is_data());
|
||||
assert_eq!(err.to_string(), ZoomLevelError::TooHigh.to_string());
|
||||
}
|
||||
|
||||
#[test]
|
||||
@ -194,41 +175,27 @@ fn message_event_deserialization() {
|
||||
"type": "m.location",
|
||||
});
|
||||
|
||||
assert_matches!(
|
||||
from_json_value::<AnyMessageLikeEvent>(json_data).unwrap(),
|
||||
AnyMessageLikeEvent::Location(MessageLikeEvent::Original(OriginalMessageLikeEvent {
|
||||
content: LocationEventContent {
|
||||
message,
|
||||
location: LocationContent {
|
||||
uri,
|
||||
description: Some(description),
|
||||
zoom_level: Some(zoom_level),
|
||||
..
|
||||
},
|
||||
asset: AssetContent {
|
||||
type_: AssetType::Self_,
|
||||
..
|
||||
},
|
||||
ts: Some(ts),
|
||||
..
|
||||
},
|
||||
event_id,
|
||||
origin_server_ts,
|
||||
room_id,
|
||||
sender,
|
||||
unsigned
|
||||
})) if event_id == event_id!("$event:notareal.hs")
|
||||
&& message.find_plain() == Some("Alice was at geo:51.5008,0.1247;u=35 as of Sat Nov 13 18:50:58 2021")
|
||||
&& message.find_html().is_none()
|
||||
&& uri == "geo:51.5008,0.1247;u=35"
|
||||
&& description == "Alice's whereabouts"
|
||||
&& zoom_level.get() == uint!(4)
|
||||
&& ts == MilliSecondsSinceUnixEpoch(uint!(1_636_829_458))
|
||||
&& origin_server_ts == MilliSecondsSinceUnixEpoch(uint!(134_829_848))
|
||||
&& room_id == room_id!("!roomid:notareal.hs")
|
||||
&& sender == user_id!("@user:notareal.hs")
|
||||
&& unsigned.is_empty()
|
||||
let ev = from_json_value::<AnyMessageLikeEvent>(json_data).unwrap();
|
||||
|
||||
let ev =
|
||||
assert_matches!(ev, AnyMessageLikeEvent::Location(MessageLikeEvent::Original(ev)) => ev);
|
||||
|
||||
assert_eq!(
|
||||
ev.content.message.find_plain(),
|
||||
Some("Alice was at geo:51.5008,0.1247;u=35 as of Sat Nov 13 18:50:58 2021")
|
||||
);
|
||||
assert_eq!(ev.content.message.find_html(), None);
|
||||
assert_eq!(ev.content.location.uri, "geo:51.5008,0.1247;u=35");
|
||||
assert_eq!(ev.content.location.description.as_deref(), Some("Alice's whereabouts"));
|
||||
assert_eq!(ev.content.location.zoom_level.unwrap().get(), uint!(4));
|
||||
assert_eq!(ev.content.asset.type_, AssetType::Self_);
|
||||
assert_eq!(ev.content.ts, Some(MilliSecondsSinceUnixEpoch(uint!(1_636_829_458))));
|
||||
|
||||
assert_eq!(ev.event_id, event_id!("$event:notareal.hs"));
|
||||
assert_eq!(ev.origin_server_ts, MilliSecondsSinceUnixEpoch(uint!(134_829_848)));
|
||||
assert_eq!(ev.room_id, room_id!("!roomid:notareal.hs"));
|
||||
assert_eq!(ev.sender, user_id!("@user:notareal.hs"));
|
||||
assert!(ev.unsigned.is_empty());
|
||||
}
|
||||
|
||||
#[test]
|
||||
@ -266,15 +233,14 @@ fn room_message_stable_deserialization() {
|
||||
});
|
||||
|
||||
let event_content = from_json_value::<RoomMessageEventContent>(json_data).unwrap();
|
||||
assert_matches!(event_content.msgtype, MessageType::Location(_));
|
||||
if let MessageType::Location(content) = event_content.msgtype {
|
||||
let content = assert_matches!(event_content.msgtype, MessageType::Location(c) => c);
|
||||
|
||||
assert_eq!(content.body, "Alice was at geo:51.5008,0.1247;u=35");
|
||||
assert_eq!(content.geo_uri, "geo:51.5008,0.1247;u=35");
|
||||
let message = content.message.unwrap();
|
||||
assert_eq!(message.len(), 1);
|
||||
assert_eq!(message[0].body, "Alice was at geo:51.5008,0.1247;u=35");
|
||||
assert_eq!(content.location.unwrap().uri, "geo:51.5008,0.1247;u=35");
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
@ -290,13 +256,12 @@ fn room_message_unstable_deserialization() {
|
||||
});
|
||||
|
||||
let event_content = from_json_value::<RoomMessageEventContent>(json_data).unwrap();
|
||||
assert_matches!(event_content.msgtype, MessageType::Location(_));
|
||||
if let MessageType::Location(content) = event_content.msgtype {
|
||||
let content = assert_matches!(event_content.msgtype, MessageType::Location(c) => c);
|
||||
|
||||
assert_eq!(content.body, "Alice was at geo:51.5008,0.1247;u=35");
|
||||
assert_eq!(content.geo_uri, "geo:51.5008,0.1247;u=35");
|
||||
let message = content.message.unwrap();
|
||||
assert_eq!(message.len(), 1);
|
||||
assert_eq!(message[0].body, "Alice was at geo:51.5008,0.1247;u=35");
|
||||
assert_eq!(content.location.unwrap().uri, "geo:51.5008,0.1247;u=35");
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user