Skip to content

Commit

Permalink
test(room): Improve Room::room_member_updates_sender tests
Browse files Browse the repository at this point in the history
  • Loading branch information
jmartinesp committed Dec 19, 2024
1 parent 487b3dc commit f53a16d
Show file tree
Hide file tree
Showing 2 changed files with 76 additions and 2 deletions.
12 changes: 12 additions & 0 deletions crates/matrix-sdk/src/test_utils/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -117,6 +117,18 @@ macro_rules! assert_next_with_timeout {
}};
}

/// Asserts the next item in a `Receiver` can be loaded in the given timeout in
/// milliseconds.
#[macro_export]
macro_rules! assert_recv_with_timeout {
($receiver:expr, $timeout_ms:expr) => {{
tokio::time::timeout(std::time::Duration::from_millis($timeout_ms), $receiver.recv())
.await
.expect("Next event timed out")
.expect("No next event received")
}};
}

/// Assert the next item in a `Stream` or `Subscriber` matches the provided
/// pattern in the given timeout in milliseconds.
///
Expand Down
66 changes: 64 additions & 2 deletions crates/matrix-sdk/tests/integration/room/joined.rs
Original file line number Diff line number Diff line change
@@ -1,16 +1,18 @@
use std::{
collections::BTreeSet,
sync::{Arc, Mutex},
time::Duration,
};

use assert_matches2::assert_let;
use futures_util::{future::join_all, pin_mut};
use matrix_sdk::{
assert_next_with_timeout,
assert_next_with_timeout, assert_recv_with_timeout,
config::SyncSettings,
room::{edit::EditedContent, Receipts, ReportedContentScore, RoomMemberRole},
test_utils::mocks::MatrixMockServer,
};
use matrix_sdk_base::RoomState;
use matrix_sdk_base::{RoomMembersUpdate, RoomState};
use matrix_sdk_test::{
async_test,
event_factory::EventFactory,
Expand Down Expand Up @@ -1156,3 +1158,63 @@ async fn test_subscribe_to_knock_requests_clears_seen_ids_on_member_reload() {

handle.abort();
}

#[async_test]
async fn test_room_member_updates_sender_on_full_member_reload() {
use assert_matches::assert_matches;
let server = MatrixMockServer::new().await;
let client = server.client_builder().build().await;

let room_id = room_id!("!a:b.c");
let room = server.sync_joined_room(&client, room_id).await;

let mut receiver = room.room_member_updates_sender.subscribe();
assert!(receiver.is_empty());

// When loading the full room member list
let user_id = user_id!("@alice:b.c");
let joined_event = EventFactory::new()
.room(room_id)
.event(RoomMemberEventContent::new(MembershipState::Join))
.sender(user_id)
.state_key(user_id)
.into_raw_timeline()
.cast();
server.mock_get_members().ok(vec![joined_event]).mock_once().mount().await;
room.sync_members().await.expect("could not reload room members");

// The member updates sender emits a full reload
let next = assert_recv_with_timeout!(receiver, 100);
assert_matches!(next, RoomMembersUpdate::FullReload);
}

#[async_test]
async fn test_room_member_updates_sender_on_partial_members_update() {
let server = MatrixMockServer::new().await;
let client = server.client_builder().build().await;

let room_id = room_id!("!a:b.c");
let room = server.sync_joined_room(&client, room_id).await;

let mut receiver = room.room_member_updates_sender.subscribe();
assert!(receiver.is_empty());

// When loading a few room member updates
let user_id = user_id!("@alice:b.c");
let joined_event = EventFactory::new()
.room(room_id)
.event(RoomMemberEventContent::new(MembershipState::Join))
.sender(user_id)
.state_key(user_id)
.into_raw_sync()
.cast();
server
.sync_room(&client, JoinedRoomBuilder::new(room_id).add_state_bulk(vec![joined_event]))
.await;

// The member updates sender emits a partial update with the user ids of the
// members
let next = assert_recv_with_timeout!(receiver, 100);
assert_let!(RoomMembersUpdate::Partial(user_ids) = next);
assert_eq!(user_ids, BTreeSet::from_iter(vec![user_id!("@alice:b.c").to_owned()]));
}

0 comments on commit f53a16d

Please sign in to comment.