diff options
author | eregon <eregon@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2017-09-20 20:18:52 +0000 |
---|---|---|
committer | eregon <eregon@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2017-09-20 20:18:52 +0000 |
commit | 1d15d5f08032acf1b7bceacbb450d617ff6e0931 (patch) | |
tree | a3785a79899302bc149e4a6e72f624ac27dc1f10 /spec/rubyspec/shared/basicobject/send.rb | |
parent | 75bfc6440d595bf339007f4fb280fd4d743e89c1 (diff) |
Move spec/rubyspec to spec/ruby for consistency
* Other ruby implementations use the spec/ruby directory.
[Misc #13792] [ruby-core:82287]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@59979 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'spec/rubyspec/shared/basicobject/send.rb')
-rw-r--r-- | spec/rubyspec/shared/basicobject/send.rb | 110 |
1 files changed, 0 insertions, 110 deletions
diff --git a/spec/rubyspec/shared/basicobject/send.rb b/spec/rubyspec/shared/basicobject/send.rb deleted file mode 100644 index f8c63c5522..0000000000 --- a/spec/rubyspec/shared/basicobject/send.rb +++ /dev/null @@ -1,110 +0,0 @@ -module SendSpecs -end - -describe :basicobject_send, shared: true do - it "invokes the named method" do - class SendSpecs::Foo - def bar - 'done' - end - end - SendSpecs::Foo.new.send(@method, :bar).should == 'done' - end - - it "accepts a String method name" do - class SendSpecs::Foo - def bar - 'done' - end - end - SendSpecs::Foo.new.send(@method, 'bar').should == 'done' - end - - it "invokes a class method if called on a class" do - class SendSpecs::Foo - def self.bar - 'done' - end - end - SendSpecs::Foo.send(@method, :bar).should == 'done' - end - - it "raises a NameError if the corresponding method can't be found" do - class SendSpecs::Foo - def bar - 'done' - end - end - 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 - class SendSpecs::Foo - def self.bar - 'done' - end - end - 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 - lambda { SendSpecs::Foo.new.send @method }.should raise_error(ArgumentError) - end - - it "raises an ArgumentError if called with more arguments than available parameters" do - class SendSpecs::Foo - def bar; end - end - - 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 - class SendSpecs::Foo - def foo(arg); end - end - - 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 - class SendSpecs::Foo - def baz(*args) args end - end - - begin - SendSpecs::Foo.new.send(@method, :baz).should == [] - SendSpecs::Foo.new.send(@method, :baz, :quux).should == [:quux] - SendSpecs::Foo.new.send(@method, :baz, :quux, :foo).should == [:quux, :foo] - rescue - fail - end - end - - it "succeeds when passing 1 or more arguments as a required and a splat parameter" do - class SendSpecs::Foo - def baz(first, *rest) [first, *rest] end - end - - SendSpecs::Foo.new.send(@method, :baz, :quux).should == [:quux] - SendSpecs::Foo.new.send(@method, :baz, :quux, :foo).should == [:quux, :foo] - end - - it "succeeds when passing 0 arguments to a method with one parameter with a default" do - class SendSpecs::Foo - def foo(first = true) first end - end - - begin - SendSpecs::Foo.new.send(@method, :foo).should == true - SendSpecs::Foo.new.send(@method, :foo, :arg).should == :arg - rescue - fail - end - end - - it "has a negative arity" do - method(@method).arity.should < 0 - end -end |