Merge pull request #306 from dgalarza/controller_action_scope_name_fix

Allow a controller to properly override scope_name
This commit is contained in:
Santiago Pastorino 2013-05-22 14:21:20 -07:00
commit f533fa24df
2 changed files with 33 additions and 1 deletions

View File

@ -284,7 +284,7 @@ module ActiveModel
end
options[:scope] = controller.serialization_scope unless options.has_key?(:scope)
options[:scope_name] = controller._serialization_scope
options[:scope_name] = controller._serialization_scope unless options.has_key?(:scope_name)
options[:url_options] = controller.url_options
serializer.new(resource, options)

View File

@ -65,3 +65,35 @@ class SerializationScopeNameTest < ActionController::TestCase
assert_equal '{"admin_user":{"admin":true}}', @response.body
end
end
class SerializationActionScopeOverrideTest < ActionController::TestCase
TestUser = Struct.new(:name, :admin)
class AdminUserSerializer < ActiveModel::Serializer
attributes :admin?
def admin?
current_admin.admin
end
end
class AdminUserTestController < ActionController::Base
protect_from_forgery
before_filter { request.format = :json }
def current_admin
TestUser.new('Bob', true)
end
def render_new_user
render :json => TestUser.new('pete', false), :serializer => AdminUserSerializer, :scope => current_admin, :scope_name => :current_admin
end
end
tests AdminUserTestController
def test_override_scope_name_with_controller
get :render_new_user
assert_equal '{"admin_user":{"admin":true}}', @response.body
end
end