use log::info;
use crate::{
lib::alloc::{sync::Arc, vec, vec::Vec},
presence::event_engine::{
effects::LeaveEffectExecutor, PresenceEvent, PresenceInput, PresenceParameters,
},
};
#[allow(clippy::too_many_arguments, dead_code)]
pub(super) async fn execute(
input: &PresenceInput,
executor: &Arc<LeaveEffectExecutor>,
) -> Vec<PresenceEvent> {
let channel_groups = input.channel_groups();
let channels = input.channels();
info!(
"Leave\nchannels: {:?}\nchannel groups: {:?}",
channels, channel_groups
);
let _ = executor(PresenceParameters {
channels: &channels,
channel_groups: &channel_groups,
})
.await;
vec![]
}
#[cfg(test)]
mod it_should {
use futures::FutureExt;
use super::*;
use crate::{
core::{PubNubError, TransportResponse},
presence::LeaveResult,
};
#[tokio::test]
async fn return_leave_success_event() {
let mocked_leave_function: Arc<LeaveEffectExecutor> = Arc::new(move |parameters| {
assert_eq!(parameters.channel_groups, &Some(vec!["cg2".to_string()]));
assert_eq!(parameters.channels, &Some(vec!["ch2".to_string()]));
async move { Ok(LeaveResult) }.boxed()
});
let result = execute(
&PresenceInput::new(
&Some(vec!["ch2".to_string()]),
&Some(vec!["cg2".to_string()]),
),
&mocked_leave_function,
)
.await;
assert!(result.is_empty());
}
#[tokio::test]
async fn return_leave_failed_event_on_error() {
let mocked_leave_function: Arc<LeaveEffectExecutor> = Arc::new(move |_| {
async move {
Err(PubNubError::Transport {
details: "test".into(),
response: Some(Box::new(TransportResponse {
status: 500,
..Default::default()
})),
})
}
.boxed()
});
let result = execute(
&PresenceInput::new(
&Some(vec!["ch3".to_string()]),
&Some(vec!["cg3".to_string()]),
),
&mocked_leave_function,
)
.await;
assert!(result.is_empty());
}
}