diff options
Diffstat (limited to 'activesupport/test')
-rw-r--r-- | activesupport/test/core_ext/module_test.rb | 14 | ||||
-rw-r--r-- | activesupport/test/reloadable_test.rb | 58 |
2 files changed, 58 insertions, 14 deletions
diff --git a/activesupport/test/core_ext/module_test.rb b/activesupport/test/core_ext/module_test.rb index 3d11f1001f..d6ea595ae2 100644 --- a/activesupport/test/core_ext/module_test.rb +++ b/activesupport/test/core_ext/module_test.rb @@ -34,18 +34,4 @@ class ModuleTest < Test::Unit::TestCase assert !One.included_in_classes.include?(De) end - def test_remove_classes_including - assert Ab.is_a?(Class) - assert Xy::Bc.is_a?(Class) - assert Yz::Zy::Cd.is_a?(Class) - assert De.is_a?(Class) - - One.remove_classes_including - - assert_raises(NameError) { Ae.is_a?(Class) } - assert_raises(NameError) { Xy::Bc.is_a?(Class) } - assert_raises(NameError) { Yz::Zy::Cd.is_a?(Class) } - - assert De.is_a?(Class) - end end
\ No newline at end of file diff --git a/activesupport/test/reloadable_test.rb b/activesupport/test/reloadable_test.rb new file mode 100644 index 0000000000..adac2fccec --- /dev/null +++ b/activesupport/test/reloadable_test.rb @@ -0,0 +1,58 @@ +require 'test/unit' +require File.dirname(__FILE__) + '/../lib/active_support/core_ext/class' +require File.dirname(__FILE__) + '/../lib/active_support/core_ext/module' +require File.dirname(__FILE__) + '/../lib/active_support/reloadable' + +module ReloadableTestSandbox + + module AModuleIncludingReloadable + include Reloadable + end + class AReloadableClass + include Reloadable + end + class AReloadableClassWithSubclasses + include Reloadable + end + class AReloadableSubclass < AReloadableClassWithSubclasses + end + class ANonReloadableSubclass < AReloadableClassWithSubclasses + def self.reloadable? + false + end + end + class AClassWhichDefinesItsOwnReloadable + def self.reloadable? + 10 + end + include Reloadable + end +end + +class ReloadableTest < Test::Unit::TestCase + def test_modules_do_not_receive_reloadable_method + assert ! ReloadableTestSandbox::AModuleIncludingReloadable.respond_to?(:reloadable?) + end + def test_classes_receive_reloadable + assert ReloadableTestSandbox::AReloadableClass.respond_to?(:reloadable?) + end + def test_classes_inherit_reloadable + assert ReloadableTestSandbox::AReloadableSubclass.respond_to?(:reloadable?) + end + def test_reloadable_is_not_overwritten_if_present + assert_equal 10, ReloadableTestSandbox::AClassWhichDefinesItsOwnReloadable.reloadable? + end + + def test_removable_classes + reloadables = %w(AReloadableClass AReloadableClassWithSubclasses AReloadableSubclass AClassWhichDefinesItsOwnReloadable) + non_reloadables = %w(ANonReloadableSubclass AModuleIncludingReloadable) + + results = Reloadable.reloadable_classes + reloadables.each do |name| + assert results.include?(ReloadableTestSandbox.const_get(name)), "Expected #{name} to be reloadable" + end + non_reloadables.each do |name| + assert ! results.include?(ReloadableTestSandbox.const_get(name)), "Expected #{name} NOT to be reloadable" + end + end +end
\ No newline at end of file |