diff --git a/xmtp_mls/src/builder.rs b/xmtp_mls/src/builder.rs index 98717c4f4..f8411744e 100644 --- a/xmtp_mls/src/builder.rs +++ b/xmtp_mls/src/builder.rs @@ -206,7 +206,7 @@ where ) .await?; - let mut client = Client::new( + let client = Client::new( api_client_wrapper, identity, store, diff --git a/xmtp_mls/src/client.rs b/xmtp_mls/src/client.rs index a06c22aff..f43d4579a 100644 --- a/xmtp_mls/src/client.rs +++ b/xmtp_mls/src/client.rs @@ -31,11 +31,13 @@ use xmtp_proto::xmtp::mls::api::v1::{ GroupMessage, WelcomeMessage, }; +#[cfg(feature = "test-utils")] +use crate::groups::device_sync::WorkerHandle; + use crate::{ api::ApiClientWrapper, groups::{ - device_sync::{preference_sync::UserPreferenceUpdate, WorkerHandle}, - group_permissions::PolicySet, + device_sync::preference_sync::UserPreferenceUpdate, group_permissions::PolicySet, GroupError, GroupMetadataOptions, MlsGroup, }, identity::{parse_credential, Identity, IdentityError}, @@ -144,9 +146,11 @@ pub struct Client> { pub(crate) context: Arc, pub(crate) history_sync_url: Option, pub(crate) local_events: broadcast::Sender>, - sync_worker_handle: Arc>>>, /// The method of verifying smart contract wallet signatures for this Client pub(crate) scw_verifier: Arc, + + #[cfg(feature = "test-utils")] + sync_worker_handle: Arc>>>, } // most of these things are `Arc`'s @@ -157,8 +161,10 @@ impl Clone for Client { context: self.context.clone(), history_sync_url: self.history_sync_url.clone(), local_events: self.local_events.clone(), - sync_worker_handle: self.sync_worker_handle.clone(), scw_verifier: self.scw_verifier.clone(), + + #[cfg(feature = "test-utils")] + sync_worker_handle: self.sync_worker_handle.clone(), } } } @@ -244,6 +250,7 @@ where context, history_sync_url, local_events: tx, + #[cfg(feature = "test-utils")] sync_worker_handle: Arc::new(Mutex::default()), scw_verifier: scw_verifier.into(), } @@ -253,10 +260,12 @@ where &self.scw_verifier } + #[cfg(feature = "test-utils")] pub fn sync_worker_handle(&self) -> Option> { self.sync_worker_handle.lock().clone() } + #[cfg(feature = "test-utils")] pub(crate) fn set_sync_worker_handle(&self, handle: Arc) { *self.sync_worker_handle.lock() = Some(handle); } diff --git a/xmtp_mls/src/groups/device_sync.rs b/xmtp_mls/src/groups/device_sync.rs index 6d1408bb6..c20451cb7 100644 --- a/xmtp_mls/src/groups/device_sync.rs +++ b/xmtp_mls/src/groups/device_sync.rs @@ -134,6 +134,7 @@ where ); let worker = SyncWorker::new(client); + #[cfg(feature = "test-utils")] self.set_sync_worker_handle(worker.handle.clone()); worker.spawn_worker(); } @@ -150,13 +151,17 @@ pub struct SyncWorker { retry: Retry, // Number of events processed + #[cfg(feature = "test-utils")] handle: Arc, } +#[cfg(feature = "test-utils")] pub struct WorkerHandle { processed: AtomicUsize, notify: Notify, } + +#[cfg(feature = "test-utils")] impl WorkerHandle { pub async fn wait_for_new_events(&self, mut count: usize) -> Result<(), Elapsed> { timeout(Duration::from_secs(3), async { @@ -233,8 +238,11 @@ where _ => {} } - self.handle.processed.fetch_add(1, Ordering::SeqCst); - self.handle.notify.notify_waiters(); + #[cfg(feature = "test-utils")] + { + self.handle.processed.fetch_add(1, Ordering::SeqCst); + self.handle.notify.notify_waiters(); + } } Ok(()) } @@ -360,6 +368,7 @@ where init: OnceCell::new(), retry, + #[cfg(feature = "test-utils")] handle: Arc::new(WorkerHandle { processed: AtomicUsize::new(0), notify: Notify::new(),