diff options
author | shugo <shugo@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2013-01-07 11:55:17 +0000 |
---|---|---|
committer | shugo <shugo@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2013-01-07 11:55:17 +0000 |
commit | 4722c20661093f5071701941bc2f7b519f2a7283 (patch) | |
tree | 05983de24d5a5120805188e191f5c9113a4df0ac /test/ruby/test_module.rb | |
parent | 04fd9aceab50c0ca97e96a8e183a948a903ed56e (diff) |
* eval.c (Init_eval): main.include should be private.
[ruby-core:51293] [Bug #7670]
* test/ruby/test_module.rb (test_top_include_is_private): a new test
for the above change.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@38731 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/ruby/test_module.rb')
-rw-r--r-- | test/ruby/test_module.rb | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/test/ruby/test_module.rb b/test/ruby/test_module.rb index 2862cd338f..185c445091 100644 --- a/test/ruby/test_module.rb +++ b/test/ruby/test_module.rb @@ -1596,4 +1596,23 @@ class TestModule < Test::Unit::TestCase m = Module.new assert_raise(NameError){ m.instance_eval { remove_const(:__FOO__) } } end + + def test_top_include_is_private + main = eval("self", TOPLEVEL_BINDING) + methods = main.singleton_class.private_instance_methods(false) + assert(methods.include?(:include)) + + assert_in_out_err([], <<-INPUT, ["true"], []) + module M + end + include M + p singleton_class < M + INPUT + + assert_in_out_err([], <<-INPUT, [], /private method `include' called for main:Object \(NoMethodError\)/) + module M + end + self.include M + INPUT + end end |