Merge pull request #213 from michihuber/fix_rendering_nil_with_custom_serializer

Fix rendering nil with custom serializer
This commit is contained in:
Steve Klabnik 2013-03-05 15:54:51 -08:00
commit 06c65871a8
3 changed files with 37 additions and 0 deletions

View File

@ -274,6 +274,7 @@ module ActiveModel
# Returns a hash representation of the serializable
# object without the root.
def serializable_hash
return nil if @object.nil?
instrument(:serialize, :serializer => self.class.name) do
@node = attributes
instrument :associations do

View File

@ -63,6 +63,10 @@ class RenderJsonTest < ActionController::TestCase
end
end
class DummyCustomSerializer < ActiveModel::Serializer
attributes :id
end
class HypermediaSerializable
def active_model_serializer
HypermediaSerializer
@ -117,6 +121,11 @@ class RenderJsonTest < ActionController::TestCase
render :json => ActiveSupport::JSON.encode(:hello => 'world')
end
def render_json_nil_with_custom_serializer
render :json => nil, :serializer => DummyCustomSerializer
end
def render_json_with_extra_options
render :json => JsonRenderable.new, :except => [:c, :e]
end
@ -216,6 +225,11 @@ class RenderJsonTest < ActionController::TestCase
assert_equal '[]', @response.body
end
def test_render_json_nil_with_custom_serializer
get :render_json_nil_with_custom_serializer
assert_equal "{\"dummy_custom\":null}", @response.body
end
def test_render_json
get :render_json_hello_world
assert_equal '{"hello":"world"}', @response.body

View File

@ -276,6 +276,28 @@ class SerializerTest < ActiveModel::TestCase
assert_equal({ :my_blog => { :author => nil } }, serializer.new(blog, :scope => user).as_json)
end
def test_nil_root_object
user = User.new
blog = nil
serializer = Class.new(BlogSerializer) do
root false
end
assert_equal(nil, serializer.new(blog, :scope => user).as_json)
end
def test_custom_root_with_nil_root_object
user = User.new
blog = nil
serializer = Class.new(BlogSerializer) do
root :my_blog
end
assert_equal({ :my_blog => nil }, serializer.new(blog, :scope => user).as_json)
end
def test_false_root
user = User.new
blog = Blog.new