diff options
author | nagachika <nagachika@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2013-09-13 14:31:46 +0000 |
---|---|---|
committer | nagachika <nagachika@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2013-09-13 14:31:46 +0000 |
commit | 81a807b1a26044b08520df4d3c510cb7d0252dc1 (patch) | |
tree | 4b3fdf814300284f4888f476eaca25419864c83c | |
parent | 4dbca94e9ecc96cf5ee14f200eaaa5178b6eccbf (diff) |
merge revision(s) 42541: [Backport #8903]
* object.c (Init_Object): undef Module#prepend_features on Class, as
well as Module#append_features. [Fixes GH-376]
* test_class.rb: Added test for above. And ensure type checking
on similar methods as module_function.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_0_0@42936 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 8 | ||||
-rw-r--r-- | object.c | 1 | ||||
-rw-r--r-- | test/ruby/test_class.rb | 26 | ||||
-rw-r--r-- | version.h | 2 |
4 files changed, 36 insertions, 1 deletions
@@ -1,3 +1,11 @@ +Fri Sep 13 23:20:29 2013 Kenichi Kamiya <kachick1@gmail.com> + + * object.c (Init_Object): undef Module#prepend_features on Class, as + well as Module#append_features. [Fixes GH-376] + + * test_class.rb: Added test for above. And ensure type checking + on similar methods as module_function. + Fri Sep 13 23:16:12 2013 Zachary Scott <e@zzak.io> * enumerator.c: [DOC] Remove reference to Enumerator::Lazy#cycle @@ -3163,6 +3163,7 @@ Init_Object(void) rb_define_alloc_func(rb_cClass, rb_class_s_alloc); rb_undef_method(rb_cClass, "extend_object"); rb_undef_method(rb_cClass, "append_features"); + rb_undef_method(rb_cClass, "prepend_features"); /* * Document-class: Data diff --git a/test/ruby/test_class.rb b/test/ruby/test_class.rb index ef7d4fa922..3eaf103fd5 100644 --- a/test/ruby/test_class.rb +++ b/test/ruby/test_class.rb @@ -105,6 +105,32 @@ class TestClass < Test::Unit::TestCase end end + def test_extend_object + c = Class.new + assert_raise(TypeError) do + Module.instance_method(:extend_object).bind(c).call(Object.new) + end + end + + def test_append_features + c = Class.new + assert_raise(TypeError) do + Module.instance_method(:append_features).bind(c).call(Module.new) + end + end + + def test_prepend_features + c = Class.new + assert_raise(TypeError) do + Module.instance_method(:prepend_features).bind(c).call(Module.new) + end + end + + def test_module_specific_methods + assert_empty(Class.private_instance_methods(true) & + [:module_function, :extend_object, :append_features, :prepend_features]) + end + def test_method_redefinition feature2155 = '[ruby-dev:39400]' @@ -1,6 +1,6 @@ #define RUBY_VERSION "2.0.0" #define RUBY_RELEASE_DATE "2013-09-13" -#define RUBY_PATCHLEVEL 311 +#define RUBY_PATCHLEVEL 312 #define RUBY_RELEASE_YEAR 2013 #define RUBY_RELEASE_MONTH 9 |