mirror of
https://github.com/ditkrg/active_model_serializers.git
synced 2026-01-22 22:06:50 +00:00
Merge pull request #837 from rails-api/store-options-in-array-serializers
Store options in array serializers
This commit is contained in:
commit
4b32e3913c
@ -176,19 +176,20 @@ module ActiveModel
|
||||
end
|
||||
|
||||
def each_association(&block)
|
||||
self.class._associations.dup.each do |name, options|
|
||||
self.class._associations.dup.each do |name, association_options|
|
||||
next unless object
|
||||
|
||||
association = object.send(name)
|
||||
association_value = send(name)
|
||||
serializer_class = ActiveModel::Serializer.serializer_for(association, options)
|
||||
serializer_class = ActiveModel::Serializer.serializer_for(association, association_options)
|
||||
|
||||
serializer = serializer_class.new(
|
||||
association_value,
|
||||
serializer_from_options(options)
|
||||
serializer_from_options(association_options).merge(options)
|
||||
) if serializer_class
|
||||
|
||||
if block_given?
|
||||
block.call(name, serializer, options[:association_options])
|
||||
block.call(name, serializer, association_options[:association_options])
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
@ -7,12 +7,14 @@ module ActiveModel
|
||||
attr_reader :meta, :meta_key
|
||||
|
||||
def initialize(objects, options = {})
|
||||
options.merge!(root: nil)
|
||||
|
||||
@objects = objects.map do |object|
|
||||
serializer_class = options.fetch(
|
||||
:serializer,
|
||||
ActiveModel::Serializer.serializer_for(object)
|
||||
)
|
||||
serializer_class.new(object)
|
||||
serializer_class.new(object, options)
|
||||
end
|
||||
@meta = options[:meta]
|
||||
@meta_key = options[:meta_key]
|
||||
|
||||
@ -6,7 +6,7 @@ module ActiveModel
|
||||
def setup
|
||||
@comment = Comment.new
|
||||
@post = Post.new
|
||||
@serializer = ArraySerializer.new([@comment, @post])
|
||||
@serializer = ArraySerializer.new([@comment, @post], {some: :options})
|
||||
end
|
||||
|
||||
def test_respond_to_each
|
||||
@ -21,6 +21,8 @@ module ActiveModel
|
||||
|
||||
assert_kind_of PostSerializer, serializers.last
|
||||
assert_kind_of Post, serializers.last.object
|
||||
|
||||
assert_equal serializers.last.custom_options[:some], :options
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
8
test/fixtures/poro.rb
vendored
8
test/fixtures/poro.rb
vendored
@ -78,6 +78,10 @@ PostSerializer = Class.new(ActiveModel::Serializer) do
|
||||
def blog
|
||||
Blog.new(id: 999, name: "Custom blog")
|
||||
end
|
||||
|
||||
def custom_options
|
||||
options
|
||||
end
|
||||
end
|
||||
|
||||
SpammyPostSerializer = Class.new(ActiveModel::Serializer) do
|
||||
@ -95,6 +99,10 @@ CommentSerializer = Class.new(ActiveModel::Serializer) do
|
||||
|
||||
belongs_to :post
|
||||
belongs_to :author
|
||||
|
||||
def custom_options
|
||||
options
|
||||
end
|
||||
end
|
||||
|
||||
AuthorSerializer = Class.new(ActiveModel::Serializer) do
|
||||
|
||||
@ -37,7 +37,7 @@ module ActiveModel
|
||||
@post.author = @author
|
||||
@author.posts = [@post]
|
||||
|
||||
@post_serializer = PostSerializer.new(@post)
|
||||
@post_serializer = PostSerializer.new(@post, {custom_options: true})
|
||||
@author_serializer = AuthorSerializer.new(@author)
|
||||
@comment_serializer = CommentSerializer.new(@comment)
|
||||
end
|
||||
@ -65,6 +65,14 @@ module ActiveModel
|
||||
end
|
||||
end
|
||||
|
||||
def test_serializer_options_are_passed_into_associations_serializers
|
||||
@post_serializer.each_association do |name, association|
|
||||
if name == :comments
|
||||
assert association.first.custom_options[:custom_options]
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
def test_belongs_to
|
||||
assert_equal(
|
||||
{ post: { type: :belongs_to, association_options: {} },
|
||||
|
||||
Loading…
Reference in New Issue
Block a user