1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00
ruby--ruby/spec/rubyspec/core/hash/shared/update.rb
eregon 95e8c48dd3 Add in-tree mspec and ruby/spec
* For easier modifications of ruby/spec by MRI developers.
* .gitignore: track changes under spec.
* spec/mspec, spec/rubyspec: add in-tree mspec and ruby/spec.
  These files can therefore be updated like any other file in MRI.
  Instructions are provided in spec/README.
  [Feature #13156] [ruby-core:79246]

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@58595 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2017-05-07 12:04:49 +00:00

59 lines
2 KiB
Ruby

describe :hash_update, shared: true do
it "adds the entries from other, overwriting duplicate keys. Returns self" do
h = { _1: 'a', _2: '3' }
h.send(@method, _1: '9', _9: 2).should equal(h)
h.should == { _1: "9", _2: "3", _9: 2 }
end
it "sets any duplicate key to the value of block if passed a block" do
h1 = { a: 2, b: -1 }
h2 = { a: -2, c: 1 }
h1.send(@method, h2) { |k,x,y| 3.14 }.should equal(h1)
h1.should == { c: 1, b: -1, a: 3.14 }
h1.send(@method, h1) { nil }
h1.should == { a: nil, b: nil, c: nil }
end
it "tries to convert the passed argument to a hash using #to_hash" do
obj = mock('{1=>2}')
obj.should_receive(:to_hash).and_return({ 1 => 2 })
{ 3 => 4 }.send(@method, obj).should == { 1 => 2, 3 => 4 }
end
it "does not call to_hash on hash subclasses" do
{ 3 => 4 }.send(@method, HashSpecs::ToHashHash[1 => 2]).should == { 1 => 2, 3 => 4 }
end
it "processes entries with same order as merge()" do
h = { 1 => 2, 3 => 4, 5 => 6, "x" => nil, nil => 5, [] => [] }
merge_bang_pairs = []
merge_pairs = []
h.merge(h) { |*arg| merge_pairs << arg }
h.send(@method, h) { |*arg| merge_bang_pairs << arg }
merge_bang_pairs.should == merge_pairs
end
it "raises a RuntimeError on a frozen instance that is modified" do
lambda do
HashSpecs.frozen_hash.send(@method, 1 => 2)
end.should raise_error(RuntimeError)
end
it "checks frozen status before coercing an object with #to_hash" do
obj = mock("to_hash frozen")
# This is necessary because mock cleanup code cannot run on the frozen
# object.
def obj.to_hash() raise Exception, "should not receive #to_hash" end
obj.freeze
lambda { HashSpecs.frozen_hash.send(@method, obj) }.should raise_error(RuntimeError)
end
# see redmine #1571
it "raises a RuntimeError on a frozen instance that would not be modified" do
lambda do
HashSpecs.frozen_hash.send(@method, HashSpecs.empty_frozen_hash)
end.should raise_error(RuntimeError)
end
end