cache 0.2.7 → 0.3.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,14 @@
1
+ require 'cache/active_support_cache_store'
2
+ module Cache::ActiveSupportCacheDalliStore
3
+ def self.extended(base)
4
+ base.extend Cache::ActiveSupportCacheStore
5
+ end
6
+
7
+ def after_fork
8
+ @metal.reset
9
+ end
10
+
11
+ def _stats
12
+ @metal.stats
13
+ end
14
+ end
@@ -0,0 +1,10 @@
1
+ require 'cache/active_support_cache_store'
2
+ module Cache::ActiveSupportCacheMemoryStore
3
+ def self.extended(base)
4
+ base.extend Cache::ActiveSupportCacheStore
5
+ end
6
+
7
+ def _stats
8
+ {}
9
+ end
10
+ end
@@ -0,0 +1,37 @@
1
+ module Cache::ActiveSupportCacheStore
2
+ # native
3
+ def fetch(k, ttl = nil, &blk)
4
+ handle_fork
5
+ @metal.fetch k, { :expires_in => extract_ttl(ttl) }, &blk
6
+ end
7
+ # --
8
+
9
+ def _get(k)
10
+ @metal.read k
11
+ end
12
+
13
+ def _get_multi(ks)
14
+ @metal.read_multi *ks
15
+ end
16
+
17
+ def _set(k, v, ttl)
18
+ if ttl == 0
19
+ @metal.write k, v # never expire
20
+ else
21
+ @metal.write k, v, :expires_in => ttl
22
+ end
23
+ end
24
+
25
+ def _delete(k)
26
+ @metal.delete k
27
+ end
28
+
29
+ def _flush
30
+ @metal.clear
31
+ end
32
+
33
+ def _exist?(k)
34
+ @metal.exist? k
35
+ # !get(k).nil?
36
+ end
37
+ end
data/lib/cache/config.rb CHANGED
@@ -11,30 +11,6 @@ class Cache
11
11
  @parent = parent
12
12
  end
13
13
 
14
- # The cache client to use.
15
- #
16
- # Note that you normally just set this when you initialize a Cache object.
17
- #
18
- # Example:
19
- # cache.config.client = Memcached.new '127.0.0.1:11211'
20
- def client=(client) #:nodoc:
21
- @client = client.is_a?(::Cache) ? client.config.client : client
22
- end
23
-
24
- def client #:nodoc:
25
- if @client.nil?
26
- self.client = if defined?(::Rails) and ::Rails.respond_to?(:cache) and rails_cache = ::Rails.cache and not rails_cache.is_a?(::Cache)
27
- rails_cache
28
- else
29
- require 'active_support/cache'
30
- require 'active_support/cache/memory_store'
31
- ::ActiveSupport::Cache::MemoryStore.new
32
- end
33
- else
34
- @client
35
- end
36
- end
37
-
38
14
  # TTL for method caches. Defaults to 60 seconds.
39
15
  #
40
16
  # Example:
@@ -46,13 +22,5 @@ class Cache
46
22
  def default_ttl #:nodoc:
47
23
  @default_ttl || 60
48
24
  end
49
-
50
- def logger #:nodoc:
51
- @logger
52
- end
53
-
54
- def logger=(logger) #:nodoc:
55
- @logger = logger
56
- end
57
25
  end
58
26
  end
@@ -0,0 +1,46 @@
1
+ module Cache::DalliClient
2
+ def after_fork
3
+ @metal.close
4
+ end
5
+
6
+ def _get(k)
7
+ @metal.get k
8
+ end
9
+
10
+ def _get_multi(ks)
11
+ @metal.get_multi ks
12
+ end
13
+
14
+ def _set(k, v, ttl)
15
+ @metal.set k, v, ttl
16
+ end
17
+
18
+ def _delete(k)
19
+ @metal.delete k
20
+ end
21
+
22
+ def _flush
23
+ @metal.flush
24
+ end
25
+
26
+ # sux
27
+ def _exist?(k)
28
+ !@metal.get(k).nil?
29
+ end
30
+
31
+ def _stats
32
+ @metal.stats
33
+ end
34
+
35
+ # native
36
+ def fetch(k, ttl = nil, &blk)
37
+ handle_fork
38
+ @metal.fetch k, extract_ttl(ttl), &blk
39
+ end
40
+
41
+ def cas(k, ttl = nil, &blk)
42
+ handle_fork
43
+ @metal.cas k, extract_ttl(ttl), &blk
44
+ end
45
+ # --
46
+ end
@@ -0,0 +1,41 @@
1
+ module Cache::MemCache
2
+ def after_fork
3
+ @metal.reset
4
+ end
5
+
6
+ def _get(k)
7
+ @metal.get k
8
+ end
9
+
10
+ def _get_multi(ks)
11
+ @metal.get_multi ks
12
+ end
13
+
14
+ def _set(k, v, ttl)
15
+ @metal.set k, v, ttl
16
+ end
17
+
18
+ def _delete(k)
19
+ @metal.delete k
20
+ end
21
+
22
+ def _flush
23
+ @metal.flush_all
24
+ end
25
+
26
+ # sux
27
+ def _exist?(k)
28
+ !@metal.get(k).nil?
29
+ end
30
+
31
+ def _stats
32
+ @metal.stats
33
+ end
34
+
35
+ # native
36
+ def fetch(k, ttl = nil, &blk)
37
+ handle_fork
38
+ @metal.fetch k, extract_ttl(ttl), &blk
39
+ end
40
+ # --
41
+ end
@@ -0,0 +1,47 @@
1
+ module Cache::Memcached
2
+ def thread_metal
3
+ ::Thread.current["#{@pid}/#{self.class.name}/#{object_id}/thread_metal"] ||= @metal.clone
4
+ end
5
+
6
+ def _get(k)
7
+ thread_metal.get k
8
+ rescue ::Memcached::NotFound
9
+ # oh well
10
+ end
11
+
12
+ def _get_multi(ks)
13
+ thread_metal.get ks
14
+ end
15
+
16
+ def _set(k, v, ttl)
17
+ thread_metal.set k, v, ttl
18
+ end
19
+
20
+ def _delete(k)
21
+ thread_metal.delete k
22
+ rescue ::Memcached::NotFound
23
+ end
24
+
25
+ def _flush
26
+ thread_metal.flush
27
+ end
28
+
29
+ def _exist?(k)
30
+ thread_metal.get k
31
+ true
32
+ rescue ::Memcached::NotFound
33
+ false
34
+ end
35
+
36
+ def _stats
37
+ thread_metal.stats
38
+ end
39
+
40
+ # native
41
+ def cas(k, ttl = nil, &blk)
42
+ handle_fork
43
+ thread_metal.cas k, extract_ttl(ttl), &blk
44
+ rescue ::Memcached::NotFound
45
+ end
46
+ # --
47
+ end
@@ -0,0 +1,33 @@
1
+ require 'cache/memcached'
2
+ module Cache::MemcachedRails
3
+ def self.extended(base)
4
+ base.extend Cache::Memcached
5
+ base.extend Override
6
+ end
7
+
8
+ module Override
9
+ def _exist?(k)
10
+ thread_metal.exist? k
11
+ # !get(k).nil?
12
+ end
13
+
14
+ def _get(k)
15
+ thread_metal.get k
16
+ end
17
+
18
+ def _get_multi(ks)
19
+ thread_metal.get_multi ks
20
+ end
21
+
22
+ def _delete(k)
23
+ thread_metal.delete k
24
+ end
25
+
26
+ # native
27
+ def cas(k, ttl = nil, &blk)
28
+ handle_fork
29
+ thread_metal.cas k, extract_ttl(ttl), &blk
30
+ end
31
+ # --
32
+ end
33
+ end
@@ -0,0 +1,38 @@
1
+ module Cache::Redis
2
+ def _get(k)
3
+ if cached_v = @metal.get(k) and cached_v.is_a?(::String)
4
+ ::Marshal.load cached_v
5
+ end
6
+ end
7
+
8
+ def _get_multi(ks)
9
+ ks.inject({}) do |memo, k|
10
+ memo[k] = @metal.get(k) if @metal.exist?(k)
11
+ memo
12
+ end
13
+ end
14
+
15
+ def _set(k, v, ttl)
16
+ if ttl == 0
17
+ @metal.set k, ::Marshal.dump(v)
18
+ else
19
+ @metal.setex k, ttl, ::Marshal.dump(v)
20
+ end
21
+ end
22
+
23
+ def _delete(k)
24
+ @metal.del k
25
+ end
26
+
27
+ def _flush
28
+ @metal.flush
29
+ end
30
+
31
+ def _exist?(k)
32
+ @metal.exists k
33
+ end
34
+
35
+ def _stats
36
+ @metal.stats
37
+ end
38
+ end
@@ -0,0 +1,6 @@
1
+ require 'cache/redis_namespace'
2
+ module Cache::RedisNamespace
3
+ def self.extended(base)
4
+ base.extend Cache::Redis
5
+ end
6
+ end
data/lib/cache/version.rb CHANGED
@@ -1,4 +1,4 @@
1
1
  class Cache
2
- VERSION = "0.2.7"
2
+ VERSION = "0.3.0"
3
3
  end
4
4
 
data/test/helper.rb CHANGED
@@ -6,6 +6,10 @@ $LOAD_PATH.unshift(File.join(File.dirname(__FILE__), '..', 'lib'))
6
6
  $LOAD_PATH.unshift(File.dirname(__FILE__))
7
7
  require 'cache'
8
8
 
9
+ if ::Bundler.definition.specs['ruby-debug19'].first or ::Bundler.definition.specs['ruby-debug'].first
10
+ require 'ruby-debug'
11
+ end
12
+
9
13
  require 'shared_tests'
10
14
 
11
15
  class Test::Unit::TestCase
data/test/shared_tests.rb CHANGED
@@ -1,5 +1,3 @@
1
- require 'logger'
2
-
3
1
  module SharedTests
4
2
  def test_get
5
3
  assert_equal nil, @cache.get('hello')
@@ -58,22 +56,7 @@ module SharedTests
58
56
  @cache.stats
59
57
  end
60
58
  end
61
-
62
- def test_logger
63
- assert_equal nil, @cache.logger
64
- l = Logger.new $stderr
65
- @cache.logger = l
66
- assert_equal l, @cache.logger
67
- end
68
-
69
- def test_reset
70
- @cache.set 'hello', 'world'
71
- assert @cache.exist?('hello')
72
- @cache.reset
73
- # still there!
74
- assert @cache.exist?('hello')
75
- end
76
-
59
+
77
60
  def test_fetch
78
61
  assert_equal nil, @cache.fetch('hello')
79
62
  assert_equal 'world', @cache.fetch('hello') { 'world' }
@@ -10,7 +10,7 @@ class TestDalliStorage < Test::Unit::TestCase
10
10
  include SharedTests
11
11
 
12
12
  def get_ring_object_id
13
- @cache.config.client.instance_variable_get(:@ring).object_id
13
+ @cache.metal.instance_variable_get(:@ring).object_id
14
14
  end
15
15
 
16
16
  def test_treats_as_thread_safe
@@ -12,7 +12,7 @@ class TestDalliStoreStorage < Test::Unit::TestCase
12
12
  include SharedTests
13
13
 
14
14
  def get_ring_object_id
15
- hidden_dalli_client = @cache.config.client.instance_variable_get :@data
15
+ hidden_dalli_client = @cache.metal.instance_variable_get :@data
16
16
  hidden_dalli_client.instance_variable_get(:@ring).object_id
17
17
  end
18
18
 
@@ -6,27 +6,27 @@ class TestDefaultStorage < Test::Unit::TestCase
6
6
  end
7
7
 
8
8
  def test_query
9
- assert @cache.storage.send(:memory_store?)
9
+ assert_equal ActiveSupport::Cache::MemoryStore, @cache.metal.class
10
10
  end
11
11
 
12
12
  def test_default
13
13
  c = Cache.new
14
- assert_equal ActiveSupport::Cache::MemoryStore, c.config.client.class
14
+ assert_equal ActiveSupport::Cache::MemoryStore, c.metal.class
15
15
  end
16
16
 
17
17
  def test_self_reference
18
18
  c = Cache.new(Cache.new)
19
- assert_equal ActiveSupport::Cache::MemoryStore, c.config.client.class
19
+ assert_equal ActiveSupport::Cache::MemoryStore, c.metal.class
20
20
  end
21
21
 
22
22
  def test_wrap_with_default
23
23
  c = Cache.wrap(Cache.new)
24
- assert_equal ActiveSupport::Cache::MemoryStore, c.config.client.class
24
+ assert_equal ActiveSupport::Cache::MemoryStore, c.metal.class
25
25
  end
26
26
 
27
27
  def test_absurd_wrap
28
28
  c = Cache.new(Cache.wrap(Cache.new))
29
- assert_equal ActiveSupport::Cache::MemoryStore, c.config.client.class
29
+ assert_equal ActiveSupport::Cache::MemoryStore, c.metal.class
30
30
  end
31
31
 
32
32
  include SharedTests
@@ -11,7 +11,7 @@ class TestMemcacheStorage < Test::Unit::TestCase
11
11
  include SharedTests
12
12
 
13
13
  def get_server_status_ids
14
- @cache.config.client.instance_variable_get(:@servers).map { |s| s.status.object_id }
14
+ @cache.metal.instance_variable_get(:@servers).map { |s| s.status.object_id }
15
15
  end
16
16
 
17
17
  def test_treats_as_thread_safe