summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorJeremy Evans <code@jeremyevans.net>2021-02-18 15:22:37 -0800
committerJeremy Evans <code@jeremyevans.net>2021-03-16 12:10:11 -0700
commit58660e943488778563b9e41005a601e9660ce21f (patch)
treef2da25d960ea4ebab02911ede6a3ff4e00ec2363 /test
parent756e8a2cf3424b9a3eb9dde4a01325cba21a7e81 (diff)
Skip refined method when exporting methods with changed visibility
Previously, attempting to change the visibility of a method in a singleton class for a class/module that is prepended to and refined would raise a NoMethodError. Fixes [Bug #17519]
Notes
Notes: Merged: https://github.com/ruby/ruby/pull/4200
Diffstat (limited to 'test')
-rw-r--r--test/ruby/test_module.rb23
1 files changed, 23 insertions, 0 deletions
diff --git a/test/ruby/test_module.rb b/test/ruby/test_module.rb
index e5152b1012..3cd2f04eff 100644
--- a/test/ruby/test_module.rb
+++ b/test/ruby/test_module.rb
@@ -2294,6 +2294,29 @@ class TestModule < Test::Unit::TestCase
assert_equal(0, 1 / 2)
end
+ def test_visibility_after_refine_and_visibility_change
+ m = Module.new
+ c = Class.new do
+ def x; :x end
+ end
+ c.prepend(m)
+ Module.new do
+ refine c do
+ def x; :y end
+ end
+ end
+
+ o1 = c.new
+ o2 = c.new
+ assert_equal(:x, o1.public_send(:x))
+ assert_equal(:x, o2.public_send(:x))
+ o1.singleton_class.send(:private, :x)
+ o2.singleton_class.send(:public, :x)
+
+ assert_raise(NoMethodError) { o1.public_send(:x) }
+ assert_equal(:x, o2.public_send(:x))
+ end
+
def test_prepend_visibility
bug8005 = '[ruby-core:53106] [Bug #8005]'
c = Class.new do