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
3 changed files with 37 additions and 0 deletions

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