mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
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
This commit is contained in:
parent
75bfc6440d
commit
1d15d5f080
4370 changed files with 0 additions and 0 deletions
42
spec/ruby/core/hash/rehash_spec.rb
Normal file
42
spec/ruby/core/hash/rehash_spec.rb
Normal file
|
@ -0,0 +1,42 @@
|
|||
require File.expand_path('../../../spec_helper', __FILE__)
|
||||
require File.expand_path('../fixtures/classes', __FILE__)
|
||||
|
||||
describe "Hash#rehash" do
|
||||
it "reorganizes the hash by recomputing all key hash codes" do
|
||||
k1 = [1]
|
||||
k2 = [2]
|
||||
h = {}
|
||||
h[k1] = 0
|
||||
h[k2] = 1
|
||||
|
||||
k1 << 2
|
||||
h.key?(k1).should == false
|
||||
h.keys.include?(k1).should == true
|
||||
|
||||
h.rehash.should equal(h)
|
||||
h.key?(k1).should == true
|
||||
h[k1].should == 0
|
||||
|
||||
k1 = mock('k1')
|
||||
k2 = mock('k2')
|
||||
v1 = mock('v1')
|
||||
v2 = mock('v2')
|
||||
|
||||
v1.should_not_receive(:hash)
|
||||
v2.should_not_receive(:hash)
|
||||
|
||||
h = { k1 => v1, k2 => v2 }
|
||||
|
||||
k1.should_receive(:hash).twice.and_return(0)
|
||||
k2.should_receive(:hash).twice.and_return(0)
|
||||
|
||||
h.rehash
|
||||
h[k1].should == v1
|
||||
h[k2].should == v2
|
||||
end
|
||||
|
||||
it "raises a RuntimeError if called on a frozen instance" do
|
||||
lambda { HashSpecs.frozen_hash.rehash }.should raise_error(RuntimeError)
|
||||
lambda { HashSpecs.empty_frozen_hash.rehash }.should raise_error(RuntimeError)
|
||||
end
|
||||
end
|
Loading…
Add table
Add a link
Reference in a new issue