mirror of
https://github.com/ditkrg/active_model_serializers.git
synced 2026-01-23 06:16:50 +00:00
Merge pull request #728 from rails-api/linked-resources-use-type-as-key
Use type as key for linked resources
This commit is contained in:
commit
ac37570bff
@ -62,7 +62,7 @@ module ActiveModel
|
|||||||
resource_path = [parent, resource_name].compact.join('.')
|
resource_path = [parent, resource_name].compact.join('.')
|
||||||
|
|
||||||
if include_assoc?(resource_path)
|
if include_assoc?(resource_path)
|
||||||
plural_name = resource_name.to_s.pluralize.to_sym
|
plural_name = serialized_object_type(serializer).pluralize.to_sym
|
||||||
attrs = [attributes_for_serializer(serializer, @options)].flatten
|
attrs = [attributes_for_serializer(serializer, @options)].flatten
|
||||||
@top[:linked] ||= {}
|
@top[:linked] ||= {}
|
||||||
@top[:linked][plural_name] ||= []
|
@top[:linked][plural_name] ||= []
|
||||||
|
|||||||
@ -8,6 +8,7 @@ module ActiveModel
|
|||||||
def setup
|
def setup
|
||||||
@author = Author.new(id: 1, name: 'Steve K.')
|
@author = Author.new(id: 1, name: 'Steve K.')
|
||||||
@author.bio = nil
|
@author.bio = nil
|
||||||
|
@author.roles = []
|
||||||
@post = Post.new(id: 42, title: 'New Post', body: 'Body')
|
@post = Post.new(id: 42, title: 'New Post', body: 'Body')
|
||||||
@anonymous_post = Post.new(id: 43, title: 'Hello!!', body: 'Hello, world!!')
|
@anonymous_post = Post.new(id: 43, title: 'Hello!!', body: 'Hello, world!!')
|
||||||
@comment = Comment.new(id: 1, body: 'ZOMG A COMMENT')
|
@comment = Comment.new(id: 1, body: 'ZOMG A COMMENT')
|
||||||
@ -54,7 +55,53 @@ module ActiveModel
|
|||||||
def test_include_type_for_association_when_is_different_than_name
|
def test_include_type_for_association_when_is_different_than_name
|
||||||
serializer = BlogSerializer.new(@blog)
|
serializer = BlogSerializer.new(@blog)
|
||||||
adapter = ActiveModel::Serializer::Adapter::JsonApi.new(serializer)
|
adapter = ActiveModel::Serializer::Adapter::JsonApi.new(serializer)
|
||||||
assert_equal({type: "author", id: "1"}, adapter.serializable_hash[:blogs][:links][:writer])
|
links = adapter.serializable_hash[:blogs][:links]
|
||||||
|
expected = {
|
||||||
|
writer: {
|
||||||
|
type: "author",
|
||||||
|
id: "1"
|
||||||
|
},
|
||||||
|
articles: {
|
||||||
|
type: "posts",
|
||||||
|
ids: ["42", "43"]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
assert_equal expected, links
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_include_linked_resources_with_type_name
|
||||||
|
serializer = BlogSerializer.new(@blog)
|
||||||
|
adapter = ActiveModel::Serializer::Adapter::JsonApi.new(serializer, include: "writer,articles")
|
||||||
|
linked = adapter.serializable_hash[:linked]
|
||||||
|
expected = {
|
||||||
|
authors: [{
|
||||||
|
id: "1",
|
||||||
|
name: "Steve K.",
|
||||||
|
links: {
|
||||||
|
posts: [],
|
||||||
|
roles: [],
|
||||||
|
bio: nil
|
||||||
|
}
|
||||||
|
}],
|
||||||
|
posts: [{
|
||||||
|
title: "New Post",
|
||||||
|
body: "Body",
|
||||||
|
id: "42",
|
||||||
|
links: {
|
||||||
|
comments: ["1"],
|
||||||
|
author: "1"
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
title: "Hello!!",
|
||||||
|
body: "Hello, world!!",
|
||||||
|
id: "43",
|
||||||
|
links: {
|
||||||
|
comments: [],
|
||||||
|
author: nil
|
||||||
|
}
|
||||||
|
}]
|
||||||
|
}
|
||||||
|
assert_equal expected, linked
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user