mirror of
https://github.com/ditkrg/active_model_serializers.git
synced 2026-01-23 06:16:50 +00:00
Revert polymorphism
This commit is contained in:
parent
c083774f9c
commit
ab1a4074ba
@ -80,10 +80,6 @@ module ActiveModel
|
||||
options[:key] || name
|
||||
end
|
||||
|
||||
def polymorphic?
|
||||
options[:polymorphic]
|
||||
end
|
||||
|
||||
protected
|
||||
|
||||
def find_serializable(object, scope, context, options)
|
||||
@ -121,49 +117,23 @@ module ActiveModel
|
||||
|
||||
class HasOne < Config #:nodoc:
|
||||
def serialize(object, scope, context, options)
|
||||
if polymorphic?
|
||||
if object
|
||||
find_serializable(object, scope, context, options).as_json(:root => polymorphic_key(object))
|
||||
else
|
||||
{}
|
||||
end
|
||||
else
|
||||
{ key => object && find_serializable(object, scope, context, options).as_json(:root => false) }
|
||||
end
|
||||
{ key => object && find_serializable(object, scope, context, options).as_json(:root => false) }
|
||||
end
|
||||
|
||||
def serialize_many(object, scope, context, options)
|
||||
if polymorphic?
|
||||
if object
|
||||
find_serializable(object, scope, context, options).as_json(:root => polymorphic_key(object))
|
||||
else
|
||||
{}
|
||||
end
|
||||
else
|
||||
key = self.key.to_s.pluralize.to_sym
|
||||
value = object && find_serializable(object, scope, context, options).as_json(:root => false)
|
||||
value = value ? [value] : []
|
||||
{ key => value }
|
||||
end
|
||||
key = self.key.to_s.pluralize.to_sym
|
||||
value = object && find_serializable(object, scope, context, options).as_json(:root => false)
|
||||
value = value ? [value] : []
|
||||
{ key => value }
|
||||
end
|
||||
|
||||
def serialize_ids(object, scope)
|
||||
if polymorphic? && object
|
||||
{
|
||||
polymorphic_key(object) => object.read_attribute_for_serialization(:id),
|
||||
}
|
||||
elsif polymorphic? && !object
|
||||
{ }
|
||||
elsif object
|
||||
if object
|
||||
{ key => object.read_attribute_for_serialization(:id) }
|
||||
else
|
||||
{ key => nil }
|
||||
end
|
||||
end
|
||||
|
||||
def polymorphic_key(object)
|
||||
object.class.to_s.demodulize.underscore.to_sym
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
@ -679,95 +679,6 @@ class SerializerTest < ActiveModel::TestCase
|
||||
}, hash.as_json)
|
||||
end
|
||||
|
||||
class PolymorphicUser < User ; end
|
||||
|
||||
class PolymorphicUserSerializer < ActiveModel::Serializer
|
||||
attributes :first_name, :last_name
|
||||
end
|
||||
|
||||
def test_polymorphic_has_one
|
||||
polymorphic_blog = Class.new do
|
||||
attr_accessor :writer
|
||||
end
|
||||
|
||||
polymorphic_serializer = Class.new(ActiveModel::Serializer) do
|
||||
has_one :writer, :polymorphic => true
|
||||
end
|
||||
|
||||
user = PolymorphicUser.new
|
||||
blog = polymorphic_blog.new
|
||||
blog.writer = user
|
||||
|
||||
serializer = polymorphic_serializer.new(blog, user)
|
||||
|
||||
assert_equal({
|
||||
:polymorphic_user => {
|
||||
:first_name => "Jose",
|
||||
:last_name => "Valim"
|
||||
}
|
||||
}, serializer.as_json)
|
||||
end
|
||||
|
||||
def test_polymorphic_has_one_with_nil
|
||||
polymorphic_blog = Class.new do
|
||||
attr_accessor :writer
|
||||
end
|
||||
|
||||
polymorphic_serializer = Class.new(ActiveModel::Serializer) do
|
||||
has_one :writer, :polymorphic => true
|
||||
end
|
||||
|
||||
user = PolymorphicUser.new
|
||||
blog = polymorphic_blog.new
|
||||
blog.writer = nil
|
||||
|
||||
serializer = polymorphic_serializer.new(blog, user)
|
||||
|
||||
assert_equal({
|
||||
}, serializer.as_json)
|
||||
end
|
||||
|
||||
def test_polymorphic_has_one_with_ids
|
||||
polymorphic_blog = Class.new do
|
||||
attr_accessor :writer
|
||||
end
|
||||
|
||||
polymorphic_serializer = Class.new(ActiveModel::Serializer) do
|
||||
embed :ids
|
||||
has_one :writer, :polymorphic => true
|
||||
end
|
||||
|
||||
user = PolymorphicUser.new :id => 1
|
||||
blog = polymorphic_blog.new
|
||||
blog.writer = user
|
||||
|
||||
serializer = polymorphic_serializer.new(blog, user)
|
||||
|
||||
assert_equal({
|
||||
:polymorphic_user => 1
|
||||
}, serializer.as_json)
|
||||
end
|
||||
|
||||
def test_polymorphic_has_one_id_with_nil
|
||||
polymorphic_blog = Class.new do
|
||||
attr_accessor :writer
|
||||
end
|
||||
|
||||
polymorphic_serializer = Class.new(ActiveModel::Serializer) do
|
||||
embed :ids
|
||||
has_one :writer, :polymorphic => true
|
||||
end
|
||||
|
||||
user = PolymorphicUser.new
|
||||
blog = polymorphic_blog.new
|
||||
blog.writer = nil
|
||||
|
||||
serializer = polymorphic_serializer.new(blog, user)
|
||||
|
||||
assert_equal({
|
||||
}, serializer.as_json)
|
||||
end
|
||||
|
||||
def test_root_provided_in_options
|
||||
author_serializer = Class.new(ActiveModel::Serializer) do
|
||||
attributes :id, :name
|
||||
|
||||
Loading…
Reference in New Issue
Block a user