summaryrefslogtreecommitdiff
path: root/spec/ruby/shared/basicobject/send.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/ruby/shared/basicobject/send.rb')
-rw-r--r--spec/ruby/shared/basicobject/send.rb28
1 files changed, 5 insertions, 23 deletions
diff --git a/spec/ruby/shared/basicobject/send.rb b/spec/ruby/shared/basicobject/send.rb
index 625aaa2917..f8c63c5522 100644
--- a/spec/ruby/shared/basicobject/send.rb
+++ b/spec/ruby/shared/basicobject/send.rb
@@ -29,20 +29,13 @@ describe :basicobject_send, shared: true do
SendSpecs::Foo.send(@method, :bar).should == 'done'
end
- it "raises a TypeError if the method name is not a string or symbol" do
- -> { SendSpecs.send(@method, nil) }.should raise_error(TypeError, /not a symbol nor a string/)
- -> { SendSpecs.send(@method, 42) }.should raise_error(TypeError, /not a symbol nor a string/)
- -> { SendSpecs.send(@method, 3.14) }.should raise_error(TypeError, /not a symbol nor a string/)
- -> { SendSpecs.send(@method, true) }.should raise_error(TypeError, /not a symbol nor a string/)
- end
-
it "raises a NameError if the corresponding method can't be found" do
class SendSpecs::Foo
def bar
'done'
end
end
- -> { SendSpecs::Foo.new.send(@method, :syegsywhwua) }.should raise_error(NameError)
+ lambda { SendSpecs::Foo.new.send(@method, :syegsywhwua) }.should raise_error(NameError)
end
it "raises a NameError if the corresponding singleton method can't be found" do
@@ -51,12 +44,12 @@ describe :basicobject_send, shared: true do
'done'
end
end
- -> { SendSpecs::Foo.send(@method, :baz) }.should raise_error(NameError)
+ lambda { SendSpecs::Foo.send(@method, :baz) }.should raise_error(NameError)
end
it "raises an ArgumentError if no arguments are given" do
class SendSpecs::Foo; end
- -> { SendSpecs::Foo.new.send @method }.should raise_error(ArgumentError)
+ lambda { SendSpecs::Foo.new.send @method }.should raise_error(ArgumentError)
end
it "raises an ArgumentError if called with more arguments than available parameters" do
@@ -64,7 +57,7 @@ describe :basicobject_send, shared: true do
def bar; end
end
- -> { SendSpecs::Foo.new.send(@method, :bar, :arg) }.should raise_error(ArgumentError)
+ lambda { SendSpecs::Foo.new.send(@method, :bar, :arg) }.should raise_error(ArgumentError)
end
it "raises an ArgumentError if called with fewer arguments than required parameters" do
@@ -72,7 +65,7 @@ describe :basicobject_send, shared: true do
def foo(arg); end
end
- -> { SendSpecs::Foo.new.send(@method, :foo) }.should raise_error(ArgumentError)
+ lambda { SendSpecs::Foo.new.send(@method, :foo) }.should raise_error(ArgumentError)
end
it "succeeds if passed an arbitrary number of arguments as a splat parameter" do
@@ -114,15 +107,4 @@ describe :basicobject_send, shared: true do
it "has a negative arity" do
method(@method).arity.should < 0
end
-
- it "invokes module methods with super correctly" do
- m1 = Module.new { def foo(ary); ary << :m1; end; }
- m2 = Module.new { def foo(ary = []); super(ary); ary << :m2; end; }
- c2 = Class.new do
- include m1
- include m2
- end
-
- c2.new.send(@method, :foo, *[[]]).should == %i[m1 m2]
- end
end