Add a test for register_event_handler
This commit is contained in:
parent
e2432d476e
commit
97731d1240
1 changed files with 55 additions and 2 deletions
|
@ -2964,8 +2964,10 @@ mod test {
|
||||||
use std::{
|
use std::{
|
||||||
collections::BTreeMap,
|
collections::BTreeMap,
|
||||||
convert::{TryFrom, TryInto},
|
convert::{TryFrom, TryInto},
|
||||||
|
future,
|
||||||
io::Cursor,
|
io::Cursor,
|
||||||
str::FromStr,
|
str::FromStr,
|
||||||
|
sync::Arc,
|
||||||
time::Duration,
|
time::Duration,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -2995,17 +2997,18 @@ mod test {
|
||||||
event_id,
|
event_id,
|
||||||
events::{
|
events::{
|
||||||
room::{
|
room::{
|
||||||
|
member::MemberEventContent,
|
||||||
message::{ImageMessageEventContent, MessageEventContent},
|
message::{ImageMessageEventContent, MessageEventContent},
|
||||||
ImageInfo,
|
ImageInfo,
|
||||||
},
|
},
|
||||||
AnyMessageEventContent, AnySyncStateEvent, EventType,
|
AnyMessageEventContent, AnySyncStateEvent, EventType, SyncStateEvent,
|
||||||
},
|
},
|
||||||
mxc_uri, room_id, thirdparty, uint, user_id, UserId,
|
mxc_uri, room_id, thirdparty, uint, user_id, UserId,
|
||||||
};
|
};
|
||||||
use serde_json::json;
|
use serde_json::json;
|
||||||
|
|
||||||
use super::{Client, Session, SyncSettings, Url};
|
use super::{Client, Session, SyncSettings, Url};
|
||||||
use crate::{ClientConfig, HttpError, RequestConfig, RoomMember};
|
use crate::{room, ClientConfig, HttpError, RequestConfig, RoomMember};
|
||||||
|
|
||||||
async fn logged_in_client() -> Client {
|
async fn logged_in_client() -> Client {
|
||||||
let session = Session {
|
let session = Session {
|
||||||
|
@ -3265,6 +3268,56 @@ mod test {
|
||||||
// assert_eq!(1, ignored_users.len())
|
// assert_eq!(1, ignored_users.len())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[tokio::test]
|
||||||
|
async fn event_handler() {
|
||||||
|
use std::sync::atomic::{AtomicU8, Ordering::SeqCst};
|
||||||
|
|
||||||
|
let client = logged_in_client().await;
|
||||||
|
|
||||||
|
let member_count = Arc::new(AtomicU8::new(0));
|
||||||
|
let typing_count = Arc::new(AtomicU8::new(0));
|
||||||
|
let power_levels_count = Arc::new(AtomicU8::new(0));
|
||||||
|
|
||||||
|
client
|
||||||
|
.register_event_handler({
|
||||||
|
let member_count = member_count.clone();
|
||||||
|
move |_ev: SyncStateEvent<MemberEventContent>, _room: room::Room| {
|
||||||
|
member_count.fetch_add(1, SeqCst);
|
||||||
|
future::ready(())
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.await
|
||||||
|
.register_event_handler({
|
||||||
|
let typing_count = typing_count.clone();
|
||||||
|
move |_ev: SyncStateEvent<MemberEventContent>| {
|
||||||
|
typing_count.fetch_add(1, SeqCst);
|
||||||
|
future::ready(())
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.await
|
||||||
|
.register_event_handler({
|
||||||
|
let power_levels_count = power_levels_count.clone();
|
||||||
|
move |_ev: SyncStateEvent<MemberEventContent>,
|
||||||
|
_client: Client,
|
||||||
|
_room: room::Room| {
|
||||||
|
power_levels_count.fetch_add(1, SeqCst);
|
||||||
|
future::ready(())
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.await;
|
||||||
|
|
||||||
|
let response = EventBuilder::default()
|
||||||
|
.add_room_event(EventsJson::Member)
|
||||||
|
.add_ephemeral(EventsJson::Typing)
|
||||||
|
.add_state_event(EventsJson::PowerLevels)
|
||||||
|
.build_sync_response();
|
||||||
|
client.process_sync(response).await.unwrap();
|
||||||
|
|
||||||
|
assert_eq!(member_count.load(SeqCst), 1);
|
||||||
|
assert_eq!(typing_count.load(SeqCst), 1);
|
||||||
|
assert_eq!(power_levels_count.load(SeqCst), 1);
|
||||||
|
}
|
||||||
|
|
||||||
#[tokio::test]
|
#[tokio::test]
|
||||||
async fn room_creation() {
|
async fn room_creation() {
|
||||||
let client = logged_in_client().await;
|
let client = logged_in_client().await;
|
||||||
|
|
Loading…
Reference in a new issue