Merge branch 'create-default-serializer' into HEAD

Conflicts:
	lib/active_model/array_serializer.rb
This commit is contained in:
Adam Stanton 2013-03-05 21:48:58 -08:00
commit da26ebd26f
3 changed files with 18 additions and 2 deletions

View File

@ -31,7 +31,8 @@ module ActiveModel
serializer = item.active_model_serializer serializer = item.active_model_serializer
end end
serializable = serializer ? serializer.new(item, @options) : item serializable = serializer ? serializer.new(item, @options)
: DefaultSerializer.new(item)
if serializable.respond_to?(:serializable_hash) if serializable.respond_to?(:serializable_hash)
serializable.serializable_hash serializable.serializable_hash

View File

@ -395,4 +395,20 @@ module ActiveModel
ActiveSupport::Notifications.instrument(event_name, payload, &block) ActiveSupport::Notifications.instrument(event_name, payload, &block)
end end
end end
# DefaultSerializer
#
# Provides a constant interface for all items, particularly
# for ArraySerializer.
class DefaultSerializer
attr_reader :object, :options
def initialize(object, options={})
@object, @options = object, options
end
def serializable_hash
@object.as_json
end
end
end end

View File

@ -51,5 +51,4 @@ class ArraySerializerTest < ActiveModel::TestCase
{ :title => "Post2" } { :title => "Post2" }
], serializer.as_json) ], serializer.as_json)
end end
end end