aboutsummaryrefslogtreecommitdiffstats
path: root/railties/test
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2016-02-18 08:23:26 -0800
committerAaron Patterson <aaron.patterson@gmail.com>2016-02-18 08:23:26 -0800
commit3239ed48d28f3c0baf4445e6c279107e892b7cab (patch)
treea9860b5c54a42bd16615ae963341229f6c6698a8 /railties/test
parent13c4cc3b5aea02716b7459c0da641438077f5236 (diff)
downloadrails-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.rb5
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