aboutsummaryrefslogtreecommitdiffstats
path: root/activesupport/test/ordered_hash_test.rb
diff options
context:
space:
mode:
authorXavier Noria <fxn@hashref.com>2010-06-13 05:06:07 +0200
committerXavier Noria <fxn@hashref.com>2010-06-13 05:09:31 +0200
commit72f9fec607c4a72b2e88995d0cb32b16b96e9068 (patch)
tree6db9d499f1dd2251b17e04e9549d2c996e0d6cf8 /activesupport/test/ordered_hash_test.rb
parent9183eaebed19f75980926fad2f3655f5f5e7826c (diff)
downloadrails-72f9fec607c4a72b2e88995d0cb32b16b96e9068.tar.gz
rails-72f9fec607c4a72b2e88995d0cb32b16b96e9068.tar.bz2
rails-72f9fec607c4a72b2e88995d0cb32b16b96e9068.zip
hash merging with a block ignores non-existing keys altogether
Diffstat (limited to 'activesupport/test/ordered_hash_test.rb')
-rw-r--r--activesupport/test/ordered_hash_test.rb33
1 files changed, 16 insertions, 17 deletions
diff --git a/activesupport/test/ordered_hash_test.rb b/activesupport/test/ordered_hash_test.rb
index 56369585ec..e19484fb82 100644
--- a/activesupport/test/ordered_hash_test.rb
+++ b/activesupport/test/ordered_hash_test.rb
@@ -144,28 +144,27 @@ class OrderedHashTest < Test::Unit::TestCase
end
def test_merge_with_block
- other_hash = ActiveSupport::OrderedHash.new
- other_hash['white'] = 'ff'
- other_hash['black'] = '00'
- merged = @ordered_hash.merge(other_hash) do |key, old_value, new_value|
- new_value * 3
+ hash = ActiveSupport::OrderedHash.new
+ hash[:a] = 0
+ hash[:b] = 0
+ merged = hash.merge(:b => 1, :c => 2) do |key, old_value, new_value|
+ new_value + 1
end
- assert_equal 'ffffff', merged['white']
- assert_equal '000000', merged['black']
-
- assert_nil @ordered_hash['white']
- assert_nil @ordered_hash['black']
+ assert_equal 0, merged[:a]
+ assert_equal 2, merged[:b]
+ assert !merged.key?(:c)
end
def test_merge_bang_with_block
- other_hash = ActiveSupport::OrderedHash.new
- other_hash['white'] = 'ff'
- other_hash['black'] = '00'
- @ordered_hash.merge!(other_hash) do |key, old_value, new_value|
- new_value * 3
+ hash = ActiveSupport::OrderedHash.new
+ hash[:a] = 0
+ hash[:b] = 0
+ hash.merge!(:a => 1, :c => 2) do |key, old_value, new_value|
+ new_value + 3
end
- assert_equal 'ffffff', @ordered_hash['white']
- assert_equal '000000', @ordered_hash['black']
+ assert_equal 4, hash[:a]
+ assert_equal 0, hash[:b]
+ assert !hash.key?(:c)
end
def test_shift