summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/forwardable.rb10
-rw-r--r--test/test_forwardable.rb24
2 files changed, 28 insertions, 6 deletions
diff --git a/lib/forwardable.rb b/lib/forwardable.rb
index 7f219235d0..3ca8a252dd 100644
--- a/lib/forwardable.rb
+++ b/lib/forwardable.rb
@@ -149,9 +149,8 @@ module Forwardable
# def_delegator :@records, :map
#
def def_instance_delegators(accessor, *methods)
- methods.delete("__send__")
- methods.delete("__id__")
- for method in methods
+ methods.each do |method|
+ next if method.to_s == "__send__" || method.to_s == "__id__"
def_instance_delegator(accessor, method)
end
end
@@ -286,9 +285,8 @@ module SingleForwardable
# def_delegator :@records, :map
#
def def_single_delegators(accessor, *methods)
- methods.delete("__send__")
- methods.delete("__id__")
- for method in methods
+ methods.each do |method|
+ next if method.to_s == "__send__" || method.to_s == "__id__"
def_single_delegator(accessor, method)
end
end
diff --git a/test/test_forwardable.rb b/test/test_forwardable.rb
index 0a90d3a878..2c91d6f87c 100644
--- a/test/test_forwardable.rb
+++ b/test/test_forwardable.rb
@@ -107,6 +107,18 @@ class TestForwardable < Test::Unit::TestCase
end
end
+ def test_def_instance_delegators_send_id
+ %i[def_delegators def_instance_delegators].each do |m|
+ cls = forwardable_class do
+ attr_reader :receiver
+ __send__ m, :@receiver, :__send__, :__id__
+ end
+
+ assert_not_equal cls.new.__id__, cls.new.receiver.__id__
+ assert_not_equal cls.new.__send__(:__id__), cls.new.receiver.__send__(:__id__)
+ end
+ end
+
def test_instance_delegate
%i[delegate instance_delegate].each do |m|
cls = forwardable_class do
@@ -215,6 +227,18 @@ class TestForwardable < Test::Unit::TestCase
end
end
+ def test_obj_single_delegators_send_id
+ %i[def_delegators def_single_delegators].each do |m|
+ obj = single_forwardable_object do
+ singleton_class.attr_reader :receiver
+ __send__ m, :@receiver, :__send__, :__id__
+ end
+
+ assert_not_equal obj.__id__, obj.receiver.__id__
+ assert_not_equal obj.__send__(:__id__), obj.receiver.__send__(:__id__)
+ end
+ end
+
def test_obj_single_delegate
%i[delegate single_delegate].each do |m|
obj = single_forwardable_object do