aboutsummaryrefslogtreecommitdiffstats
path: root/activesupport/test/core_ext/hash_ext_test.rb
diff options
context:
space:
mode:
authorDavid Heinemeier Hansson <david@loudthinking.com>2006-01-23 05:38:02 +0000
committerDavid Heinemeier Hansson <david@loudthinking.com>2006-01-23 05:38:02 +0000
commit9c24899ab0fad8baa4db543dd45f3d20ae95d3b3 (patch)
tree16becf9099b0ecfcd238986f8d0fbb3b6d0fa7ea /activesupport/test/core_ext/hash_ext_test.rb
parent010e999092c04bd5ef9185db284a8733bc1b6ee6 (diff)
downloadrails-9c24899ab0fad8baa4db543dd45f3d20ae95d3b3.tar.gz
rails-9c24899ab0fad8baa4db543dd45f3d20ae95d3b3.tar.bz2
rails-9c24899ab0fad8baa4db543dd45f3d20ae95d3b3.zip
Fix merge and dup for hashes with indifferent access (closes #3404) [kenneth.miller@bitfield.net]
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@3468 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'activesupport/test/core_ext/hash_ext_test.rb')
-rw-r--r--activesupport/test/core_ext/hash_ext_test.rb19
1 files changed, 19 insertions, 0 deletions
diff --git a/activesupport/test/core_ext/hash_ext_test.rb b/activesupport/test/core_ext/hash_ext_test.rb
index a62dc3fbca..d74cea0991 100644
--- a/activesupport/test/core_ext/hash_ext_test.rb
+++ b/activesupport/test/core_ext/hash_ext_test.rb
@@ -116,6 +116,25 @@ class HashExtTest < Test::Unit::TestCase
assert [updated_with_strings, updated_with_symbols, updated_with_mixed].all? {|hash| hash.keys.size == 2}
end
+ def test_indifferent_merging
+ hash = HashWithIndifferentAccess.new
+ hash[:a] = 'failure'
+ hash['b'] = 'failure'
+
+ other = { 'a' => 1, :b => 2 }
+
+ merged = hash.merge(other)
+
+ assert_equal HashWithIndifferentAccess, merged.class
+ assert_equal 1, merged[:a]
+ assert_equal 2, merged['b']
+
+ hash.update(other)
+
+ assert_equal 1, hash[:a]
+ assert_equal 2, hash['b']
+ end
+
def test_assert_valid_keys
assert_nothing_raised do
{ :failure => "stuff", :funny => "business" }.assert_valid_keys([ :failure, :funny ])