aboutsummaryrefslogtreecommitdiffstats
path: root/activesupport/test/core_ext/module/introspection_test.rb
diff options
context:
space:
mode:
authorRafael França <rafaelmfranca@gmail.com>2017-01-17 23:21:05 -0500
committerGitHub <noreply@github.com>2017-01-17 23:21:05 -0500
commit5ac8af203391c2bfa7f50cabefe65371f216347e (patch)
tree20f3befb28adeab869264becc59190024cbd95c2 /activesupport/test/core_ext/module/introspection_test.rb
parent39c77eb1843f79925c7195e8869afc7cb7323682 (diff)
parent1d3ddac7b8fbc4ff5cdd984f58991cf736748ad9 (diff)
downloadrails-5ac8af203391c2bfa7f50cabefe65371f216347e.tar.gz
rails-5ac8af203391c2bfa7f50cabefe65371f216347e.tar.bz2
rails-5ac8af203391c2bfa7f50cabefe65371f216347e.zip
Merge pull request #27713 from coreyward/module_freeze_parent_name
Module#parent_name broken for frozen classes
Diffstat (limited to 'activesupport/test/core_ext/module/introspection_test.rb')
-rw-r--r--activesupport/test/core_ext/module/introspection_test.rb37
1 files changed, 37 insertions, 0 deletions
diff --git a/activesupport/test/core_ext/module/introspection_test.rb b/activesupport/test/core_ext/module/introspection_test.rb
new file mode 100644
index 0000000000..db383850cd
--- /dev/null
+++ b/activesupport/test/core_ext/module/introspection_test.rb
@@ -0,0 +1,37 @@
+require "abstract_unit"
+require "active_support/core_ext/module/introspection"
+
+module ParentA
+ module B
+ module C; end
+ module FrozenC; end
+ FrozenC.freeze
+ end
+
+ module FrozenB; end
+ FrozenB.freeze
+end
+
+class IntrospectionTest < ActiveSupport::TestCase
+ def test_parent_name
+ assert_equal "ParentA", ParentA::B.parent_name
+ assert_equal "ParentA::B", ParentA::B::C.parent_name
+ assert_nil ParentA.parent_name
+ end
+
+ def test_parent_name_when_frozen
+ assert_equal "ParentA", ParentA::FrozenB.parent_name
+ assert_equal "ParentA::B", ParentA::B::FrozenC.parent_name
+ end
+
+ def test_parent
+ assert_equal ParentA::B, ParentA::B::C.parent
+ assert_equal ParentA, ParentA::B.parent
+ assert_equal Object, ParentA.parent
+ end
+
+ def test_parents
+ assert_equal [ParentA::B, ParentA, Object], ParentA::B::C.parents
+ assert_equal [ParentA, Object], ParentA::B.parents
+ end
+end