From 92a15a519413b3933587472501a40293c9a13b0d Mon Sep 17 00:00:00 2001 From: Rebecca Turner Date: Sat, 6 Apr 2024 11:39:06 -0700 Subject: [PATCH] Make `cache_set_lifespan` the inverse of `cache_get_lifespan` This makes it possible to temporarily change a cache lifespan, or to remove a cache lifespan once it's set. See #197 for context. --- src/lib.rs | 6 ++++-- src/stores/disk.rs | 8 ++++---- src/stores/redis.rs | 18 ++++++++++-------- 3 files changed, 18 insertions(+), 14 deletions(-) diff --git a/src/lib.rs b/src/lib.rs index fa49324..efcebfe 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -419,7 +419,9 @@ pub trait IOCached { } /// Set the lifespan of cached values, returns the old value - fn cache_set_lifespan(&mut self, _seconds: u64) -> Option { + /// + /// If the lifespan is set to `None`, cached values do not expire. + fn cache_set_lifespan(&mut self, _seconds: Option) -> Option { None } } @@ -445,7 +447,7 @@ pub trait IOCachedAsync { } /// Set the lifespan of cached values, returns the old value - fn cache_set_lifespan(&mut self, _seconds: u64) -> Option { + fn cache_set_lifespan(&mut self, _seconds: Option) -> Option { None } } diff --git a/src/stores/disk.rs b/src/stores/disk.rs index 33a85e7..939021c 100644 --- a/src/stores/disk.rs +++ b/src/stores/disk.rs @@ -273,9 +273,9 @@ where self.seconds } - fn cache_set_lifespan(&mut self, seconds: u64) -> Option { + fn cache_set_lifespan(&mut self, seconds: Option) -> Option { let old = self.seconds; - self.seconds = Some(seconds); + self.seconds = seconds; old } @@ -346,7 +346,7 @@ mod tests { sleep(Duration::new(2, 500000)); assert!(c.cache_get(&1).unwrap().is_none()); - let old = c.cache_set_lifespan(1).unwrap(); + let old = c.cache_set_lifespan(Some(1)).unwrap(); assert_eq!(2, old); assert!(c.cache_set(1, 100).unwrap().is_none()); assert!(c.cache_get(&1).unwrap().is_some()); @@ -354,7 +354,7 @@ mod tests { sleep(Duration::new(1, 600000)); assert!(c.cache_get(&1).unwrap().is_none()); - c.cache_set_lifespan(10).unwrap(); + c.cache_set_lifespan(Some(10)).unwrap(); assert!(c.cache_set(1, 100).unwrap().is_none()); assert!(c.cache_set(2, 100).unwrap().is_none()); assert_eq!(c.cache_get(&1).unwrap().unwrap(), 100); diff --git a/src/stores/redis.rs b/src/stores/redis.rs index 8e95dc7..763512c 100644 --- a/src/stores/redis.rs +++ b/src/stores/redis.rs @@ -345,9 +345,11 @@ where Some(self.seconds) } - fn cache_set_lifespan(&mut self, seconds: u64) -> Option { + fn cache_set_lifespan(&mut self, seconds: Option) -> Option { let old = self.seconds; - self.seconds = seconds; + // Redis must have a cache TTL, so get as close to an unbounded cache as we can if + // the user wants values to never expire. + self.seconds = seconds.unwrap_or(u64::MAX); Some(old) } @@ -639,9 +641,9 @@ mod async_redis { } /// Set the lifespan of cached values, returns the old value - fn cache_set_lifespan(&mut self, seconds: u64) -> Option { + fn cache_set_lifespan(&mut self, seconds: Option) -> Option { let old = self.seconds; - self.seconds = seconds; + self.seconds = seconds.unwrap_or(u64::MAX); Some(old) } } @@ -675,7 +677,7 @@ mod async_redis { sleep(Duration::new(2, 500_000)); assert!(c.cache_get(&1).await.unwrap().is_none()); - let old = c.cache_set_lifespan(1).unwrap(); + let old = c.cache_set_lifespan(Some(1)).unwrap(); assert_eq!(2, old); assert!(c.cache_set(1, 100).await.unwrap().is_none()); assert!(c.cache_get(&1).await.unwrap().is_some()); @@ -683,7 +685,7 @@ mod async_redis { sleep(Duration::new(1, 600_000)); assert!(c.cache_get(&1).await.unwrap().is_none()); - c.cache_set_lifespan(10).unwrap(); + c.cache_set_lifespan(Some(10)).unwrap(); assert!(c.cache_set(1, 100).await.unwrap().is_none()); assert!(c.cache_set(2, 100).await.unwrap().is_none()); assert_eq!(c.cache_get(&1).await.unwrap().unwrap(), 100); @@ -736,7 +738,7 @@ mod tests { sleep(Duration::new(2, 500_000)); assert!(c.cache_get(&1).unwrap().is_none()); - let old = c.cache_set_lifespan(1).unwrap(); + let old = c.cache_set_lifespan(Some(1)).unwrap(); assert_eq!(2, old); assert!(c.cache_set(1, 100).unwrap().is_none()); assert!(c.cache_get(&1).unwrap().is_some()); @@ -744,7 +746,7 @@ mod tests { sleep(Duration::new(1, 600_000)); assert!(c.cache_get(&1).unwrap().is_none()); - c.cache_set_lifespan(10).unwrap(); + c.cache_set_lifespan(Some(10)).unwrap(); assert!(c.cache_set(1, 100).unwrap().is_none()); assert!(c.cache_set(2, 100).unwrap().is_none()); assert_eq!(c.cache_get(&1).unwrap().unwrap(), 100);