From c4b0b4c91c54b58b02cf94b25d6127b9c3777996 Mon Sep 17 00:00:00 2001 From: matz Date: Thu, 24 Sep 2009 04:42:28 +0000 Subject: * proc.c (mnew): generate method object that wraps method_missing, when #respond_to_missing? is defined. * test/ruby/test_object.rb (test_respond_to_missing): add test suites for #respond_to_missing? changes. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@25073 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- test/ruby/test_object.rb | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) (limited to 'test') diff --git a/test/ruby/test_object.rb b/test/ruby/test_object.rb index eff463f307..47e4a640d9 100644 --- a/test/ruby/test_object.rb +++ b/test/ruby/test_object.rb @@ -304,6 +304,39 @@ class TestObject < Test::Unit::TestCase end end + def test_respond_to_missing + c = Class.new + c.class_eval do + def respond_to_missing?(id) + if id == :foobar + true + else + false + end + end + def method_missing(id,*args) + if id == :foobar + return [:foo, *args] + else + super + end + end + end + + foo = c.new + assert_equal([:foo], foo.foobar); + assert_equal([:foo, 1], foo.foobar(1)); + assert(foo.respond_to?(:foobar)) + assert_equal(false, foo.respond_to?(:foobarbaz)) + assert_raise(NoMethodError) do + foo.foobarbaz + end + + foobar = foo.method(:foobar) + assert_equal([:foo], foobar.call); + assert_equal([:foo, 1], foobar.call(1)); + end + def test_send_with_no_arguments assert_raise(ArgumentError) { 1.send } end -- cgit v1.2.3