diff options
author | Doug Barth <dougbarth@gmail.com> | 2008-10-09 10:47:32 -0500 |
---|---|---|
committer | Michael Koziarski <michael@koziarski.com> | 2008-10-17 18:09:27 +0200 |
commit | 4b63c2700ffc5c646af0e728d4ec2fcb6770671b (patch) | |
tree | e0b504b733cf534f5822f976f312e3fe6ec6e1f6 /activesupport | |
parent | c3d6205a4ba92e25f1092ac9c1f4e72ee3c796ed (diff) | |
download | rails-4b63c2700ffc5c646af0e728d4ec2fcb6770671b.tar.gz rails-4b63c2700ffc5c646af0e728d4ec2fcb6770671b.tar.bz2 rails-4b63c2700ffc5c646af0e728d4ec2fcb6770671b.zip |
Bring MemCacheStore and CompressedMemCacheStore inline with expected counter manipulation semantics.
Signed-off-by: Michael Koziarski <michael@koziarski.com>
Diffstat (limited to 'activesupport')
-rw-r--r-- | activesupport/lib/active_support/cache/compressed_mem_cache_store.rb | 9 | ||||
-rw-r--r-- | activesupport/lib/active_support/cache/mem_cache_store.rb | 3 | ||||
-rw-r--r-- | activesupport/test/caching_test.rb | 10 |
3 files changed, 10 insertions, 12 deletions
diff --git a/activesupport/lib/active_support/cache/compressed_mem_cache_store.rb b/activesupport/lib/active_support/cache/compressed_mem_cache_store.rb index 0bff6cf9ad..d87eb17337 100644 --- a/activesupport/lib/active_support/cache/compressed_mem_cache_store.rb +++ b/activesupport/lib/active_support/cache/compressed_mem_cache_store.rb @@ -3,12 +3,17 @@ module ActiveSupport class CompressedMemCacheStore < MemCacheStore def read(name, options = nil) if value = super(name, (options || {}).merge(:raw => true)) - Marshal.load(ActiveSupport::Gzip.decompress(value)) + if raw?(options) + value + else + Marshal.load(ActiveSupport::Gzip.decompress(value)) + end end end def write(name, value, options = nil) - super(name, ActiveSupport::Gzip.compress(Marshal.dump(value)), (options || {}).merge(:raw => true)) + value = ActiveSupport::Gzip.compress(Marshal.dump(value)) unless raw?(options) + super(name, value, (options || {}).merge(:raw => true)) end end end diff --git a/activesupport/lib/active_support/cache/mem_cache_store.rb b/activesupport/lib/active_support/cache/mem_cache_store.rb index 58958dccef..5531c30b7f 100644 --- a/activesupport/lib/active_support/cache/mem_cache_store.rb +++ b/activesupport/lib/active_support/cache/mem_cache_store.rb @@ -34,6 +34,9 @@ module ActiveSupport def write(key, value, options = nil) super method = options && options[:unless_exist] ? :add : :set + # memcache-client will break the connection if you send it an integer + # in raw mode, so we convert it to a string to be sure it continues working. + value = value.to_s if raw?(options) response = @data.send(method, key, value, expires_in(options), raw?(options)) response == Response::STORED rescue MemCache::MemCacheError => e diff --git a/activesupport/test/caching_test.rb b/activesupport/test/caching_test.rb index e2da2796eb..88c6d6cca4 100644 --- a/activesupport/test/caching_test.rb +++ b/activesupport/test/caching_test.rb @@ -159,11 +159,6 @@ class MemCacheStoreTest < Test::Unit::TestCase @cache.read('foo').gsub!(/.*/, 'baz') assert_equal 'bar', @cache.read('foo') end - - # Disabling increment and decrement tests until issues can be addressed in the - # upstream codebase. - def test_increment; end - def test_decrement; end end class CompressedMemCacheStore < Test::Unit::TestCase @@ -173,9 +168,4 @@ class CompressedMemCacheStore < Test::Unit::TestCase end include CacheStoreBehavior - - # Disabling increment and decrement tests until issues can be addressed in the - # upstream codebase. - def test_increment; end - def test_decrement; end end |