2017-07-09 13:41:28 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2015-09-29 07:53:39 -04:00
|
|
|
require "cases/helper"
|
|
|
|
|
|
|
|
module ActiveRecord
|
|
|
|
class CacheKeyTest < ActiveRecord::TestCase
|
|
|
|
self.use_transactional_tests = false
|
|
|
|
|
2017-05-18 12:12:32 -04:00
|
|
|
class CacheMe < ActiveRecord::Base
|
|
|
|
self.cache_versioning = false
|
|
|
|
end
|
|
|
|
|
|
|
|
class CacheMeWithVersion < ActiveRecord::Base
|
|
|
|
self.cache_versioning = true
|
|
|
|
end
|
2015-09-29 07:53:39 -04:00
|
|
|
|
|
|
|
setup do
|
|
|
|
@connection = ActiveRecord::Base.connection
|
2017-05-18 12:12:32 -04:00
|
|
|
@connection.create_table(:cache_mes, force: true) { |t| t.timestamps }
|
|
|
|
@connection.create_table(:cache_me_with_versions, force: true) { |t| t.timestamps }
|
2015-09-29 07:53:39 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
teardown do
|
|
|
|
@connection.drop_table :cache_mes, if_exists: true
|
2017-05-18 12:12:32 -04:00
|
|
|
@connection.drop_table :cache_me_with_versions, if_exists: true
|
2015-09-29 07:53:39 -04:00
|
|
|
end
|
|
|
|
|
2017-04-06 19:40:52 -04:00
|
|
|
test "cache_key format is not too precise" do
|
2015-09-29 07:53:39 -04:00
|
|
|
record = CacheMe.create
|
|
|
|
key = record.cache_key
|
|
|
|
|
|
|
|
assert_equal key, record.reload.cache_key
|
|
|
|
end
|
2017-05-18 12:12:32 -04:00
|
|
|
|
|
|
|
test "cache_key has no version when versioning is on" do
|
|
|
|
record = CacheMeWithVersion.create
|
|
|
|
assert_equal "active_record/cache_key_test/cache_me_with_versions/#{record.id}", record.cache_key
|
|
|
|
end
|
|
|
|
|
|
|
|
test "cache_version is only there when versioning is on" do
|
2018-01-25 18:14:09 -05:00
|
|
|
assert_predicate CacheMeWithVersion.create.cache_version, :present?
|
|
|
|
assert_not_predicate CacheMe.create.cache_version, :present?
|
2017-05-18 12:12:32 -04:00
|
|
|
end
|
2017-05-19 08:09:09 -04:00
|
|
|
|
|
|
|
test "cache_key_with_version always has both key and version" do
|
|
|
|
r1 = CacheMeWithVersion.create
|
2018-09-07 22:41:55 -04:00
|
|
|
assert_equal "active_record/cache_key_test/cache_me_with_versions/#{r1.id}-#{r1.updated_at.utc.to_s(:usec)}", r1.cache_key_with_version
|
2017-05-19 08:09:09 -04:00
|
|
|
|
|
|
|
r2 = CacheMe.create
|
2018-09-07 22:41:55 -04:00
|
|
|
assert_equal "active_record/cache_key_test/cache_mes/#{r2.id}-#{r2.updated_at.utc.to_s(:usec)}", r2.cache_key_with_version
|
|
|
|
end
|
|
|
|
|
|
|
|
test "cache_version is the same when it comes from the DB or from the user" do
|
2018-07-12 01:08:36 -04:00
|
|
|
skip("Mysql2 and PostgreSQL don't return a string value for updated_at") if current_adapter?(:Mysql2Adapter, :PostgreSQLAdapter)
|
2018-09-07 22:41:55 -04:00
|
|
|
|
|
|
|
record = CacheMeWithVersion.create
|
|
|
|
record_from_db = CacheMeWithVersion.find(record.id)
|
|
|
|
assert_not_called(record_from_db, :updated_at) do
|
|
|
|
record_from_db.cache_version
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_equal record.cache_version, record_from_db.cache_version
|
|
|
|
end
|
|
|
|
|
|
|
|
test "cache_version does not truncate zeros when timestamp ends in zeros" do
|
2018-07-12 01:08:36 -04:00
|
|
|
skip("Mysql2 and PostgreSQL don't return a string value for updated_at") if current_adapter?(:Mysql2Adapter, :PostgreSQLAdapter)
|
2018-09-07 22:41:55 -04:00
|
|
|
|
|
|
|
travel_to Time.now.beginning_of_day do
|
|
|
|
record = CacheMeWithVersion.create
|
|
|
|
record_from_db = CacheMeWithVersion.find(record.id)
|
|
|
|
assert_not_called(record_from_db, :updated_at) do
|
|
|
|
record_from_db.cache_version
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_equal record.cache_version, record_from_db.cache_version
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
test "cache_version calls updated_at when the value is generated at create time" do
|
|
|
|
record = CacheMeWithVersion.create
|
|
|
|
assert_called(record, :updated_at) do
|
|
|
|
record.cache_version
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
test "cache_version does NOT call updated_at when value is from the database" do
|
2018-07-12 01:08:36 -04:00
|
|
|
skip("Mysql2 and PostgreSQL don't return a string value for updated_at") if current_adapter?(:Mysql2Adapter, :PostgreSQLAdapter)
|
2018-09-07 22:41:55 -04:00
|
|
|
|
|
|
|
record = CacheMeWithVersion.create
|
|
|
|
record_from_db = CacheMeWithVersion.find(record.id)
|
|
|
|
assert_not_called(record_from_db, :updated_at) do
|
|
|
|
record_from_db.cache_version
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
test "cache_version does call updated_at when it is assigned via a Time object" do
|
|
|
|
record = CacheMeWithVersion.create
|
|
|
|
record_from_db = CacheMeWithVersion.find(record.id)
|
|
|
|
assert_called(record_from_db, :updated_at) do
|
|
|
|
record_from_db.updated_at = Time.now
|
|
|
|
record_from_db.cache_version
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
test "cache_version does call updated_at when it is assigned via a string" do
|
|
|
|
record = CacheMeWithVersion.create
|
|
|
|
record_from_db = CacheMeWithVersion.find(record.id)
|
|
|
|
assert_called(record_from_db, :updated_at) do
|
|
|
|
record_from_db.updated_at = Time.now.to_s
|
|
|
|
record_from_db.cache_version
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
test "cache_version does call updated_at when it is assigned via a hash" do
|
|
|
|
record = CacheMeWithVersion.create
|
|
|
|
record_from_db = CacheMeWithVersion.find(record.id)
|
|
|
|
assert_called(record_from_db, :updated_at) do
|
|
|
|
record_from_db.updated_at = { 1 => 2016, 2 => 11, 3 => 12, 4 => 1, 5 => 2, 6 => 3, 7 => 22 }
|
|
|
|
record_from_db.cache_version
|
|
|
|
end
|
2017-05-19 08:09:09 -04:00
|
|
|
end
|
2018-10-15 16:31:12 -04:00
|
|
|
|
|
|
|
test "updated_at on class but not on instance raises an error" do
|
|
|
|
record = CacheMeWithVersion.create
|
|
|
|
record_from_db = CacheMeWithVersion.where(id: record.id).select(:id).first
|
|
|
|
assert_raises(ActiveModel::MissingAttributeError) do
|
|
|
|
record_from_db.cache_version
|
|
|
|
end
|
|
|
|
end
|
2015-09-29 07:53:39 -04:00
|
|
|
end
|
|
|
|
end
|