Merge pull request #773 from sweatypitts/master

Make json api adapter 'include' option accept an array
This commit is contained in:
Alexandre de Oliveira 2015-03-11 14:59:39 -03:00
commit 3e8325b63e
6 changed files with 144 additions and 105 deletions

View File

@ -189,6 +189,8 @@ resources in the `"linked"` member when the resource names are included in the
`include` option. `include` option.
```ruby ```ruby
render @posts, include: ['authors', 'comments']
# or
render @posts, include: 'authors,comments' render @posts, include: 'authors,comments'
``` ```

View File

@ -121,7 +121,9 @@ module ActiveModel
end end
def check_assoc(assoc) def check_assoc(assoc)
@options[:include].split(',').any? do |s| include_opt = @options[:include]
include_opt = include_opt.split(',') if include_opt.is_a?(String)
include_opt.any? do |s|
s.match(/^#{assoc.gsub('.', '\.')}/) s.match(/^#{assoc.gsub('.', '\.')}/)
end end
end end

View File

@ -52,7 +52,7 @@ module ActionController
def render_resource_with_nested_has_many_include def render_resource_with_nested_has_many_include
setup_post setup_post
render json: @post, include: 'author,author.roles', adapter: :json_api render json: @post, include: ['author', 'author.roles'], adapter: :json_api
end end
def render_resource_with_missing_nested_has_many_include def render_resource_with_missing_nested_has_many_include
@ -74,7 +74,7 @@ module ActionController
def render_collection_with_include def render_collection_with_include
setup_post setup_post
render json: [@post], include: 'author,comments', adapter: :json_api render json: [@post], include: ['author', 'comments'], adapter: :json_api
end end
end end

View File

@ -89,7 +89,7 @@ module ActiveModel
def test_include_linked_resources_with_type_name def test_include_linked_resources_with_type_name
serializer = BlogSerializer.new(@blog) serializer = BlogSerializer.new(@blog)
adapter = ActiveModel::Serializer::Adapter::JsonApi.new(serializer, include: "writer,articles") adapter = ActiveModel::Serializer::Adapter::JsonApi.new(serializer, include: ['writer', 'articles'])
linked = adapter.serializable_hash[:linked] linked = adapter.serializable_hash[:linked]
expected = { expected = {
authors: [{ authors: [{

View File

@ -24,7 +24,7 @@ module ActiveModel
@serializer = PostPreviewSerializer.new(@post) @serializer = PostPreviewSerializer.new(@post)
@adapter = ActiveModel::Serializer::Adapter::JsonApi.new( @adapter = ActiveModel::Serializer::Adapter::JsonApi.new(
@serializer, @serializer,
include: 'comments,author' include: ['comments', 'author']
) )
end end

View File

@ -14,14 +14,21 @@ module ActiveModel
@second_post = Post.new(id: 20, title: 'New Post', body: 'Body') @second_post = Post.new(id: 20, title: 'New Post', body: 'Body')
@third_post = Post.new(id: 30, title: 'Yet Another Post', body: 'Body') @third_post = Post.new(id: 30, title: 'Yet Another Post', body: 'Body')
@blog = Blog.new({ name: 'AMS Blog' }) @blog = Blog.new({ name: 'AMS Blog' })
@first_comment = Comment.new(id: 1, body: 'ZOMG A COMMENT')
@second_comment = Comment.new(id: 2, body: 'ZOMG ANOTHER COMMENT')
@first_post.blog = @blog @first_post.blog = @blog
@second_post.blog = @blog @second_post.blog = @blog
@third_post.blog = nil @third_post.blog = nil
@first_post.comments = [] @first_post.comments = [@first_comment, @second_comment]
@second_post.comments = [] @second_post.comments = []
@third_post.comments = []
@first_post.author = @author1 @first_post.author = @author1
@second_post.author = @author2 @second_post.author = @author2
@third_post.author = @author1 @third_post.author = @author1
@first_comment.post = @first_post
@first_comment.author = nil
@second_comment.post = @first_post
@second_comment.author = nil
@author1.posts = [@first_post, @third_post] @author1.posts = [@first_post, @third_post]
@author1.bio = @bio1 @author1.bio = @bio1
@author1.roles = [] @author1.roles = []
@ -33,43 +40,41 @@ module ActiveModel
end end
def test_include_multiple_posts_and_linked def test_include_multiple_posts_and_linked
@serializer = ArraySerializer.new([@first_post, @second_post]) serializer = ArraySerializer.new([@first_post, @second_post])
@adapter = ActiveModel::Serializer::Adapter::JsonApi.new(@serializer, include: 'author,author.bio,comments') adapter = ActiveModel::Serializer::Adapter::JsonApi.new(
serializer,
@first_comment = Comment.new(id: 1, body: 'ZOMG A COMMENT') include: ['author', 'author.bio', 'comments']
@second_comment = Comment.new(id: 2, body: 'ZOMG ANOTHER COMMENT') )
@first_post.comments = [@first_comment, @second_comment] alt_adapter = ActiveModel::Serializer::Adapter::JsonApi.new(
@first_comment.post = @first_post serializer,
@first_comment.author = nil include: 'author,author.bio,comments'
@second_comment.post = @first_post )
@second_comment.author = nil
assert_equal([
{ title: "Hello!!", body: "Hello, world!!", id: "10", links: { comments: ['1', '2'], blog: "999", author: "1" } },
{ title: "New Post", body: "Body", id: "20", links: { comments: [], blog: "999", author: "2" } }
], @adapter.serializable_hash[:posts])
expected = { expected = {
comments: [{ linked: {
comments: [
{
id: "1", id: "1",
body: "ZOMG A COMMENT", body: "ZOMG A COMMENT",
links: { links: {
post: "10", post: "1",
author: nil author: nil
} }
}, { }, {
id: "2", id: "2",
body: "ZOMG ANOTHER COMMENT", body: "ZOMG ANOTHER COMMENT",
links: { links: {
post: "10", post: "1",
author: nil author: nil
} }
}], }
authors: [{ ],
authors: [
{
id: "1", id: "1",
name: "Steve K.", name: "Steve K.",
links: { links: {
posts: ["10", "30"], posts: ["1", "3"],
roles: [], roles: [],
bio: "1" bio: "1"
} }
@ -77,12 +82,14 @@ module ActiveModel
id: "2", id: "2",
name: "Tenderlove", name: "Tenderlove",
links: { links: {
posts: ["20"], posts: ["2"],
roles: [], roles: [],
bio: "2" bio: "2"
} }
}], }
bios: [{ ],
bios: [
{
id: "1", id: "1",
content: "AMS Contributor", content: "AMS Contributor",
links: { links: {
@ -94,26 +101,50 @@ module ActiveModel
links: { links: {
author: "2" author: "2"
} }
}]
} }
assert_equal expected, @adapter.serializable_hash[:linked] ]
},
posts: [
{
id: "10",
title: "Hello!!",
body: "Hello, world!!",
links: {
comments: ['1', '2'],
blog: "999",
author: "1"
}
},
{
id: "2",
title: "New Post",
body: "Body",
links: {
comments: [],
blog: "999",
author: "2"
}
}
]
}
assert_equal expected, adapter.serializable_hash
assert_equal expected, alt_adapter.serializable_hash
end end
def test_include_bio_and_linked def test_include_multiple_posts_and_linked
@serializer = BioSerializer.new(@bio1) serializer = BioSerializer.new @bio1
@adapter = ActiveModel::Serializer::Adapter::JsonApi.new(@serializer, include: 'author,author.posts') adapter = ActiveModel::Serializer::Adapter::JsonApi.new(
serializer,
@first_comment = Comment.new(id: 1, body: 'ZOMG A COMMENT') include: ['author', 'author.posts']
@second_comment = Comment.new(id: 2, body: 'ZOMG ANOTHER COMMENT') )
@first_post.comments = [@first_comment, @second_comment] alt_adapter = ActiveModel::Serializer::Adapter::JsonApi.new(
@third_post.comments = [] serializer,
@first_comment.post = @first_post include: 'author,author.posts'
@first_comment.author = nil )
@second_comment.post = @first_post
@second_comment.author = nil
expected = { expected = {
authors: [{ authors: [
{
id: "1", id: "1",
name: "Steve K.", name: "Steve K.",
links: { links: {
@ -121,28 +152,32 @@ module ActiveModel
roles: [], roles: [],
bio: "1" bio: "1"
} }
}], }
posts: [{ ],
posts: [
{
id: "10",
title: "Hello!!", title: "Hello!!",
body: "Hello, world!!", body: "Hello, world!!",
id: "10",
links: { links: {
comments: ["1", "2"], comments: ["1", "2"],
blog: "999", blog: "999",
author: "1" author: "1"
} }
}, { }, {
id: "30",
title: "Yet Another Post", title: "Yet Another Post",
body: "Body", body: "Body",
id: "30",
links: { links: {
comments: [], comments: [],
blog: nil, blog: nil,
author: "1" author: "1"
} }
}]
} }
assert_equal expected, @adapter.serializable_hash[:linked] ]
}
assert_equal expected, adapter.serializable_hash[:linked]
assert_equal expected, alt_adapter.serializable_hash[:linked]
end end
def test_ignore_model_namespace_for_linked_resource_type def test_ignore_model_namespace_for_linked_resource_type