rails-brotli-cache 0.3.5 → 0.3.7
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +1 -0
- data/lib/rails-brotli-cache/store.rb +36 -5
- data/lib/rails-brotli-cache/version.rb +1 -1
- data/spec/rails-brotli-cache/compatibility_spec.rb +105 -0
- metadata +4 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 80eea251ed8707e59e4f8a9b829c7046dd9343edcd045e4ef83aa840d8fc5fae
|
4
|
+
data.tar.gz: fbe018c38651848f9aba05d3b59e96c802b7afddc36099cc8d5a5a1099fd3975
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: c4b1622f27a59b6b46067a5ee1d354a0696029e6ebdd71b8be913c59f021251a9862600b08ed12fb7111c7a9183bc07903227a3dc0f3d9ee1563e60de0546dc8
|
7
|
+
data.tar.gz: 80a043902519762f273c65ce864ed0c9e64397c72a3a750f513e335502b46e7c1876a8d28653147db01b4762ba28be3c8f2dd4657e06671d140959a4aa0f3c09
|
data/.gitignore
CHANGED
@@ -42,6 +42,13 @@ module RailsBrotliCache
|
|
42
42
|
end
|
43
43
|
|
44
44
|
def write(name, value, options = nil)
|
45
|
+
if value.is_a?(Integer)
|
46
|
+
return @core_store.write(
|
47
|
+
cache_key(name),
|
48
|
+
value
|
49
|
+
)
|
50
|
+
end
|
51
|
+
|
45
52
|
serialized = Marshal.dump(value)
|
46
53
|
options = (options || {}).reverse_merge(compress: true)
|
47
54
|
|
@@ -84,7 +91,29 @@ module RailsBrotliCache
|
|
84
91
|
Marshal.load(serialized)
|
85
92
|
end
|
86
93
|
|
87
|
-
|
94
|
+
def write_multi(hash, options = nil)
|
95
|
+
hash.each do |key, val|
|
96
|
+
write(key, val, options)
|
97
|
+
end
|
98
|
+
end
|
99
|
+
|
100
|
+
def read_multi(*names)
|
101
|
+
options = names.extract_options!
|
102
|
+
|
103
|
+
Hash[names.map do |name|
|
104
|
+
[name, read(name, options)]
|
105
|
+
end]
|
106
|
+
end
|
107
|
+
|
108
|
+
def fetch_multi(*names)
|
109
|
+
options = names.extract_options!
|
110
|
+
|
111
|
+
names.each do |name|
|
112
|
+
fetch(name, options) { yield(name) }
|
113
|
+
end
|
114
|
+
end
|
115
|
+
|
116
|
+
def exist?(name, options = nil)
|
88
117
|
@core_store.exist?(cache_key(name), options)
|
89
118
|
end
|
90
119
|
|
@@ -96,12 +125,14 @@ module RailsBrotliCache
|
|
96
125
|
@core_store.clear
|
97
126
|
end
|
98
127
|
|
99
|
-
def increment(
|
100
|
-
|
128
|
+
def increment(*args)
|
129
|
+
args[0] = cache_key(args[0])
|
130
|
+
@core_store.increment(*args)
|
101
131
|
end
|
102
132
|
|
103
|
-
def decrement(
|
104
|
-
|
133
|
+
def decrement(*args)
|
134
|
+
args[0] = cache_key(args[0])
|
135
|
+
@core_store.decrement(*args)
|
105
136
|
end
|
106
137
|
|
107
138
|
def self.supports_cache_versioning?
|
@@ -0,0 +1,105 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'spec_helper'
|
4
|
+
|
5
|
+
describe RailsBrotliCache do
|
6
|
+
|
7
|
+
CACHE_STORE_TYPES = [
|
8
|
+
[ActiveSupport::Cache::MemoryStore.new, ActiveSupport::Cache::MemoryStore.new],
|
9
|
+
[ActiveSupport::Cache::RedisCacheStore.new, ActiveSupport::Cache::RedisCacheStore.new],
|
10
|
+
[ActiveSupport::Cache::MemCacheStore.new, ActiveSupport::Cache::MemCacheStore.new],
|
11
|
+
[ActiveSupport::Cache::FileStore.new('./tmp'), ActiveSupport::Cache::FileStore.new('./tmp')],
|
12
|
+
[ActiveSupport::Cache::NullStore.new, ActiveSupport::Cache::NullStore.new]
|
13
|
+
]
|
14
|
+
|
15
|
+
CACHE_STORE_TYPES.each do |cache_store_types|
|
16
|
+
describe "Brotli cache has the same API as #{cache_store_types[0].class}" do
|
17
|
+
subject(:brotli_store) do
|
18
|
+
RailsBrotliCache::Store.new(cache_store_types[0])
|
19
|
+
end
|
20
|
+
|
21
|
+
let(:standard_cache) do
|
22
|
+
cache_store_types[1]
|
23
|
+
end
|
24
|
+
|
25
|
+
it "compares the same cache stores" do
|
26
|
+
expect(standard_cache.class).to eq(brotli_store.core_store.class)
|
27
|
+
end
|
28
|
+
|
29
|
+
it "for #clear" do
|
30
|
+
expect(brotli_store.clear.class).to eq(standard_cache.clear.class)
|
31
|
+
end
|
32
|
+
|
33
|
+
it "for #read and #write" do
|
34
|
+
int_val = 123
|
35
|
+
expect(brotli_store.write("int_val_key", int_val).class).to eq(standard_cache.write("int_val_key", int_val).class)
|
36
|
+
expect(brotli_store.read("int_val_key")).to eq(standard_cache.read("int_val_key"))
|
37
|
+
|
38
|
+
str_val = "str"
|
39
|
+
expect(brotli_store.write("str_val_key", int_val).class).to eq(standard_cache.write("str_val_key", int_val).class)
|
40
|
+
expect(brotli_store.read("str_val_key")).to eq(standard_cache.read("str_val_key"))
|
41
|
+
|
42
|
+
complex_val = OpenStruct.new(a: 1, b: 2)
|
43
|
+
expect(brotli_store.write("complex_val_key", int_val).class).to eq(standard_cache.write("complex_val_key", int_val).class)
|
44
|
+
expect(brotli_store.read("complex_val_key")).to eq(standard_cache.read("complex_val_key"))
|
45
|
+
end
|
46
|
+
|
47
|
+
it "for #increment and #decrement" do
|
48
|
+
expect(brotli_store.write("inc_val_key", 1).class).to eq(standard_cache.write("inc_val_key", 1).class)
|
49
|
+
expect(brotli_store.increment("inc_val_key").class).to eq(standard_cache.increment("inc_val_key").class)
|
50
|
+
expect(brotli_store.read("inc_val_key")).to eq(standard_cache.read("inc_val_key"))
|
51
|
+
expect(brotli_store.increment("inc_val_key", 2).class).to eq(standard_cache.increment("inc_val_key", 2).class)
|
52
|
+
expect(brotli_store.read("inc_val_key")).to eq(standard_cache.read("inc_val_key"))
|
53
|
+
expect(brotli_store.decrement("inc_val_key", 2).class).to eq(standard_cache.decrement("inc_val_key", 2).class)
|
54
|
+
expect(brotli_store.read("inc_val_key")).to eq(standard_cache.read("inc_val_key"))
|
55
|
+
end
|
56
|
+
|
57
|
+
it "for #fetch" do
|
58
|
+
val = "123"
|
59
|
+
expect(brotli_store.fetch("val_key") { val }).to eq(standard_cache.fetch("val_key") { val })
|
60
|
+
expect(brotli_store.fetch("val_key", force: true) { val }).to eq(standard_cache.fetch("val_key", force: true) { val })
|
61
|
+
expect(brotli_store.fetch("val_key")).to eq(standard_cache.fetch("val_key"))
|
62
|
+
end
|
63
|
+
|
64
|
+
it "for #write_multi and #read_multi" do
|
65
|
+
if standard_cache.class != ActiveSupport::Cache::NullStore ## NullStore does not support read/write multi
|
66
|
+
values = {
|
67
|
+
"key_1" => "val_1",
|
68
|
+
"key_2" => "val_2"
|
69
|
+
}
|
70
|
+
|
71
|
+
brotli_store.write_multi(values)
|
72
|
+
standard_cache.write_multi(values)
|
73
|
+
expect(brotli_store.read("key_1")).to eq "val_1"
|
74
|
+
expect(brotli_store.read("key_2")).to eq "val_2"
|
75
|
+
expect(standard_cache.read("key_1")).to eq "val_1"
|
76
|
+
expect(standard_cache.read("key_2")).to eq "val_2"
|
77
|
+
|
78
|
+
expect(brotli_store.read_multi("key_1", "key_2")).to eq(standard_cache.read_multi("key_1", "key_2"))
|
79
|
+
end
|
80
|
+
end
|
81
|
+
|
82
|
+
it "for #fetch_multi" do
|
83
|
+
if standard_cache.class != ActiveSupport::Cache::NullStore ## NullStore does not support fetch multi
|
84
|
+
values = {
|
85
|
+
"key_1" => "val_1",
|
86
|
+
"key_2" => "val_2"
|
87
|
+
}
|
88
|
+
|
89
|
+
brotli_store.fetch_multi("key_1", "key_2") do |key|
|
90
|
+
"val_#{key.split('_').last}"
|
91
|
+
end
|
92
|
+
|
93
|
+
standard_cache.fetch_multi("key_1", "key_2") do |key|
|
94
|
+
"val_#{key.split('_').last}"
|
95
|
+
end
|
96
|
+
|
97
|
+
expect(brotli_store.read("key_1")).to eq "val_1"
|
98
|
+
expect(brotli_store.read("key_2")).to eq "val_2"
|
99
|
+
|
100
|
+
expect(brotli_store.read_multi("key_1", "key_2")).to eq(standard_cache.read_multi("key_1", "key_2"))
|
101
|
+
end
|
102
|
+
end
|
103
|
+
end
|
104
|
+
end
|
105
|
+
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: rails-brotli-cache
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.3.
|
4
|
+
version: 0.3.7
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- pawurb
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2023-05-
|
11
|
+
date: 2023-05-27 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rails
|
@@ -158,6 +158,7 @@ files:
|
|
158
158
|
- spec/dummy/public/robots.txt
|
159
159
|
- spec/dummy/vendor/.keep
|
160
160
|
- spec/fixtures/sample.json
|
161
|
+
- spec/rails-brotli-cache/compatibility_spec.rb
|
161
162
|
- spec/rails-brotli-cache/rails_store_spec.rb
|
162
163
|
- spec/rails-brotli-cache/redis_spec.rb
|
163
164
|
- spec/rails-brotli-cache/store_spec.rb
|
@@ -230,6 +231,7 @@ test_files:
|
|
230
231
|
- spec/dummy/public/robots.txt
|
231
232
|
- spec/dummy/vendor/.keep
|
232
233
|
- spec/fixtures/sample.json
|
234
|
+
- spec/rails-brotli-cache/compatibility_spec.rb
|
233
235
|
- spec/rails-brotli-cache/rails_store_spec.rb
|
234
236
|
- spec/rails-brotli-cache/redis_spec.rb
|
235
237
|
- spec/rails-brotli-cache/store_spec.rb
|