diff options
| author | Jon Leighton <j@jonathanleighton.com> | 2012-02-07 23:23:18 +0000 | 
|---|---|---|
| committer | Jon Leighton <j@jonathanleighton.com> | 2012-02-07 23:41:21 +0000 | 
| commit | 77b4edce1544f105cc7764249becc1e998b88fc2 (patch) | |
| tree | 8e5b3a1a70220ea7abbb3f05e8fccb5abbafb5e3 | |
| parent | b3328779d0ce8e4568e7966099754eae1e5791ad (diff) | |
| download | rails-77b4edce1544f105cc7764249becc1e998b88fc2.tar.gz rails-77b4edce1544f105cc7764249becc1e998b88fc2.tar.bz2 rails-77b4edce1544f105cc7764249becc1e998b88fc2.zip | |
Fix attribute_before_type_cast for serialized attributes. Fixes #4837.
Conflicts:
	activerecord/lib/active_record/core.rb
| -rw-r--r-- | activerecord/lib/active_record/attribute_methods/serialization.rb | 8 | ||||
| -rw-r--r-- | activerecord/lib/active_record/base.rb | 2 | ||||
| -rw-r--r-- | activerecord/test/cases/base_test.rb | 15 | 
3 files changed, 25 insertions, 0 deletions
| diff --git a/activerecord/lib/active_record/attribute_methods/serialization.rb b/activerecord/lib/active_record/attribute_methods/serialization.rb index 2ffd91f796..1798afc3b7 100644 --- a/activerecord/lib/active_record/attribute_methods/serialization.rb +++ b/activerecord/lib/active_record/attribute_methods/serialization.rb @@ -88,6 +88,14 @@ module ActiveRecord            super          end        end + +      def read_attribute_before_type_cast(attr_name) +        if serialized_attributes.include?(attr_name) +          super.unserialized_value +        else +          super +        end +      end      end    end  end diff --git a/activerecord/lib/active_record/base.rb b/activerecord/lib/active_record/base.rb index 198db715b2..9c4d4cb274 100644 --- a/activerecord/lib/active_record/base.rb +++ b/activerecord/lib/active_record/base.rb @@ -531,6 +531,8 @@ module ActiveRecord #:nodoc:        # The dup method does not preserve the timestamps (created|updated)_(at|on).        def initialize_dup(other)          cloned_attributes = other.clone_attributes(:read_attribute_before_type_cast) +        self.class.initialize_attributes(cloned_attributes) +          cloned_attributes.delete(self.class.primary_key)          @attributes = cloned_attributes diff --git a/activerecord/test/cases/base_test.rb b/activerecord/test/cases/base_test.rb index 703bb7eb5c..aeb44da2b2 100644 --- a/activerecord/test/cases/base_test.rb +++ b/activerecord/test/cases/base_test.rb @@ -1251,6 +1251,21 @@ class BasicsTest < ActiveRecord::TestCase      assert_equal(hash, important_topic.content)    end +  # This test was added to fix GH #4004. Obviously the value returned +  # is not really the value 'before type cast' so we should maybe think +  # about changing that in the future. +  def test_serialized_attribute_before_type_cast_returns_unserialized_value +    klass = Class.new(ActiveRecord::Base) +    klass.table_name = "topics" +    klass.serialize :content, Hash + +    t = klass.new(:content => { :foo => :bar }) +    assert_equal({ :foo => :bar }, t.content_before_type_cast) +    t.save! +    t.reload +    assert_equal({ :foo => :bar }, t.content_before_type_cast) +  end +    def test_serialized_attribute_declared_in_subclass      hash = { 'important1' => 'value1', 'important2' => 'value2' }      important_topic = ImportantTopic.create("important" => hash) | 
