1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98
|
require File.expand_path('../../../spec_helper', __FILE__)
require File.expand_path('../fixtures/classes', __FILE__)
require File.expand_path('../shared/iteration', __FILE__)
describe "Hash#reject" do
it "returns a new hash removing keys for which the block yields true" do
h = new_hash(1=>false, 2=>true, 3=>false, 4=>true)
h.reject { |k,v| v }.keys.sort.should == [1,3]
end
it "is equivalent to hsh.dup.delete_if" do
h = new_hash(:a => 'a', :b => 'b', :c => 'd')
h.reject { |k,v| k == 'd' }.should == (h.dup.delete_if { |k, v| k == 'd' })
all_args_reject = []
all_args_delete_if = []
h = new_hash(1 => 2, 3 => 4)
h.reject { |*args| all_args_reject << args }
h.delete_if { |*args| all_args_delete_if << args }
all_args_reject.should == all_args_delete_if
h = new_hash(1 => 2)
# dup doesn't copy singleton methods
def h.to_a() end
h.reject { false }.to_a.should == [[1, 2]]
end
it "returns subclass instance for subclasses" do
HashSpecs::MyHash[1 => 2, 3 => 4].reject { false }.should be_kind_of(HashSpecs::MyHash)
HashSpecs::MyHash[1 => 2, 3 => 4].reject { true }.should be_kind_of(HashSpecs::MyHash)
end
it "taints the resulting hash" do
h = new_hash(:a => 1).taint
h.reject {false}.tainted?.should == true
end
it "processes entries with the same order as reject!" do
h = new_hash(:a => 1, :b => 2, :c => 3, :d => 4)
reject_pairs = []
reject_bang_pairs = []
h.dup.reject { |*pair| reject_pairs << pair }
h.reject! { |*pair| reject_bang_pairs << pair }
reject_pairs.should == reject_bang_pairs
end
it_behaves_like(:hash_iteration_no_block, :reject)
end
describe "Hash#reject!" do
it "removes keys from self for which the block yields true" do
hsh = new_hash
(1 .. 10).each { |k| hsh[k] = k.even? }
hsh.reject! { |k,v| v }
hsh.keys.sort.should == [1,3,5,7,9]
end
it "is equivalent to delete_if if changes are made" do
hsh = new_hash(:a => 1)
hsh.reject! { |k,v| v < 2 }.should == hsh.dup.delete_if { |k, v| v < 2 }
end
it "returns nil if no changes were made" do
new_hash(:a => 1).reject! { |k,v| v > 1 }.should == nil
end
it "processes entries with the same order as delete_if" do
h = new_hash(:a => 1, :b => 2, :c => 3, :d => 4)
reject_bang_pairs = []
delete_if_pairs = []
h.dup.reject! { |*pair| reject_bang_pairs << pair }
h.dup.delete_if { |*pair| delete_if_pairs << pair }
reject_bang_pairs.should == delete_if_pairs
end
ruby_version_is ""..."1.9" do
it "raises a TypeError if called on a frozen instance" do
lambda { HashSpecs.frozen_hash.reject! { false } }.should raise_error(TypeError)
lambda { HashSpecs.empty_frozen_hash.reject! { true } }.should raise_error(TypeError)
end
end
ruby_version_is "1.9" do
it "raises a RuntimeError if called on a frozen instance that is modified" do
lambda { HashSpecs.empty_frozen_hash.reject! { true } }.should raise_error(RuntimeError)
end
it "raises a RuntimeError if called on a frozen instance that would not be modified" do
lambda { HashSpecs.frozen_hash.reject! { false } }.should raise_error(RuntimeError)
end
end
it_behaves_like(:hash_iteration_no_block, :reject!)
end
|