aboutsummaryrefslogtreecommitdiffstats
path: root/activemodel/test/cases/mass_assignment_security_test.rb
diff options
context:
space:
mode:
authorBogdan Gusiev <agresso@gmail.com>2011-05-26 15:58:43 +0300
committerBogdan Gusiev <agresso@gmail.com>2011-05-26 15:58:43 +0300
commitc7567c9a6dee1380432beaf88c1854a4ed6bb15b (patch)
tree5377527d012f7d5dfa25c1b393c65c14213e9982 /activemodel/test/cases/mass_assignment_security_test.rb
parent9562c0f8998e04833737591378841b45bbf24bef (diff)
downloadrails-c7567c9a6dee1380432beaf88c1854a4ed6bb15b.tar.gz
rails-c7567c9a6dee1380432beaf88c1854a4ed6bb15b.tar.bz2
rails-c7567c9a6dee1380432beaf88c1854a4ed6bb15b.zip
MassAssignmentSecurity: add ability to specify your own sanitizer
Added an ability to specify your own behavior on mass assingment protection, controlled by option: ActiveModel::MassAssignmentSecurity.mass_assignment_sanitizer
Diffstat (limited to 'activemodel/test/cases/mass_assignment_security_test.rb')
-rw-r--r--activemodel/test/cases/mass_assignment_security_test.rb20
1 files changed, 20 insertions, 0 deletions
diff --git a/activemodel/test/cases/mass_assignment_security_test.rb b/activemodel/test/cases/mass_assignment_security_test.rb
index 43a12eed61..a778240827 100644
--- a/activemodel/test/cases/mass_assignment_security_test.rb
+++ b/activemodel/test/cases/mass_assignment_security_test.rb
@@ -1,6 +1,15 @@
require "cases/helper"
require 'models/mass_assignment_specific'
+
+class CustomSanitizer < ActiveModel::MassAssignmentSecurity::Sanitizer
+
+ def process_removed_attributes(attrs)
+ raise StandardError
+ end
+
+end
+
class MassAssignmentSecurityTest < ActiveModel::TestCase
def test_attribute_protection
@@ -76,4 +85,15 @@ class MassAssignmentSecurityTest < ActiveModel::TestCase
assert_equal sanitized, { }
end
+ def test_custom_sanitizer
+ user = User.new
+ User.mass_assignment_sanitizer = CustomSanitizer.new
+ assert_raise StandardError do
+ user.sanitize_for_mass_assignment("admin" => true)
+ end
+ ensure
+ User.mass_assignment_sanitizer = nil
+
+ end
+
end