-
Notifications
You must be signed in to change notification settings - Fork 1.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Grape formatter feature requested in #1268
- adds handling for when the returned resource is not serializable via ams - fix for when resource is an Array - Moves grape include to grape namespace. Changes Enumerable to Array because a plain hash is enumerable. - Add integration test - Refine scope of Grape version dependency - Assert that the response is equal to a manually defined JSON string - Add single module to include in Grape projects - Create a Serializable Resource to test rails-api from Grape - Update docs - Fix discrepency between ActiveRecord 4.0 - 4.1 and 4.2
- Loading branch information
1 parent
aa43848
commit abe0982
Showing
7 changed files
with
156 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
# Integration with Grape | ||
|
||
[Grape](https://github.com/ruby-grape/grape) is an opinionated micro-framework for creating REST-like APIs in ruby. | ||
|
||
ActiveModelSerializers currently supports Grape 0.13.x | ||
|
||
To add [Grape](https://github.com/ruby-grape/grape) support, add the following in the base of your Grape endpoints to enable the formatter and helper functions: | ||
|
||
```ruby | ||
module Example | ||
class Dummy < Grape::API | ||
require 'grape/active_model_serializers' | ||
include Grape::ActiveModelSerializers | ||
mount Example::V1::Base | ||
end | ||
end | ||
``` | ||
|
||
Aside from this, [configuration](../general/configuration_options.md) of AMS is exactly the same. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
# To add grape support, require 'grape/active_model_serializers' in the base of your grape endpoints | ||
# Then add 'include Grape::ActiveModelSerializers' to enable the formatter and helpers | ||
require 'active_model_serializers' | ||
require 'grape/formatters/active_model_serializers' | ||
require 'grape/helpers/active_model_serializers' | ||
|
||
module Grape::ActiveModelSerializers | ||
extend ActiveSupport::Concern | ||
|
||
included do | ||
formatter :json, Grape::Formatters::ActiveModelSerializers | ||
helpers Grape::Helpers::ActiveModelSerializers | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
# A grape response formatter that can be used as 'formatter :json, Grape::Formatters::ActiveModelSerializers' | ||
# | ||
# Serializer options can be passed as a hash from your grape endpoint using env[:active_model_serializer_options], | ||
# or better yet user the render helper in Grape::Helpers::ActiveModelSerializers | ||
module Grape | ||
module Formatters | ||
module ActiveModelSerializers | ||
def self.call(resource, env) | ||
return resource.to_json unless resource.is_a?(Array) || resource.respond_to?(:model_name) || resource.class.respond_to?(:model_name) | ||
serializer_options = {} | ||
serializer_options.merge!(env[:active_model_serializer_options]) if env[:active_model_serializer_options] | ||
ActiveModel::SerializableResource.new(resource, serializer_options).to_json | ||
end | ||
end | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
# Helpers can be included in your grape endpoint as: helpers Grape::Helpers::ActiveModelSerializers | ||
module Grape | ||
module Helpers | ||
module ActiveModelSerializers | ||
# A convenience method for passing ActiveModelSerializers serializer options | ||
# | ||
# Example: To include relationships in the response: render(post, include: ['comments']) | ||
# | ||
# Example: To include pagination meta data: render(posts, meta: { page: posts.page, total_pages: posts.total_pages }) | ||
def render(resource, active_model_serializer_options = {}) | ||
env[:active_model_serializer_options] = active_model_serializer_options | ||
resource | ||
end | ||
end | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,89 @@ | ||
require 'test_helper' | ||
require 'grape' | ||
require 'grape/active_model_serializers' | ||
|
||
class ActiveModelSerializers::GrapeTest < Minitest::Test | ||
include Rack::Test::Methods | ||
|
||
class GrapeTest < Grape::API | ||
format :json | ||
include Grape::ActiveModelSerializers | ||
|
||
resources :grape do | ||
get '/render' do | ||
render ARModels::Post.new(title: 'Dummy Title', body: 'Lorem Ipsum') | ||
end | ||
|
||
get '/render_with_json_api' do | ||
post = ARModels::Post.new(title: 'Dummy Title', body: 'Lorem Ipsum') | ||
render( | ||
post, | ||
meta: { page: 1, total_pages: 2 }, | ||
adapter: :json_api | ||
) | ||
end | ||
|
||
get '/render_array_with_json_api' do | ||
post = ARModels::Post.create(title: 'Dummy Title', body: 'Lorem Ipsum') | ||
post.dup.save | ||
render(ARModels::Post.all, adapter: :json_api) | ||
end | ||
end | ||
end | ||
|
||
def app | ||
GrapeTest.new | ||
end | ||
|
||
def test_formatter_returns_json | ||
get '/grape/render' | ||
assert last_response.ok? | ||
expected = { id: nil, title: 'Dummy Title', body: 'Lorem Ipsum', comments: [], author: nil } | ||
assert_equal expected.to_json, last_response.body | ||
end | ||
|
||
def test_render_helper_passes_through_options_correctly | ||
get '/grape/render_with_json_api' | ||
|
||
post = ARModels::Post.new(title: 'Dummy Title', body: 'Lorem Ipsum') | ||
serializable_resource = serializable(post, serializer: ARModels::PostSerializer, adapter: :json_api, meta: { page: 1, total_pages: 2 }) | ||
|
||
assert last_response.ok? | ||
assert_equal serializable_resource.to_json, last_response.body | ||
end | ||
|
||
def test_formatter_handles_arrays | ||
get '/grape/render_array_with_json_api' | ||
|
||
expected = { | ||
'data' => [ | ||
{ | ||
id: '1', | ||
type: 'ar_models_posts', | ||
attributes: { | ||
title: 'Dummy Title', | ||
body: 'Lorem Ipsum' | ||
}, | ||
relationships: { | ||
comments: { data: [] }, | ||
author: { data: nil } | ||
} | ||
}, | ||
{ | ||
id: '2', | ||
type: 'ar_models_posts', | ||
attributes: { | ||
title: 'Dummy Title', | ||
body: 'Lorem Ipsum' | ||
}, | ||
relationships: { | ||
comments: { data: [] }, | ||
author: { data: nil } | ||
} | ||
} | ||
] | ||
} | ||
|
||
assert_equal expected.to_json, last_response.body | ||
end | ||
end |