From c181db631fb2dacc285c827eed1438ba0ce9ae49 Mon Sep 17 00:00:00 2001 From: Hocuri Date: Tue, 19 Nov 2024 16:59:05 +0100 Subject: [PATCH] feat: Clear config cache in start_io() (#6228) This is needed for iOS (https://github.com/deltachat/deltachat-ios/pull/2393), see comment in the code. An alternative would be to add an API `invalidate_config_cache()` or to do nothing and just assume that things will be fine. --- src/context.rs | 45 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) diff --git a/src/context.rs b/src/context.rs index 40bf95fbd9..dd1b5e73ea 100644 --- a/src/context.rs +++ b/src/context.rs @@ -472,6 +472,14 @@ impl Context { // Allow at least 1 message every second + a burst of 3. *lock = Ratelimit::new(Duration::new(3, 0), 3.0); } + + // The next line is mainly for iOS: + // iOS starts a separate process for receiving notifications and if the user concurrently + // starts the app, the UI process opens the database but waits with calling start_io() + // until the notifications process finishes. + // Now, some configs may have changed, so, we need to invalidate the cache. + self.sql.config_cache.write().await.clear(); + self.scheduler.start(self.clone()).await; } @@ -2064,4 +2072,41 @@ mod tests { Ok(()) } + + #[tokio::test(flavor = "multi_thread", worker_threads = 2)] + async fn test_cache_is_cleared_when_io_is_started() -> Result<()> { + let alice = TestContext::new_alice().await; + assert_eq!( + alice.get_config(Config::ShowEmails).await?, + Some("2".to_string()) + ); + + // Change the config circumventing the cache + // This simulates what the notfication plugin on iOS might do + // because it runs in a different process + alice + .sql + .execute( + "INSERT OR REPLACE INTO config (keyname, value) VALUES ('show_emails', '0')", + (), + ) + .await?; + + // Alice's Delta Chat doesn't know about it yet: + assert_eq!( + alice.get_config(Config::ShowEmails).await?, + Some("2".to_string()) + ); + + // Starting IO will fail of course because no server settings are configured, + // but it should invalidate the caches: + alice.start_io().await; + + assert_eq!( + alice.get_config(Config::ShowEmails).await?, + Some("0".to_string()) + ); + + Ok(()) + } }