diff options
author | Ryuta Kamizono <kamipo@gmail.com> | 2018-06-30 16:56:41 +0900 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-06-30 16:56:41 +0900 |
commit | d1062732aee590dd0c557dd486356864b32b34f0 (patch) | |
tree | e31bb735e69f2688e581d9da440a1c3e2bda801c /activesupport | |
parent | a9692941600c34afbc8d60d15cb5f179d30f67e5 (diff) | |
parent | 5394be374dd20c34ddf128cfd04d6b80096a4acb (diff) | |
download | rails-d1062732aee590dd0c557dd486356864b32b34f0.tar.gz rails-d1062732aee590dd0c557dd486356864b32b34f0.tar.bz2 rails-d1062732aee590dd0c557dd486356864b32b34f0.zip |
Merge pull request #33264 from huacnlee/fix-redis-incr-ttl-check
Fix Cache :redis_store increment/decrement ttl check and add more tests.
Diffstat (limited to 'activesupport')
-rw-r--r-- | activesupport/lib/active_support/cache/redis_cache_store.rb | 4 | ||||
-rw-r--r-- | activesupport/test/cache/stores/redis_cache_store_test.rb | 24 |
2 files changed, 22 insertions, 6 deletions
diff --git a/activesupport/lib/active_support/cache/redis_cache_store.rb b/activesupport/lib/active_support/cache/redis_cache_store.rb index 95f8f639e8..a05718b663 100644 --- a/activesupport/lib/active_support/cache/redis_cache_store.rb +++ b/activesupport/lib/active_support/cache/redis_cache_store.rb @@ -264,7 +264,7 @@ module ActiveSupport failsafe :increment do redis.with do |c| val = c.incrby key, amount - if expires_in > 0 && c.ttl(key) == -2 + if expires_in > 0 && c.ttl(key) < 0 c.expire key, expires_in end val @@ -290,7 +290,7 @@ module ActiveSupport failsafe :decrement do redis.with do |c| val = c.decrby key, amount - if expires_in > 0 && c.ttl(key) == -2 + if expires_in > 0 && c.ttl(key) < 0 c.expire key, expires_in end val diff --git a/activesupport/test/cache/stores/redis_cache_store_test.rb b/activesupport/test/cache/stores/redis_cache_store_test.rb index a2165e1978..845254ac69 100644 --- a/activesupport/test/cache/stores/redis_cache_store_test.rb +++ b/activesupport/test/cache/stores/redis_cache_store_test.rb @@ -145,24 +145,40 @@ module ActiveSupport::Cache::RedisCacheStoreTests def test_increment_expires_in assert_called_with @cache.redis, :incrby, [ "#{@namespace}:foo", 1 ] do assert_called_with @cache.redis, :expire, [ "#{@namespace}:foo", 60 ] do - @cache.increment("foo", 1, expires_in: 60) + @cache.increment "foo", 1, expires_in: 60 end end + # key and ttl exist + @cache.redis.setex "#{@namespace}:bar", 120, 1 assert_not_called @cache.redis, :expire do - @cache.decrement("foo", 1, expires_in: 60) + @cache.increment "bar", 1, expires_in: 120 + end + + # key exist but not have expire + @cache.redis.set "#{@namespace}:dar", 10 + assert_called_with @cache.redis, :expire, [ "#{@namespace}:dar", 60 ] do + @cache.increment "dar", 1, expires_in: 60 end end def test_decrement_expires_in assert_called_with @cache.redis, :decrby, [ "#{@namespace}:foo", 1 ] do assert_called_with @cache.redis, :expire, [ "#{@namespace}:foo", 60 ] do - @cache.decrement("foo", 1, expires_in: 60) + @cache.decrement "foo", 1, expires_in: 60 end end + # key and ttl exist + @cache.redis.setex "#{@namespace}:bar", 120, 1 assert_not_called @cache.redis, :expire do - @cache.decrement("foo", 1, expires_in: 60) + @cache.decrement "bar", 1, expires_in: 120 + end + + # key exist but not have expire + @cache.redis.set "#{@namespace}:dar", 10 + assert_called_with @cache.redis, :expire, [ "#{@namespace}:dar", 60 ] do + @cache.decrement "dar", 1, expires_in: 60 end end end |