aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record/serialization.rb
diff options
context:
space:
mode:
authorVitor Baptista <vitor@vitorbaptista.com>2013-01-15 23:19:02 -0300
committerVitor Baptista <vitor@vitorbaptista.com>2013-01-16 10:43:30 -0300
commite1e5f3005705b3028ca3a09c61444a8c21398273 (patch)
tree5043b96a180cbe485f99d89bb7fd703bc6324c96 /activerecord/lib/active_record/serialization.rb
parente5f5863e86a93d8eea503fb36127e7ebe7364f5e (diff)
downloadrails-e1e5f3005705b3028ca3a09c61444a8c21398273.tar.gz
rails-e1e5f3005705b3028ca3a09c61444a8c21398273.tar.bz2
rails-e1e5f3005705b3028ca3a09c61444a8c21398273.zip
Don't rely on Hash key's ordering
If we set encoding latin1 for a PostgreSQL database, it calls PostgreSQLAdapter::create_database with options that have, among other things: { 'encoding' => 'latin1' } Then, we use reverse_merge(:encoding => "utf8") to setup the default encoding. In the end, the hash looks like: { :encoding => 'utf8', 'encoding' => 'latin1' } The call to options.symbolize_keys calls to_sym on each_key of this Hash. It usually means that the encoding passed overwrites the default utf8, but it's not guaranteed. So, we shouldn't rely on it. The same was happening in ActiveRecord::ConnectionHandling.
Diffstat (limited to 'activerecord/lib/active_record/serialization.rb')
0 files changed, 0 insertions, 0 deletions