From 85fb3b2a6ab1069b6d0d43fea2300878c0ee4911 Mon Sep 17 00:00:00 2001 From: Benjamin Bouvier Date: Wed, 20 Nov 2024 13:07:04 +0100 Subject: [PATCH] task: add manual Sync impl for VerificationCache to avoid overflowing evaluation requirements --- crates/matrix-sdk-base/Cargo.toml | 2 +- crates/matrix-sdk-crypto/Cargo.toml | 5 +++++ crates/matrix-sdk-crypto/src/verification/cache.rs | 13 +++++++++++++ 3 files changed, 19 insertions(+), 1 deletion(-) diff --git a/crates/matrix-sdk-base/Cargo.toml b/crates/matrix-sdk-base/Cargo.toml index 65a3246d62e..c312798fb85 100644 --- a/crates/matrix-sdk-base/Cargo.toml +++ b/crates/matrix-sdk-base/Cargo.toml @@ -30,7 +30,7 @@ uniffi = ["dep:uniffi", "matrix-sdk-crypto?/uniffi", "matrix-sdk-common/uniffi"] # Private feature, see # https://github.com/matrix-org/matrix-rust-sdk/pull/3749#issuecomment-2312939823 for the gory # details. -test-send-sync = [] +test-send-sync = ["matrix-sdk-crypto?/test-send-sync"] # "message-ids" feature doesn't do anything and is deprecated. message-ids = [] diff --git a/crates/matrix-sdk-crypto/Cargo.toml b/crates/matrix-sdk-crypto/Cargo.toml index 12830bb60ca..de18989829e 100644 --- a/crates/matrix-sdk-crypto/Cargo.toml +++ b/crates/matrix-sdk-crypto/Cargo.toml @@ -23,6 +23,11 @@ experimental-algorithms = [] uniffi = ["dep:uniffi"] _disable-minimum-rotation-period-ms = [] +# Private feature, see +# https://github.com/matrix-org/matrix-rust-sdk/pull/3749#issuecomment-2312939823 for the gory +# details. +test-send-sync = [] + # "message-ids" feature doesn't do anything and is deprecated. message-ids = [] diff --git a/crates/matrix-sdk-crypto/src/verification/cache.rs b/crates/matrix-sdk-crypto/src/verification/cache.rs index c847abbad3a..8f770ba9cb2 100644 --- a/crates/matrix-sdk-crypto/src/verification/cache.rs +++ b/crates/matrix-sdk-crypto/src/verification/cache.rs @@ -33,6 +33,19 @@ pub struct VerificationCache { inner: Arc, } +// See https://github.com/matrix-org/matrix-rust-sdk/pull/3749#issuecomment-2312939823. +#[cfg(not(feature = "test-send-sync"))] +unsafe impl Sync for VerificationCache {} + +#[cfg(feature = "test-send-sync")] +#[test] +// See https://github.com/matrix-org/matrix-rust-sdk/pull/3749#issuecomment-2312939823. +fn test_send_sync_for_room() { + fn assert_send_sync() {} + + assert_send_sync::(); +} + #[derive(Debug, Default)] struct VerificationCacheInner { verification: StdRwLock>>,