mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
ee9e08679a
This will make sure it doesn't change the state of the current proccess when removing the owners constant.
24 lines
824 B
Ruby
24 lines
824 B
Ruby
require "cases/helper"
|
|
require "models/owner"
|
|
require "models/pet"
|
|
|
|
class ReloadModelsTest < ActiveRecord::TestCase
|
|
include ActiveSupport::Testing::Isolation
|
|
|
|
fixtures :pets, :owners
|
|
|
|
def test_has_one_with_reload
|
|
pet = Pet.find_by_name("parrot")
|
|
pet.owner = Owner.find_by_name("ashley")
|
|
|
|
# Reload the class Owner, simulating auto-reloading of model classes in a
|
|
# development environment. Note that meanwhile the class Pet is not
|
|
# reloaded, simulating a class that is present in a plugin.
|
|
Object.class_eval { remove_const :Owner }
|
|
Kernel.load(File.expand_path(File.join(File.dirname(__FILE__), "../models/owner.rb")))
|
|
|
|
pet = Pet.find_by_name("parrot")
|
|
pet.owner = Owner.find_by_name("ashley")
|
|
assert_equal pet.owner, Owner.find_by_name("ashley")
|
|
end
|
|
end unless in_memory_db?
|