flexirest 1.12.3 → 1.12.4
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +6 -0
- data/lib/flexirest/caching.rb +6 -4
- data/lib/flexirest/version.rb +1 -1
- data/spec/lib/caching_spec.rb +45 -9
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 4b2b1b6afc271ee5ca051d711746396685574b2a7f18ca06919f48dbdd4bbafc
|
4
|
+
data.tar.gz: 10a84526cef840be253ff7fc36fc1571f7fbb463e11a900a11142b895cd8ebaa
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: bb7b781df1bd6f64482c6b672ac397bef31b5a0717f677db8c03988aee79253b95962136e835131fc55794f48828df6f35b3d9b36f9156e7fce5d41d3af9098d
|
7
|
+
data.tar.gz: 586b813a1a098c15a7c0f56267c044ac46649c97cd0a933960bbcc19e3b27397083cd05802c30ca042d280417ff68d9dcae3eb8b152f9373afd712e794e863d4
|
data/CHANGELOG.md
CHANGED
data/lib/flexirest/caching.rb
CHANGED
@@ -68,9 +68,10 @@ module Flexirest
|
|
68
68
|
end
|
69
69
|
|
70
70
|
if cache_store && (headers[:etag] || headers[:expires])
|
71
|
-
|
71
|
+
class_name = request.class_name
|
72
|
+
key = "#{class_name}:#{request.original_url}"
|
72
73
|
Flexirest::Logger.debug " \033[1;4;32m#{Flexirest.name}\033[0m #{key} - Writing to cache" unless quiet
|
73
|
-
cached_response = CachedResponse.new(status:response.status, result:result, response_headers: headers)
|
74
|
+
cached_response = CachedResponse.new(status:response.status, result:result, response_headers: headers, class_name:class_name)
|
74
75
|
cached_response.etag = "#{headers[:etag]}" if headers[:etag]
|
75
76
|
cached_response.expires = Time.parse(headers[:expires]) rescue nil if headers[:expires]
|
76
77
|
if cached_response.etag.present? || cached_response.expires
|
@@ -101,18 +102,19 @@ module Flexirest
|
|
101
102
|
@etag = options[:etag]
|
102
103
|
@expires = options[:expires]
|
103
104
|
@response_headers = options[:response_headers]
|
105
|
+
@old_cached_instance = options[:result].class.name.nil?
|
104
106
|
|
105
|
-
@class_name = options[:result].class.name
|
106
107
|
if options[:result].is_a?(ResultIterator)
|
107
108
|
@class_name = options[:result][0].class.name
|
108
109
|
@result = options[:result].map{|i| {}.merge(i._attributes)}
|
109
110
|
else
|
111
|
+
@class_name = options[:class_name]
|
110
112
|
@result = {}.merge(options[:result].try(:_attributes) || {})
|
111
113
|
end
|
112
114
|
end
|
113
115
|
|
114
116
|
def result
|
115
|
-
return @result if @
|
117
|
+
return @result if @old_cached_instance
|
116
118
|
|
117
119
|
if @result.is_a?(Array)
|
118
120
|
ri = ResultIterator.new(self)
|
data/lib/flexirest/version.rb
CHANGED
data/spec/lib/caching_spec.rb
CHANGED
@@ -109,6 +109,7 @@ describe Flexirest::Caching do
|
|
109
109
|
base_url "http://www.example.com"
|
110
110
|
get :all, "/"
|
111
111
|
put :save_all, "/"
|
112
|
+
get :plain, "/plain/:id", plain: true
|
112
113
|
end
|
113
114
|
|
114
115
|
Person.cache_store = CachingExampleCacheStore5.new({ expires_in: 1.day.to_i }) # default cache expiration
|
@@ -121,7 +122,8 @@ describe Flexirest::Caching do
|
|
121
122
|
cached_response = Flexirest::CachedResponse.new(
|
122
123
|
status:200,
|
123
124
|
result:@cached_object,
|
124
|
-
etag:@etag
|
125
|
+
etag:@etag,
|
126
|
+
class_name:Person.name)
|
125
127
|
expect_any_instance_of(CachingExampleCacheStore5).to receive(:read).once.with("Person:/").and_return(Marshal.dump(cached_response))
|
126
128
|
expect_any_instance_of(Flexirest::Connection).to receive(:get){ |connection, path, options|
|
127
129
|
expect(path).to eq('/')
|
@@ -131,11 +133,23 @@ describe Flexirest::Caching do
|
|
131
133
|
expect(ret.first_name).to eq("Johnny")
|
132
134
|
end
|
133
135
|
|
136
|
+
it "should read the response to the cache store if response is a 204 with empty bodies and cache is wanted" do
|
137
|
+
cached_response = Flexirest::CachedResponse.new(
|
138
|
+
status:204,
|
139
|
+
result:true,
|
140
|
+
expires:Time.now + 30,
|
141
|
+
class_name:Person.name)
|
142
|
+
expect_any_instance_of(CachingExampleCacheStore5).to receive(:read).once.with("Person:/").and_return(Marshal.dump(cached_response))
|
143
|
+
expect_any_instance_of(Flexirest::Connection).not_to receive(:get)
|
144
|
+
Person.all
|
145
|
+
end
|
146
|
+
|
134
147
|
it "should not read from the cache store to check for an etag unless it's a GET request" do
|
135
148
|
cached_response = Flexirest::CachedResponse.new(
|
136
149
|
status:200,
|
137
150
|
result:@cached_object,
|
138
|
-
etag:@etag
|
151
|
+
etag:@etag,
|
152
|
+
class_name:Person.name)
|
139
153
|
expect_any_instance_of(CachingExampleCacheStore5).to_not receive(:read)
|
140
154
|
expect_any_instance_of(Flexirest::Connection).to receive(:put).and_return(::FaradayResponseMock.new(OpenStruct.new(status:200, body: {result: "foo"}.to_json, response_headers:{})))
|
141
155
|
ret = Person.save_all
|
@@ -145,7 +159,8 @@ describe Flexirest::Caching do
|
|
145
159
|
cached_response = Flexirest::CachedResponse.new(
|
146
160
|
status: 200,
|
147
161
|
result: @cached_object,
|
148
|
-
etag: @etag
|
162
|
+
etag: @etag,
|
163
|
+
class_name:Person.name
|
149
164
|
)
|
150
165
|
allow_any_instance_of(CachingExampleCacheStore5).to receive(:read).and_return(Marshal.dump(cached_response))
|
151
166
|
new_name = 'Pete'
|
@@ -166,7 +181,8 @@ describe Flexirest::Caching do
|
|
166
181
|
cached_response = Flexirest::CachedResponse.new(
|
167
182
|
status:200,
|
168
183
|
result:@cached_object,
|
169
|
-
expires:Time.now + 30
|
184
|
+
expires:Time.now + 30,
|
185
|
+
class_name:Person.name)
|
170
186
|
expect_any_instance_of(CachingExampleCacheStore5).to receive(:read).once.with("Person:/").and_return(Marshal.dump(cached_response))
|
171
187
|
expect_any_instance_of(Flexirest::Connection).not_to receive(:get)
|
172
188
|
ret = Person.all
|
@@ -177,7 +193,8 @@ describe Flexirest::Caching do
|
|
177
193
|
cached_response = Flexirest::CachedResponse.new(
|
178
194
|
status:200,
|
179
195
|
result:@cached_object,
|
180
|
-
expires:Time.now + 30
|
196
|
+
expires:Time.now + 30,
|
197
|
+
class_name:Person.name)
|
181
198
|
Timecop.travel(Time.now + 60)
|
182
199
|
expect_any_instance_of(CachingExampleCacheStore5).to receive(:read).once.with("Person:/").and_return(nil)
|
183
200
|
expect_any_instance_of(Flexirest::Connection).to receive(:get).with("/", an_instance_of(Hash)).and_return(::FaradayResponseMock.new(OpenStruct.new(status:200, body:"{\"result\":true}", response_headers:{})))
|
@@ -189,7 +206,8 @@ describe Flexirest::Caching do
|
|
189
206
|
cached_response = Flexirest::CachedResponse.new(
|
190
207
|
status:200,
|
191
208
|
result:@cached_object,
|
192
|
-
expires:Time.now + 30
|
209
|
+
expires:Time.now + 30,
|
210
|
+
class_name:Person.name)
|
193
211
|
expect_any_instance_of(CachingExampleCacheStore5).to receive(:read).once.with("Person:/").and_return(Marshal.dump(cached_response))
|
194
212
|
expect_any_instance_of(Flexirest::Connection).not_to receive(:get)
|
195
213
|
ret = Person.all
|
@@ -201,7 +219,8 @@ describe Flexirest::Caching do
|
|
201
219
|
cached_response = Flexirest::CachedResponse.new(
|
202
220
|
status:200,
|
203
221
|
result:@cached_object,
|
204
|
-
expires:Time.now + 30
|
222
|
+
expires:Time.now + 30,
|
223
|
+
class_name:Person.name)
|
205
224
|
expect_any_instance_of(CachingExampleCacheStore5).to receive(:read).once.with("Person:/").and_return(Marshal.dump(cached_response))
|
206
225
|
expect_any_instance_of(Flexirest::Connection).not_to receive(:get)
|
207
226
|
p = Person.new(first_name:"Billy")
|
@@ -219,7 +238,8 @@ describe Flexirest::Caching do
|
|
219
238
|
status:200,
|
220
239
|
result:object,
|
221
240
|
etag:etag,
|
222
|
-
expires:Time.now + 30
|
241
|
+
expires:Time.now + 30,
|
242
|
+
class_name:Person.name)
|
223
243
|
expect_any_instance_of(CachingExampleCacheStore5).to receive(:read).once.with("Person:/").and_return(Marshal.dump(cached_response))
|
224
244
|
expect_any_instance_of(Flexirest::Connection).not_to receive(:get)
|
225
245
|
ret = Person.all
|
@@ -237,7 +257,8 @@ describe Flexirest::Caching do
|
|
237
257
|
status:200,
|
238
258
|
result:object,
|
239
259
|
etag:etag,
|
240
|
-
expires:Time.now + 30
|
260
|
+
expires:Time.now + 30,
|
261
|
+
class_name:Person.name)
|
241
262
|
Timecop.travel(Time.now + 60)
|
242
263
|
expect_any_instance_of(CachingExampleCacheStore5).to receive(:read).once.with("Person:/").and_return(nil)
|
243
264
|
expect_any_instance_of(Flexirest::Connection).to receive(:get).with("/", an_instance_of(Hash)).and_return(::FaradayResponseMock.new(OpenStruct.new(status:200, body:"[{\"first_name\":\"Billy\"}]", response_headers:{})))
|
@@ -247,6 +268,21 @@ describe Flexirest::Caching do
|
|
247
268
|
Timecop.return
|
248
269
|
end
|
249
270
|
|
271
|
+
it "should not write the response to the cache if it is a plain request" do
|
272
|
+
response_body = "This is another non-JSON string"
|
273
|
+
expect_any_instance_of(CachingExampleCacheStore5).to receive(:read).once.with("Person:/plain/1234").and_return(nil)
|
274
|
+
expect_any_instance_of(CachingExampleCacheStore5).to receive(:write).once.with("Person:/plain/1234", an_instance_of(String), hash_excluding(:etag))
|
275
|
+
expect_any_instance_of(Flexirest::Connection).to receive(:get).with(any_args).and_return(::FaradayResponseMock.new(OpenStruct.new(status:200, response_headers:{expires:(Time.now + 30).rfc822}, body:response_body)))
|
276
|
+
Person.plain(id:1234)
|
277
|
+
end
|
278
|
+
|
279
|
+
it "should write the response to the cache if response is a 204 with empty bodies and with expires set (or an etag)" do
|
280
|
+
expect_any_instance_of(CachingExampleCacheStore5).to receive(:read).once.with("Person:/").and_return(nil)
|
281
|
+
expect_any_instance_of(CachingExampleCacheStore5).to receive(:write).once.with("Person:/", an_instance_of(String), hash_excluding(:etag))
|
282
|
+
expect_any_instance_of(Flexirest::Connection).to receive(:get).with(any_args).and_return(::FaradayResponseMock.new(OpenStruct.new(status:204, response_headers:{expires:(Time.now + 30).rfc822}, body: nil)))
|
283
|
+
Person.all
|
284
|
+
end
|
285
|
+
|
250
286
|
it "should not write the response to the cache unless it has caching headers" do
|
251
287
|
expect_any_instance_of(CachingExampleCacheStore5).to receive(:read).once.with("Person:/").and_return(nil)
|
252
288
|
expect_any_instance_of(CachingExampleCacheStore5).not_to receive(:write)
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: flexirest
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.12.
|
4
|
+
version: 1.12.4
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Andy Jeffries
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2024-
|
11
|
+
date: 2024-05-31 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bundler
|