flexirest 1.12.3 → 1.12.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- 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
         |