mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
Update to ruby/spec@83063a3
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@62094 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
1e658d45e1
commit
3fa5bd38af
494 changed files with 4133 additions and 3109 deletions
|
@ -1,15 +1,17 @@
|
|||
require File.expand_path('../../../spec_helper', __FILE__)
|
||||
require File.expand_path('../fixtures/classes', __FILE__)
|
||||
require File.expand_path('../../../shared/hash/key_error', __FILE__)
|
||||
|
||||
describe "Hash#fetch" do
|
||||
it "returns the value for key" do
|
||||
{ a: 1, b: -1 }.fetch(:b).should == -1
|
||||
context "when the key is not found" do
|
||||
it_behaves_like :key_error, ->(obj, key) { obj.fetch(key) }, Hash.new(a: 5)
|
||||
it_behaves_like :key_error, ->(obj, key) { obj.fetch(key) }, {}
|
||||
it_behaves_like :key_error, ->(obj, key) { obj.fetch(key) }, Hash.new { 5 }
|
||||
it_behaves_like :key_error, ->(obj, key) { obj.fetch(key) }, Hash.new(5)
|
||||
end
|
||||
|
||||
it "raises a KeyError if key is not found" do
|
||||
lambda { {}.fetch(:a) }.should raise_error(KeyError)
|
||||
lambda { Hash.new(5).fetch(:a) }.should raise_error(KeyError)
|
||||
lambda { Hash.new { 5 }.fetch(:a) }.should raise_error(KeyError)
|
||||
it "returns the value for key" do
|
||||
{ a: 1, b: -1 }.fetch(:b).should == -1
|
||||
end
|
||||
|
||||
it "returns default if key is not found when passed a default" do
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue