matrix_sdk_test/sync_builder/
left_room.rsuse ruma::{
api::client::sync::sync_events::v3::LeftRoom,
events::{AnyRoomAccountDataEvent, AnySyncStateEvent, AnySyncTimelineEvent},
serde::Raw,
OwnedRoomId, RoomId,
};
use super::{RoomAccountDataTestEvent, StateTestEvent};
use crate::DEFAULT_TEST_ROOM_ID;
pub struct LeftRoomBuilder {
pub(super) room_id: OwnedRoomId,
pub(super) inner: LeftRoom,
}
impl LeftRoomBuilder {
pub fn new(room_id: &RoomId) -> Self {
Self { room_id: room_id.to_owned(), inner: Default::default() }
}
pub fn room_id(&self) -> &RoomId {
&self.room_id
}
pub fn add_timeline_event(mut self, event: impl Into<Raw<AnySyncTimelineEvent>>) -> Self {
self.inner.timeline.events.push(event.into());
self
}
pub fn add_timeline_bulk<I>(mut self, events: I) -> Self
where
I: IntoIterator<Item = Raw<AnySyncTimelineEvent>>,
{
self.inner.timeline.events.extend(events);
self
}
pub fn add_timeline_state_bulk<I>(self, events: I) -> Self
where
I: IntoIterator<Item = Raw<AnySyncStateEvent>>,
{
let events = events.into_iter().map(|event| event.cast());
self.add_timeline_bulk(events)
}
pub fn set_timeline_limited(mut self) -> Self {
self.inner.timeline.limited = true;
self
}
pub fn set_timeline_prev_batch(mut self, prev_batch: String) -> Self {
self.inner.timeline.prev_batch = Some(prev_batch);
self
}
pub fn add_state_event(mut self, event: StateTestEvent) -> Self {
self.inner.state.events.push(event.into_raw_event());
self
}
pub fn add_state_bulk<I>(mut self, events: I) -> Self
where
I: IntoIterator<Item = Raw<AnySyncStateEvent>>,
{
self.inner.state.events.extend(events);
self
}
pub fn add_account_data(mut self, event: RoomAccountDataTestEvent) -> Self {
self.inner.account_data.events.push(event.into_raw_event());
self
}
pub fn add_account_data_bulk<I>(mut self, events: I) -> Self
where
I: IntoIterator<Item = Raw<AnyRoomAccountDataEvent>>,
{
self.inner.account_data.events.extend(events);
self
}
}
impl Default for LeftRoomBuilder {
fn default() -> Self {
Self::new(&DEFAULT_TEST_ROOM_ID)
}
}