summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2014-04-30 06:32:24 +0000
committerusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2014-04-30 06:32:24 +0000
commit20d4a375e2df9bde23b027581099ca5c8515950d (patch)
treee21bb20156fbf9780c0fa1aa188446afafa541cc /test
parenta2542330283e668c518dc9fc1c044959ed1cdc2a (diff)
merge revision(s) 43682,43727,43752,43759: [Backport #9560]
* lib/delegate.rb (Delegator#send): override to get rid of global function interference. [Fixes GH-449] * lib/delegate.rb (Delegator#send): separate from method_missing so that super calls proper method. * lib/delegate.rb (Delegator#method_missing): try private methods defined in Kernel after the target. [Fixes GH-449] * lib/delegate.rb (SimpleDelegator#__getobj__): target object must be set. * lib/delegate.rb (DelegateClass#__getobj__): ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_0_0@45747 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test')
-rw-r--r--test/ruby/envutil.rb23
-rw-r--r--test/test_delegate.rb36
2 files changed, 59 insertions, 0 deletions
diff --git a/test/ruby/envutil.rb b/test/ruby/envutil.rb
index 948cbc25bc..cfc16d1d86 100644
--- a/test/ruby/envutil.rb
+++ b/test/ruby/envutil.rb
@@ -379,6 +379,29 @@ eom
AssertFile
end
+ def assert_raise_with_message(exception, expected, msg = nil, &block)
+ case expected
+ when String
+ assert = :assert_equal
+ when Regexp
+ assert = :assert_match
+ else
+ raise TypeError, "Expected #{expected.inspect} to be a kind of String or Regexp, not #{expected.class}"
+ end
+
+ ex = assert_raise(exception, *msg) {yield}
+ msg = message(msg, "") {"Expected Exception(#{exception}) was raised, but the message doesn't match"}
+
+ if assert == :assert_equal
+ assert_equal(expected, ex.message, msg)
+ else
+ msg = message(msg) { "Expected #{mu_pp expected} to match #{mu_pp ex.message}" }
+ assert expected =~ ex.message, msg
+ block.binding.eval("proc{|_|$~=_}").call($~)
+ end
+ ex
+ end
+
class << (AssertFile = Struct.new(:message).new)
include Assertions
def assert_file_predicate(predicate, *args)
diff --git a/test/test_delegate.rb b/test/test_delegate.rb
index a09451b88f..dfe9f1db10 100644
--- a/test/test_delegate.rb
+++ b/test/test_delegate.rb
@@ -1,5 +1,6 @@
require 'test/unit'
require 'delegate'
+require_relative 'ruby/envutil'
class TestDelegateClass < Test::Unit::TestCase
module M
@@ -133,4 +134,39 @@ class TestDelegateClass < Test::Unit::TestCase
assert_raise(NoMethodError, '[ruby-dev:40314]#4') {d.delegate_test_private}
assert_raise(NoMethodError, '[ruby-dev:40314]#5') {d.send(:delegate_test_private)}
end
+
+ def test_global_function
+ klass = Class.new do
+ def open
+ end
+ end
+ obj = klass.new
+ d = SimpleDelegator.new(obj)
+ assert_nothing_raised(ArgumentError) {obj.open}
+ assert_nothing_raised(ArgumentError) {d.open}
+ assert_nothing_raised(ArgumentError) {d.send(:open)}
+ end
+
+ def test_send_method_in_delegator
+ d = Class.new(SimpleDelegator) do
+ def foo
+ "foo"
+ end
+ end.new(Object.new)
+ assert_equal("foo", d.send(:foo))
+ end
+
+ def test_unset_simple_delegator
+ d = SimpleDelegator.allocate
+ assert_raise_with_message(ArgumentError, /not delegated/) {
+ d.__getobj__
+ }
+ end
+
+ def test_unset_delegate_class
+ d = IV.allocate
+ assert_raise_with_message(ArgumentError, /not delegated/) {
+ d.__getobj__
+ }
+ end
end