2018-03-04 10:09:32 -05:00
|
|
|
require_relative '../../spec_helper'
|
|
|
|
require_relative 'fixtures/classes'
|
2017-05-07 08:04:49 -04:00
|
|
|
|
|
|
|
describe "Hash#delete" do
|
|
|
|
it "removes the entry and returns the deleted value" do
|
|
|
|
h = { a: 5, b: 2 }
|
|
|
|
h.delete(:b).should == 2
|
|
|
|
h.should == { a: 5 }
|
|
|
|
end
|
|
|
|
|
|
|
|
it "calls supplied block if the key is not found" do
|
|
|
|
{ a: 1, b: 10, c: 100 }.delete(:d) { 5 }.should == 5
|
|
|
|
Hash.new(:default).delete(:d) { 5 }.should == 5
|
2017-10-28 11:15:48 -04:00
|
|
|
Hash.new { :default }.delete(:d) { 5 }.should == 5
|
2017-05-07 08:04:49 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "returns nil if the key is not found when no block is given" do
|
|
|
|
{ a: 1, b: 10, c: 100 }.delete(:d).should == nil
|
|
|
|
Hash.new(:default).delete(:d).should == nil
|
2017-10-28 11:15:48 -04:00
|
|
|
Hash.new { :default }.delete(:d).should == nil
|
2017-05-07 08:04:49 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
# MRI explicitly implements this behavior
|
|
|
|
it "allows removing a key while iterating" do
|
|
|
|
h = { a: 1, b: 2 }
|
|
|
|
visited = []
|
|
|
|
h.each_pair { |k,v|
|
|
|
|
visited << k
|
|
|
|
h.delete(k)
|
|
|
|
}
|
|
|
|
visited.should == [:a, :b]
|
|
|
|
h.should == {}
|
|
|
|
end
|
|
|
|
|
|
|
|
it "accepts keys with private #hash method" do
|
|
|
|
key = HashSpecs::KeyWithPrivateHash.new
|
|
|
|
{ key => 5 }.delete(key).should == 5
|
|
|
|
end
|
|
|
|
|
2017-12-27 11:12:47 -05:00
|
|
|
it "raises a #{frozen_error_class} if called on a frozen instance" do
|
|
|
|
lambda { HashSpecs.frozen_hash.delete("foo") }.should raise_error(frozen_error_class)
|
|
|
|
lambda { HashSpecs.empty_frozen_hash.delete("foo") }.should raise_error(frozen_error_class)
|
2017-05-07 08:04:49 -04:00
|
|
|
end
|
|
|
|
end
|