diff options
author | Aaron Patterson <aaron.patterson@gmail.com> | 2016-02-18 08:23:26 -0800 |
---|---|---|
committer | Aaron Patterson <aaron.patterson@gmail.com> | 2016-02-18 08:23:26 -0800 |
commit | 3239ed48d28f3c0baf4445e6c279107e892b7cab (patch) | |
tree | a9860b5c54a42bd16615ae963341229f6c6698a8 /railties/test | |
parent | 13c4cc3b5aea02716b7459c0da641438077f5236 (diff) | |
download | rails-3239ed48d28f3c0baf4445e6c279107e892b7cab.tar.gz rails-3239ed48d28f3c0baf4445e6c279107e892b7cab.tar.bz2 rails-3239ed48d28f3c0baf4445e6c279107e892b7cab.zip |
move digest cache on to the DetailsKey object
This moves digest calculation cache on to the details key object.
Before, the digest cache was a class level ivar, and one of the keys was
the hash value of the details key object:
https://github.com/rails/rails/blob/13c4cc3b5aea02716b7459c0da641438077f5236/actionview/lib/action_view/digestor.rb#L28
An object's hash value is not unique, so it's possible for this cache
key to produce colliding keys with no resolution. This commit move
cache on to the details key object itself, so we know that the digests
are always unique per details key object.
Diffstat (limited to 'railties/test')
-rw-r--r-- | railties/test/application/per_request_digest_cache_test.rb | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/railties/test/application/per_request_digest_cache_test.rb b/railties/test/application/per_request_digest_cache_test.rb index 3198e12662..210646c7c0 100644 --- a/railties/test/application/per_request_digest_cache_test.rb +++ b/railties/test/application/per_request_digest_cache_test.rb @@ -50,12 +50,13 @@ class PerRequestDigestCacheTest < ActiveSupport::TestCase get '/customers' assert_equal 200, last_response.status - assert_equal [ '8ba099b7749542fe765ff34a6824d548' ], ActionView::Digestor.cache.values + values = ActionView::LookupContext::DetailsKey.digest_caches.first.values + assert_equal [ '8ba099b7749542fe765ff34a6824d548' ], values assert_equal %w(david dingus), last_response.body.split.map(&:strip) end test "template digests are cleared before a request" do - assert_called(ActionView::Digestor.cache, :clear) do + assert_called(ActionView::LookupContext::DetailsKey, :clear) do get '/customers' assert_equal 200, last_response.status end |