mirror of
https://github.com/ditkrg/active_model_serializers.git
synced 2026-01-24 23:06:50 +00:00
Revert polymorphism
This commit is contained in:
parent
c083774f9c
commit
ab1a4074ba
@ -80,10 +80,6 @@ module ActiveModel
|
|||||||
options[:key] || name
|
options[:key] || name
|
||||||
end
|
end
|
||||||
|
|
||||||
def polymorphic?
|
|
||||||
options[:polymorphic]
|
|
||||||
end
|
|
||||||
|
|
||||||
protected
|
protected
|
||||||
|
|
||||||
def find_serializable(object, scope, context, options)
|
def find_serializable(object, scope, context, options)
|
||||||
@ -121,49 +117,23 @@ module ActiveModel
|
|||||||
|
|
||||||
class HasOne < Config #:nodoc:
|
class HasOne < Config #:nodoc:
|
||||||
def serialize(object, scope, context, options)
|
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) }
|
{ key => object && find_serializable(object, scope, context, options).as_json(:root => false) }
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
def serialize_many(object, scope, context, options)
|
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
|
key = self.key.to_s.pluralize.to_sym
|
||||||
value = object && find_serializable(object, scope, context, options).as_json(:root => false)
|
value = object && find_serializable(object, scope, context, options).as_json(:root => false)
|
||||||
value = value ? [value] : []
|
value = value ? [value] : []
|
||||||
{ key => value }
|
{ key => value }
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
def serialize_ids(object, scope)
|
def serialize_ids(object, scope)
|
||||||
if polymorphic? && object
|
if object
|
||||||
{
|
|
||||||
polymorphic_key(object) => object.read_attribute_for_serialization(:id),
|
|
||||||
}
|
|
||||||
elsif polymorphic? && !object
|
|
||||||
{ }
|
|
||||||
elsif object
|
|
||||||
{ key => object.read_attribute_for_serialization(:id) }
|
{ key => object.read_attribute_for_serialization(:id) }
|
||||||
else
|
else
|
||||||
{ key => nil }
|
{ key => nil }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def polymorphic_key(object)
|
|
||||||
object.class.to_s.demodulize.underscore.to_sym
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@ -679,95 +679,6 @@ class SerializerTest < ActiveModel::TestCase
|
|||||||
}, hash.as_json)
|
}, hash.as_json)
|
||||||
end
|
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
|
def test_root_provided_in_options
|
||||||
author_serializer = Class.new(ActiveModel::Serializer) do
|
author_serializer = Class.new(ActiveModel::Serializer) do
|
||||||
attributes :id, :name
|
attributes :id, :name
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user