Merge pull request #682 from ride/json-api-root

Include root by default in JSON-API serializers
This commit is contained in:
Steve Klabnik 2014-10-14 14:19:32 -04:00
commit efea975419
2 changed files with 22 additions and 0 deletions

View File

@ -2,6 +2,11 @@ module ActiveModel
class Serializer
class Adapter
class JsonApi < Adapter
def initialize(serializer, options = {})
super
serializer.root ||= true
end
def serializable_hash(opts = {})
@hash = serializer.attributes

View File

@ -13,6 +13,16 @@ module ActionController
@profile = Profile.new({ name: 'Name 1', description: 'Description 1', comments: 'Comments 1' })
render json: @profile, root: "custom_root"
end
def render_using_default_adapter_root
old_adapter = ActiveModel::Serializer.config.adapter
# JSON-API adapter sets root by default
ActiveModel::Serializer.config.adapter = ActiveModel::Serializer::Adapter::JsonApi
@profile = Profile.new({ name: 'Name 1', description: 'Description 1', comments: 'Comments 1' })
render json: @profile
ensure
ActiveModel::Serializer.config.adapter = old_adapter
end
end
tests MyController
@ -31,6 +41,13 @@ module ActionController
assert_equal 'application/json', @response.content_type
assert_equal '{"custom_root":{"name":"Name 1","description":"Description 1"}}', @response.body
end
def test_render_using_default_root
get :render_using_default_adapter_root
assert_equal 'application/json', @response.content_type
assert_equal '{"profile":{"name":"Name 1","description":"Description 1"}}', @response.body
end
end
end
end