aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/cases
diff options
context:
space:
mode:
authorGuillermo Iguaran <guilleiguaran@gmail.com>2012-07-17 02:34:57 -0500
committerGuillermo Iguaran <guilleiguaran@gmail.com>2012-09-16 23:58:19 -0500
commit8020f71df120f80fd7db9ab568c8d0d6d1ad4e28 (patch)
tree5e6fa3226871f385f0a154d566ddaf0b713f49a4 /activerecord/test/cases
parentf8c9a4d3e88181cee644f91e1342bfe896ca64c6 (diff)
downloadrails-8020f71df120f80fd7db9ab568c8d0d6d1ad4e28.tar.gz
rails-8020f71df120f80fd7db9ab568c8d0d6d1ad4e28.tar.bz2
rails-8020f71df120f80fd7db9ab568c8d0d6d1ad4e28.zip
Remove mass assignment security from ActiveRecord
Diffstat (limited to 'activerecord/test/cases')
-rw-r--r--activerecord/test/cases/associations/has_many_associations_test.rb22
-rw-r--r--activerecord/test/cases/associations/has_many_through_associations_test.rb15
-rw-r--r--activerecord/test/cases/associations/has_one_associations_test.rb16
-rw-r--r--activerecord/test/cases/base_test.rb4
-rw-r--r--activerecord/test/cases/deprecated_dynamic_methods_test.rb28
-rw-r--r--activerecord/test/cases/mass_assignment_security_test.rb966
-rw-r--r--activerecord/test/cases/validations_test.rb6
7 files changed, 6 insertions, 1051 deletions
diff --git a/activerecord/test/cases/associations/has_many_associations_test.rb b/activerecord/test/cases/associations/has_many_associations_test.rb
index 5edabb4790..83128628ef 100644
--- a/activerecord/test/cases/associations/has_many_associations_test.rb
+++ b/activerecord/test/cases/associations/has_many_associations_test.rb
@@ -188,28 +188,6 @@ class HasManyAssociationsTest < ActiveRecord::TestCase
assert_equal invoice.id, line_item.invoice_id
end
- def test_association_conditions_bypass_attribute_protection
- car = Car.create(:name => 'honda')
-
- bulb = car.frickinawesome_bulbs.new
- assert_equal true, bulb.frickinawesome?
-
- bulb = car.frickinawesome_bulbs.new(:frickinawesome => false)
- assert_equal true, bulb.frickinawesome?
-
- bulb = car.frickinawesome_bulbs.build
- assert_equal true, bulb.frickinawesome?
-
- bulb = car.frickinawesome_bulbs.build(:frickinawesome => false)
- assert_equal true, bulb.frickinawesome?
-
- bulb = car.frickinawesome_bulbs.create
- assert_equal true, bulb.frickinawesome?
-
- bulb = car.frickinawesome_bulbs.create(:frickinawesome => false)
- assert_equal true, bulb.frickinawesome?
- end
-
# When creating objects on the association, we must not do it within a scope (even though it
# would be convenient), because this would cause that scope to be applied to any callbacks etc.
def test_build_and_create_should_not_happen_within_scope
diff --git a/activerecord/test/cases/associations/has_many_through_associations_test.rb b/activerecord/test/cases/associations/has_many_through_associations_test.rb
index 36e5ba9660..50a40739b9 100644
--- a/activerecord/test/cases/associations/has_many_through_associations_test.rb
+++ b/activerecord/test/cases/associations/has_many_through_associations_test.rb
@@ -58,21 +58,6 @@ class HasManyThroughAssociationsTest < ActiveRecord::TestCase
assert post.reload.people(true).include?(person)
end
- def test_associate_existing_with_strict_mass_assignment_sanitizer
- SecureReader.mass_assignment_sanitizer = :strict
-
- SecureReader.new
-
- post = posts(:thinking)
- person = people(:david)
-
- assert_queries(1) do
- post.secure_people << person
- end
- ensure
- SecureReader.mass_assignment_sanitizer = :logger
- end
-
def test_associate_existing_record_twice_should_add_to_target_twice
post = posts(:thinking)
person = people(:david)
diff --git a/activerecord/test/cases/associations/has_one_associations_test.rb b/activerecord/test/cases/associations/has_one_associations_test.rb
index 8bc633f2b5..a7ec0f2709 100644
--- a/activerecord/test/cases/associations/has_one_associations_test.rb
+++ b/activerecord/test/cases/associations/has_one_associations_test.rb
@@ -446,22 +446,6 @@ class HasOneAssociationsTest < ActiveRecord::TestCase
assert_equal pirate.id, ship.pirate_id
end
- def test_association_conditions_bypass_attribute_protection
- car = Car.create(:name => 'honda')
-
- bulb = car.build_frickinawesome_bulb
- assert_equal true, bulb.frickinawesome?
-
- bulb = car.build_frickinawesome_bulb(:frickinawesome => false)
- assert_equal true, bulb.frickinawesome?
-
- bulb = car.create_frickinawesome_bulb
- assert_equal true, bulb.frickinawesome?
-
- bulb = car.create_frickinawesome_bulb(:frickinawesome => false)
- assert_equal true, bulb.frickinawesome?
- end
-
def test_new_is_called_with_attributes_and_options
car = Car.create(:name => 'honda')
diff --git a/activerecord/test/cases/base_test.rb b/activerecord/test/cases/base_test.rb
index b25d169038..fbfdd0f07a 100644
--- a/activerecord/test/cases/base_test.rb
+++ b/activerecord/test/cases/base_test.rb
@@ -55,10 +55,6 @@ class ReadonlyTitlePost < Post
attr_readonly :title
end
-class ProtectedTitlePost < Post
- attr_protected :title
-end
-
class Weird < ActiveRecord::Base; end
class Boolean < ActiveRecord::Base
diff --git a/activerecord/test/cases/deprecated_dynamic_methods_test.rb b/activerecord/test/cases/deprecated_dynamic_methods_test.rb
index 392f5f4cd5..dde36e7f72 100644
--- a/activerecord/test/cases/deprecated_dynamic_methods_test.rb
+++ b/activerecord/test/cases/deprecated_dynamic_methods_test.rb
@@ -199,23 +199,7 @@ class DeprecatedDynamicMethodsTest < ActiveRecord::TestCase
assert !new_customer.persisted?
end
- def test_find_or_initialize_from_one_attribute_should_not_set_attribute_even_when_protected
- c = Company.find_or_initialize_by_name({:name => "Fortune 1000", :rating => 1000})
- assert_equal "Fortune 1000", c.name
- assert_not_equal 1000, c.rating
- assert c.valid?
- assert !c.persisted?
- end
-
- def test_find_or_create_from_one_attribute_should_not_set_attribute_even_when_protected
- c = Company.find_or_create_by_name({:name => "Fortune 1000", :rating => 1000})
- assert_equal "Fortune 1000", c.name
- assert_not_equal 1000, c.rating
- assert c.valid?
- assert c.persisted?
- end
-
- def test_find_or_initialize_from_one_attribute_should_set_attribute_even_when_protected
+ def test_find_or_initialize_from_one_attribute_should_set_attribute
c = Company.find_or_initialize_by_name_and_rating("Fortune 1000", 1000)
assert_equal "Fortune 1000", c.name
assert_equal 1000, c.rating
@@ -223,7 +207,7 @@ class DeprecatedDynamicMethodsTest < ActiveRecord::TestCase
assert !c.persisted?
end
- def test_find_or_create_from_one_attribute_should_set_attribute_even_when_protected
+ def test_find_or_create_from_one_attribute_should_set_attribute
c = Company.find_or_create_by_name_and_rating("Fortune 1000", 1000)
assert_equal "Fortune 1000", c.name
assert_equal 1000, c.rating
@@ -231,7 +215,7 @@ class DeprecatedDynamicMethodsTest < ActiveRecord::TestCase
assert c.persisted?
end
- def test_find_or_initialize_from_one_attribute_should_set_attribute_even_when_protected_and_also_set_the_hash
+ def test_find_or_initialize_from_one_attribute_should_set_attribute_even_when_set_the_hash
c = Company.find_or_initialize_by_rating(1000, {:name => "Fortune 1000"})
assert_equal "Fortune 1000", c.name
assert_equal 1000, c.rating
@@ -239,7 +223,7 @@ class DeprecatedDynamicMethodsTest < ActiveRecord::TestCase
assert !c.persisted?
end
- def test_find_or_create_from_one_attribute_should_set_attribute_even_when_protected_and_also_set_the_hash
+ def test_find_or_create_from_one_attribute_should_set_attribute_even_when_set_the_hash
c = Company.find_or_create_by_rating(1000, {:name => "Fortune 1000"})
assert_equal "Fortune 1000", c.name
assert_equal 1000, c.rating
@@ -247,7 +231,7 @@ class DeprecatedDynamicMethodsTest < ActiveRecord::TestCase
assert c.persisted?
end
- def test_find_or_initialize_should_set_protected_attributes_if_given_as_block
+ def test_find_or_initialize_should_set_attributes_if_given_as_block
c = Company.find_or_initialize_by_name(:name => "Fortune 1000") { |f| f.rating = 1000 }
assert_equal "Fortune 1000", c.name
assert_equal 1000.to_f, c.rating.to_f
@@ -255,7 +239,7 @@ class DeprecatedDynamicMethodsTest < ActiveRecord::TestCase
assert !c.persisted?
end
- def test_find_or_create_should_set_protected_attributes_if_given_as_block
+ def test_find_or_create_should_set_attributes_if_given_as_block
c = Company.find_or_create_by_name(:name => "Fortune 1000") { |f| f.rating = 1000 }
assert_equal "Fortune 1000", c.name
assert_equal 1000.to_f, c.rating.to_f
diff --git a/activerecord/test/cases/mass_assignment_security_test.rb b/activerecord/test/cases/mass_assignment_security_test.rb
deleted file mode 100644
index a36b2c2506..0000000000
--- a/activerecord/test/cases/mass_assignment_security_test.rb
+++ /dev/null
@@ -1,966 +0,0 @@
-require "cases/helper"
-require 'models/company'
-require 'models/subscriber'
-require 'models/keyboard'
-require 'models/task'
-require 'models/person'
-
-
-module MassAssignmentTestHelpers
- def setup
- # another AR test modifies the columns which causes issues with create calls
- TightPerson.reset_column_information
- LoosePerson.reset_column_information
- end
-
- def attributes_hash
- {
- :id => 5,
- :first_name => 'Josh',
- :gender => 'm',
- :comments => 'rides a sweet bike'
- }
- end
-
- def assert_default_attributes(person, create = false)
- unless create
- assert_nil person.id
- else
- assert !!person.id
- end
- assert_equal 'Josh', person.first_name
- assert_equal 'm', person.gender
- assert_nil person.comments
- end
-
- def assert_admin_attributes(person, create = false)
- unless create
- assert_nil person.id
- else
- assert !!person.id
- end
- assert_equal 'Josh', person.first_name
- assert_equal 'm', person.gender
- assert_equal 'rides a sweet bike', person.comments
- end
-
- def assert_all_attributes(person)
- assert_equal 5, person.id
- assert_equal 'Josh', person.first_name
- assert_equal 'm', person.gender
- assert_equal 'rides a sweet bike', person.comments
- end
-
- def with_strict_sanitizer
- ActiveRecord::Base.mass_assignment_sanitizer = :strict
- yield
- ensure
- ActiveRecord::Base.mass_assignment_sanitizer = :logger
- end
-end
-
-module MassAssignmentRelationTestHelpers
- def setup
- super
- @person = LoosePerson.create(attributes_hash)
- end
-end
-
-
-class MassAssignmentSecurityTest < ActiveRecord::TestCase
- include MassAssignmentTestHelpers
-
- def test_customized_primary_key_remains_protected
- subscriber = Subscriber.new(:nick => 'webster123', :name => 'nice try')
- assert_nil subscriber.id
-
- keyboard = Keyboard.new(:key_number => 9, :name => 'nice try')
- assert_nil keyboard.id
- end
-
- def test_customized_primary_key_remains_protected_when_referred_to_as_id
- subscriber = Subscriber.new(:id => 'webster123', :name => 'nice try')
- assert_nil subscriber.id
-
- keyboard = Keyboard.new(:id => 9, :name => 'nice try')
- assert_nil keyboard.id
- end
-
- def test_mass_assigning_invalid_attribute
- firm = Firm.new
-
- assert_raise(ActiveRecord::UnknownAttributeError) do
- firm.attributes = { "id" => 5, "type" => "Client", "i_dont_even_exist" => 20 }
- end
- end
-
- def test_mass_assigning_does_not_choke_on_nil
- assert_nil Firm.new.assign_attributes(nil)
- end
-
- def test_mass_assigning_does_not_choke_on_empty_hash
- assert_nil Firm.new.assign_attributes({})
- end
-
- def test_assign_attributes_uses_default_role_when_no_role_is_provided
- p = LoosePerson.new
- p.assign_attributes(attributes_hash)
-
- assert_default_attributes(p)
- end
-
- def test_assign_attributes_skips_mass_assignment_security_protection_when_without_protection_is_used
- p = LoosePerson.new
- p.assign_attributes(attributes_hash, :without_protection => true)
-
- assert_all_attributes(p)
- end
-
- def test_assign_attributes_with_default_role_and_attr_protected_attributes
- p = LoosePerson.new
- p.assign_attributes(attributes_hash, :as => :default)
-
- assert_default_attributes(p)
- end
-
- def test_assign_attributes_with_admin_role_and_attr_protected_attributes
- p = LoosePerson.new
- p.assign_attributes(attributes_hash, :as => :admin)
-
- assert_admin_attributes(p)
- end
-
- def test_assign_attributes_with_default_role_and_attr_accessible_attributes
- p = TightPerson.new
- p.assign_attributes(attributes_hash, :as => :default)
-
- assert_default_attributes(p)
- end
-
- def test_assign_attributes_with_admin_role_and_attr_accessible_attributes
- p = TightPerson.new
- p.assign_attributes(attributes_hash, :as => :admin)
-
- assert_admin_attributes(p)
- end
-
- def test_new_with_attr_accessible_attributes
- p = TightPerson.new(attributes_hash)
-
- assert_default_attributes(p)
- end
-
- def test_new_with_attr_protected_attributes
- p = LoosePerson.new(attributes_hash)
-
- assert_default_attributes(p)
- end
-
- def test_create_with_attr_accessible_attributes
- p = TightPerson.create(attributes_hash)
-
- assert_default_attributes(p, true)
- end
-
- def test_create_with_attr_protected_attributes
- p = LoosePerson.create(attributes_hash)
-
- assert_default_attributes(p, true)
- end
-
- def test_new_with_admin_role_with_attr_accessible_attributes
- p = TightPerson.new(attributes_hash, :as => :admin)
-
- assert_admin_attributes(p)
- end
-
- def test_new_with_admin_role_with_attr_protected_attributes
- p = LoosePerson.new(attributes_hash, :as => :admin)
-
- assert_admin_attributes(p)
- end
-
- def test_create_with_admin_role_with_attr_accessible_attributes
- p = TightPerson.create(attributes_hash, :as => :admin)
-
- assert_admin_attributes(p, true)
- end
-
- def test_create_with_admin_role_with_attr_protected_attributes
- p = LoosePerson.create(attributes_hash, :as => :admin)
-
- assert_admin_attributes(p, true)
- end
-
- def test_create_with_bang_with_admin_role_with_attr_accessible_attributes
- p = TightPerson.create!(attributes_hash, :as => :admin)
-
- assert_admin_attributes(p, true)
- end
-
- def test_create_with_bang_with_admin_role_with_attr_protected_attributes
- p = LoosePerson.create!(attributes_hash, :as => :admin)
-
- assert_admin_attributes(p, true)
- end
-
- def test_new_with_without_protection_with_attr_accessible_attributes
- p = TightPerson.new(attributes_hash, :without_protection => true)
-
- assert_all_attributes(p)
- end
-
- def test_new_with_without_protection_with_attr_protected_attributes
- p = LoosePerson.new(attributes_hash, :without_protection => true)
-
- assert_all_attributes(p)
- end
-
- def test_create_with_without_protection_with_attr_accessible_attributes
- p = TightPerson.create(attributes_hash, :without_protection => true)
-
- assert_all_attributes(p)
- end
-
- def test_create_with_without_protection_with_attr_protected_attributes
- p = LoosePerson.create(attributes_hash, :without_protection => true)
-
- assert_all_attributes(p)
- end
-
- def test_create_with_bang_with_without_protection_with_attr_accessible_attributes
- p = TightPerson.create!(attributes_hash, :without_protection => true)
-
- assert_all_attributes(p)
- end
-
- def test_create_with_bang_with_without_protection_with_attr_protected_attributes
- p = LoosePerson.create!(attributes_hash, :without_protection => true)
-
- assert_all_attributes(p)
- end
-
- def test_protection_against_class_attribute_writers
- [:logger, :configurations, :primary_key_prefix_type, :table_name_prefix, :table_name_suffix, :pluralize_table_names,
- :default_timezone, :schema_format, :lock_optimistically, :timestamped_migrations, :default_scopes,
- :connection_handler, :nested_attributes_options, :_attr_readonly, :attribute_types_cached_by_default,
- :attribute_method_matchers, :time_zone_aware_attributes, :skip_time_zone_conversion_for_attributes].each do |method|
- assert_respond_to Task, method
- assert_respond_to Task, "#{method}="
- assert_respond_to Task.new, method
- assert !Task.new.respond_to?("#{method}=")
- end
- end
-
- test "ActiveRecord::Model.whitelist_attributes works for models which include Model" do
- begin
- prev, ActiveRecord::Model.whitelist_attributes = ActiveRecord::Model.whitelist_attributes, true
-
- klass = Class.new { include ActiveRecord::Model }
- assert_equal ActiveModel::MassAssignmentSecurity::WhiteList, klass.active_authorizers[:default].class
- assert_equal [], klass.active_authorizers[:default].to_a
- ensure
- ActiveRecord::Model.whitelist_attributes = prev
- end
- end
-
- test "ActiveRecord::Model.whitelist_attributes works for models which inherit Base" do
- begin
- prev, ActiveRecord::Model.whitelist_attributes = ActiveRecord::Model.whitelist_attributes, true
-
- klass = Class.new(ActiveRecord::Base)
- assert_equal ActiveModel::MassAssignmentSecurity::WhiteList, klass.active_authorizers[:default].class
- assert_equal [], klass.active_authorizers[:default].to_a
-
- klass.attr_accessible 'foo'
- assert_equal ['foo'], Class.new(klass).active_authorizers[:default].to_a
- ensure
- ActiveRecord::Model.whitelist_attributes = prev
- end
- end
-
- test "ActiveRecord::Model.mass_assignment_sanitizer works for models which include Model" do
- begin
- sanitizer = Object.new
- prev, ActiveRecord::Model.mass_assignment_sanitizer = ActiveRecord::Model.mass_assignment_sanitizer, sanitizer
-
- klass = Class.new { include ActiveRecord::Model }
- assert_equal sanitizer, klass._mass_assignment_sanitizer
-
- ActiveRecord::Model.mass_assignment_sanitizer = nil
- klass = Class.new { include ActiveRecord::Model }
- assert_not_nil klass._mass_assignment_sanitizer
- ensure
- ActiveRecord::Model.mass_assignment_sanitizer = prev
- end
- end
-
- test "ActiveRecord::Model.mass_assignment_sanitizer works for models which inherit Base" do
- begin
- sanitizer = Object.new
- prev, ActiveRecord::Model.mass_assignment_sanitizer = ActiveRecord::Model.mass_assignment_sanitizer, sanitizer
-
- klass = Class.new(ActiveRecord::Base)
- assert_equal sanitizer, klass._mass_assignment_sanitizer
-
- sanitizer2 = Object.new
- klass.mass_assignment_sanitizer = sanitizer2
- assert_equal sanitizer2, Class.new(klass)._mass_assignment_sanitizer
- ensure
- ActiveRecord::Model.mass_assignment_sanitizer = prev
- end
- end
-end
-
-
-# This class should be deleted when we remove activerecord-deprecated_finders as a
-# dependency.
-class MassAssignmentSecurityDeprecatedFindersTest < ActiveRecord::TestCase
- include MassAssignmentTestHelpers
-
- def setup
- super
- @deprecation_behavior = ActiveSupport::Deprecation.behavior
- ActiveSupport::Deprecation.behavior = :silence
- end
-
- def teardown
- ActiveSupport::Deprecation.behavior = @deprecation_behavior
- end
-
- def test_find_or_initialize_by_with_attr_accessible_attributes
- p = TightPerson.find_or_initialize_by_first_name('Josh', attributes_hash)
-
- assert_default_attributes(p)
- end
-
- def test_find_or_initialize_by_with_admin_role_with_attr_accessible_attributes
- p = TightPerson.find_or_initialize_by_first_name('Josh', attributes_hash, :as => :admin)
-
- assert_admin_attributes(p)
- end
-
- def test_find_or_initialize_by_with_attr_protected_attributes
- p = LoosePerson.find_or_initialize_by_first_name('Josh', attributes_hash)
-
- assert_default_attributes(p)
- end
-
- def test_find_or_initialize_by_with_admin_role_with_attr_protected_attributes
- p = LoosePerson.find_or_initialize_by_first_name('Josh', attributes_hash, :as => :admin)
-
- assert_admin_attributes(p)
- end
-
- def test_find_or_create_by_with_attr_accessible_attributes
- p = TightPerson.find_or_create_by_first_name('Josh', attributes_hash)
-
- assert_default_attributes(p, true)
- end
-
- def test_find_or_create_by_with_admin_role_with_attr_accessible_attributes
- p = TightPerson.find_or_create_by_first_name('Josh', attributes_hash, :as => :admin)
-
- assert_admin_attributes(p, true)
- end
-
- def test_find_or_create_by_with_attr_protected_attributes
- p = LoosePerson.find_or_create_by_first_name('Josh', attributes_hash)
-
- assert_default_attributes(p, true)
- end
-
- def test_find_or_create_by_with_admin_role_with_attr_protected_attributes
- p = LoosePerson.find_or_create_by_first_name('Josh', attributes_hash, :as => :admin)
-
- assert_admin_attributes(p, true)
- end
-
-end
-
-
-class MassAssignmentSecurityHasOneRelationsTest < ActiveRecord::TestCase
- include MassAssignmentTestHelpers
- include MassAssignmentRelationTestHelpers
-
- # build
-
- def test_has_one_build_with_attr_protected_attributes
- best_friend = @person.build_best_friend(attributes_hash)
- assert_default_attributes(best_friend)
- end
-
- def test_has_one_build_with_attr_accessible_attributes
- best_friend = @person.build_best_friend(attributes_hash)
- assert_default_attributes(best_friend)
- end
-
- def test_has_one_build_with_admin_role_with_attr_protected_attributes
- best_friend = @person.build_best_friend(attributes_hash, :as => :admin)
- assert_admin_attributes(best_friend)
- end
-
- def test_has_one_build_with_admin_role_with_attr_accessible_attributes
- best_friend = @person.build_best_friend(attributes_hash, :as => :admin)
- assert_admin_attributes(best_friend)
- end
-
- def test_has_one_build_without_protection
- best_friend = @person.build_best_friend(attributes_hash, :without_protection => true)
- assert_all_attributes(best_friend)
- end
-
- def test_has_one_build_with_strict_sanitizer
- with_strict_sanitizer do
- best_friend = @person.build_best_friend(attributes_hash.except(:id, :comments))
- assert_equal @person.id, best_friend.best_friend_id
- end
- end
-
- # create
-
- def test_has_one_create_with_attr_protected_attributes
- best_friend = @person.create_best_friend(attributes_hash)
- assert_default_attributes(best_friend, true)
- end
-
- def test_has_one_create_with_attr_accessible_attributes
- best_friend = @person.create_best_friend(attributes_hash)
- assert_default_attributes(best_friend, true)
- end
-
- def test_has_one_create_with_admin_role_with_attr_protected_attributes
- best_friend = @person.create_best_friend(attributes_hash, :as => :admin)
- assert_admin_attributes(best_friend, true)
- end
-
- def test_has_one_create_with_admin_role_with_attr_accessible_attributes
- best_friend = @person.create_best_friend(attributes_hash, :as => :admin)
- assert_admin_attributes(best_friend, true)
- end
-
- def test_has_one_create_without_protection
- best_friend = @person.create_best_friend(attributes_hash, :without_protection => true)
- assert_all_attributes(best_friend)
- end
-
- def test_has_one_create_with_strict_sanitizer
- with_strict_sanitizer do
- best_friend = @person.create_best_friend(attributes_hash.except(:id, :comments))
- assert_equal @person.id, best_friend.best_friend_id
- end
- end
-
- # create!
-
- def test_has_one_create_with_bang_with_attr_protected_attributes
- best_friend = @person.create_best_friend!(attributes_hash)
- assert_default_attributes(best_friend, true)
- end
-
- def test_has_one_create_with_bang_with_attr_accessible_attributes
- best_friend = @person.create_best_friend!(attributes_hash)
- assert_default_attributes(best_friend, true)
- end
-
- def test_has_one_create_with_bang_with_admin_role_with_attr_protected_attributes
- best_friend = @person.create_best_friend!(attributes_hash, :as => :admin)
- assert_admin_attributes(best_friend, true)
- end
-
- def test_has_one_create_with_bang_with_admin_role_with_attr_accessible_attributes
- best_friend = @person.create_best_friend!(attributes_hash, :as => :admin)
- assert_admin_attributes(best_friend, true)
- end
-
- def test_has_one_create_with_bang_without_protection
- best_friend = @person.create_best_friend!(attributes_hash, :without_protection => true)
- assert_all_attributes(best_friend)
- end
-
- def test_has_one_create_with_bang_with_strict_sanitizer
- with_strict_sanitizer do
- best_friend = @person.create_best_friend!(attributes_hash.except(:id, :comments))
- assert_equal @person.id, best_friend.best_friend_id
- end
- end
-
-end
-
-
-class MassAssignmentSecurityBelongsToRelationsTest < ActiveRecord::TestCase
- include MassAssignmentTestHelpers
- include MassAssignmentRelationTestHelpers
-
- # build
-
- def test_belongs_to_build_with_attr_protected_attributes
- best_friend = @person.build_best_friend_of(attributes_hash)
- assert_default_attributes(best_friend)
- end
-
- def test_belongs_to_build_with_attr_accessible_attributes
- best_friend = @person.build_best_friend_of(attributes_hash)
- assert_default_attributes(best_friend)
- end
-
- def test_belongs_to_build_with_admin_role_with_attr_protected_attributes
- best_friend = @person.build_best_friend_of(attributes_hash, :as => :admin)
- assert_admin_attributes(best_friend)
- end
-
- def test_belongs_to_build_with_admin_role_with_attr_accessible_attributes
- best_friend = @person.build_best_friend_of(attributes_hash, :as => :admin)
- assert_admin_attributes(best_friend)
- end
-
- def test_belongs_to_build_without_protection
- best_friend = @person.build_best_friend_of(attributes_hash, :without_protection => true)
- assert_all_attributes(best_friend)
- end
-
- # create
-
- def test_belongs_to_create_with_attr_protected_attributes
- best_friend = @person.create_best_friend_of(attributes_hash)
- assert_default_attributes(best_friend, true)
- end
-
- def test_belongs_to_create_with_attr_accessible_attributes
- best_friend = @person.create_best_friend_of(attributes_hash)
- assert_default_attributes(best_friend, true)
- end
-
- def test_belongs_to_create_with_admin_role_with_attr_protected_attributes
- best_friend = @person.create_best_friend_of(attributes_hash, :as => :admin)
- assert_admin_attributes(best_friend, true)
- end
-
- def test_belongs_to_create_with_admin_role_with_attr_accessible_attributes
- best_friend = @person.create_best_friend_of(attributes_hash, :as => :admin)
- assert_admin_attributes(best_friend, true)
- end
-
- def test_belongs_to_create_without_protection
- best_friend = @person.create_best_friend_of(attributes_hash, :without_protection => true)
- assert_all_attributes(best_friend)
- end
-
- def test_belongs_to_create_with_strict_sanitizer
- with_strict_sanitizer do
- best_friend = @person.create_best_friend_of(attributes_hash.except(:id, :comments))
- assert_equal best_friend.id, @person.best_friend_of_id
- end
- end
-
- # create!
-
- def test_belongs_to_create_with_bang_with_attr_protected_attributes
- best_friend = @person.create_best_friend!(attributes_hash)
- assert_default_attributes(best_friend, true)
- end
-
- def test_belongs_to_create_with_bang_with_attr_accessible_attributes
- best_friend = @person.create_best_friend!(attributes_hash)
- assert_default_attributes(best_friend, true)
- end
-
- def test_belongs_to_create_with_bang_with_admin_role_with_attr_protected_attributes
- best_friend = @person.create_best_friend!(attributes_hash, :as => :admin)
- assert_admin_attributes(best_friend, true)
- end
-
- def test_belongs_to_create_with_bang_with_admin_role_with_attr_accessible_attributes
- best_friend = @person.create_best_friend!(attributes_hash, :as => :admin)
- assert_admin_attributes(best_friend, true)
- end
-
- def test_belongs_to_create_with_bang_without_protection
- best_friend = @person.create_best_friend!(attributes_hash, :without_protection => true)
- assert_all_attributes(best_friend)
- end
-
- def test_belongs_to_create_with_bang_with_strict_sanitizer
- with_strict_sanitizer do
- best_friend = @person.create_best_friend_of!(attributes_hash.except(:id, :comments))
- assert_equal best_friend.id, @person.best_friend_of_id
- end
- end
-
-end
-
-
-class MassAssignmentSecurityHasManyRelationsTest < ActiveRecord::TestCase
- include MassAssignmentTestHelpers
- include MassAssignmentRelationTestHelpers
-
- # build
-
- def test_has_many_build_with_attr_protected_attributes
- best_friend = @person.best_friends.build(attributes_hash)
- assert_default_attributes(best_friend)
- end
-
- def test_has_many_build_with_attr_accessible_attributes
- best_friend = @person.best_friends.build(attributes_hash)
- assert_default_attributes(best_friend)
- end
-
- def test_has_many_build_with_admin_role_with_attr_protected_attributes
- best_friend = @person.best_friends.build(attributes_hash, :as => :admin)
- assert_admin_attributes(best_friend)
- end
-
- def test_has_many_build_with_admin_role_with_attr_accessible_attributes
- best_friend = @person.best_friends.build(attributes_hash, :as => :admin)
- assert_admin_attributes(best_friend)
- end
-
- def test_has_many_build_without_protection
- best_friend = @person.best_friends.build(attributes_hash, :without_protection => true)
- assert_all_attributes(best_friend)
- end
-
- def test_has_many_build_with_strict_sanitizer
- with_strict_sanitizer do
- best_friend = @person.best_friends.build(attributes_hash.except(:id, :comments))
- assert_equal @person.id, best_friend.best_friend_id
- end
- end
-
- # create
-
- def test_has_many_create_with_attr_protected_attributes
- best_friend = @person.best_friends.create(attributes_hash)
- assert_default_attributes(best_friend, true)
- end
-
- def test_has_many_create_with_attr_accessible_attributes
- best_friend = @person.best_friends.create(attributes_hash)
- assert_default_attributes(best_friend, true)
- end
-
- def test_has_many_create_with_admin_role_with_attr_protected_attributes
- best_friend = @person.best_friends.create(attributes_hash, :as => :admin)
- assert_admin_attributes(best_friend, true)
- end
-
- def test_has_many_create_with_admin_role_with_attr_accessible_attributes
- best_friend = @person.best_friends.create(attributes_hash, :as => :admin)
- assert_admin_attributes(best_friend, true)
- end
-
- def test_has_many_create_without_protection
- best_friend = @person.best_friends.create(attributes_hash, :without_protection => true)
- assert_all_attributes(best_friend)
- end
-
- def test_has_many_create_with_strict_sanitizer
- with_strict_sanitizer do
- best_friend = @person.best_friends.create(attributes_hash.except(:id, :comments))
- assert_equal @person.id, best_friend.best_friend_id
- end
- end
-
- # create!
-
- def test_has_many_create_with_bang_with_attr_protected_attributes
- best_friend = @person.best_friends.create!(attributes_hash)
- assert_default_attributes(best_friend, true)
- end
-
- def test_has_many_create_with_bang_with_attr_accessible_attributes
- best_friend = @person.best_friends.create!(attributes_hash)
- assert_default_attributes(best_friend, true)
- end
-
- def test_has_many_create_with_bang_with_admin_role_with_attr_protected_attributes
- best_friend = @person.best_friends.create!(attributes_hash, :as => :admin)
- assert_admin_attributes(best_friend, true)
- end
-
- def test_has_many_create_with_bang_with_admin_role_with_attr_accessible_attributes
- best_friend = @person.best_friends.create!(attributes_hash, :as => :admin)
- assert_admin_attributes(best_friend, true)
- end
-
- def test_has_many_create_with_bang_without_protection
- best_friend = @person.best_friends.create!(attributes_hash, :without_protection => true)
- assert_all_attributes(best_friend)
- end
-
- def test_has_many_create_with_bang_with_strict_sanitizer
- with_strict_sanitizer do
- best_friend = @person.best_friends.create!(attributes_hash.except(:id, :comments))
- assert_equal @person.id, best_friend.best_friend_id
- end
- end
-
-end
-
-
-class MassAssignmentSecurityNestedAttributesTest < ActiveRecord::TestCase
- include MassAssignmentTestHelpers
-
- def nested_attributes_hash(association, collection = false, except = [:id])
- if collection
- { :first_name => 'David' }.merge(:"#{association}_attributes" => [attributes_hash.except(*except)])
- else
- { :first_name => 'David' }.merge(:"#{association}_attributes" => attributes_hash.except(*except))
- end
- end
-
- # build
-
- def test_has_one_new_with_attr_protected_attributes
- person = LoosePerson.new(nested_attributes_hash(:best_friend))
- assert_default_attributes(person.best_friend)
- end
-
- def test_has_one_new_with_attr_accessible_attributes
- person = TightPerson.new(nested_attributes_hash(:best_friend))
- assert_default_attributes(person.best_friend)
- end
-
- def test_has_one_new_with_admin_role_with_attr_protected_attributes
- person = LoosePerson.new(nested_attributes_hash(:best_friend), :as => :admin)
- assert_admin_attributes(person.best_friend)
- end
-
- def test_has_one_new_with_admin_role_with_attr_accessible_attributes
- person = TightPerson.new(nested_attributes_hash(:best_friend), :as => :admin)
- assert_admin_attributes(person.best_friend)
- end
-
- def test_has_one_new_without_protection
- person = LoosePerson.new(nested_attributes_hash(:best_friend, false, nil), :without_protection => true)
- assert_all_attributes(person.best_friend)
- end
-
- def test_belongs_to_new_with_attr_protected_attributes
- person = LoosePerson.new(nested_attributes_hash(:best_friend_of))
- assert_default_attributes(person.best_friend_of)
- end
-
- def test_belongs_to_new_with_attr_accessible_attributes
- person = TightPerson.new(nested_attributes_hash(:best_friend_of))
- assert_default_attributes(person.best_friend_of)
- end
-
- def test_belongs_to_new_with_admin_role_with_attr_protected_attributes
- person = LoosePerson.new(nested_attributes_hash(:best_friend_of), :as => :admin)
- assert_admin_attributes(person.best_friend_of)
- end
-
- def test_belongs_to_new_with_admin_role_with_attr_accessible_attributes
- person = TightPerson.new(nested_attributes_hash(:best_friend_of), :as => :admin)
- assert_admin_attributes(person.best_friend_of)
- end
-
- def test_belongs_to_new_without_protection
- person = LoosePerson.new(nested_attributes_hash(:best_friend_of, false, nil), :without_protection => true)
- assert_all_attributes(person.best_friend_of)
- end
-
- def test_has_many_new_with_attr_protected_attributes
- person = LoosePerson.new(nested_attributes_hash(:best_friends, true))
- assert_default_attributes(person.best_friends.first)
- end
-
- def test_has_many_new_with_attr_accessible_attributes
- person = TightPerson.new(nested_attributes_hash(:best_friends, true))
- assert_default_attributes(person.best_friends.first)
- end
-
- def test_has_many_new_with_admin_role_with_attr_protected_attributes
- person = LoosePerson.new(nested_attributes_hash(:best_friends, true), :as => :admin)
- assert_admin_attributes(person.best_friends.first)
- end
-
- def test_has_many_new_with_admin_role_with_attr_accessible_attributes
- person = TightPerson.new(nested_attributes_hash(:best_friends, true), :as => :admin)
- assert_admin_attributes(person.best_friends.first)
- end
-
- def test_has_many_new_without_protection
- person = LoosePerson.new(nested_attributes_hash(:best_friends, true, nil), :without_protection => true)
- assert_all_attributes(person.best_friends.first)
- end
-
- # create
-
- def test_has_one_create_with_attr_protected_attributes
- person = LoosePerson.create(nested_attributes_hash(:best_friend))
- assert_default_attributes(person.best_friend, true)
- end
-
- def test_has_one_create_with_attr_accessible_attributes
- person = TightPerson.create(nested_attributes_hash(:best_friend))
- assert_default_attributes(person.best_friend, true)
- end
-
- def test_has_one_create_with_admin_role_with_attr_protected_attributes
- person = LoosePerson.create(nested_attributes_hash(:best_friend), :as => :admin)
- assert_admin_attributes(person.best_friend, true)
- end
-
- def test_has_one_create_with_admin_role_with_attr_accessible_attributes
- person = TightPerson.create(nested_attributes_hash(:best_friend), :as => :admin)
- assert_admin_attributes(person.best_friend, true)
- end
-
- def test_has_one_create_without_protection
- person = LoosePerson.create(nested_attributes_hash(:best_friend, false, nil), :without_protection => true)
- assert_all_attributes(person.best_friend)
- end
-
- def test_belongs_to_create_with_attr_protected_attributes
- person = LoosePerson.create(nested_attributes_hash(:best_friend_of))
- assert_default_attributes(person.best_friend_of, true)
- end
-
- def test_belongs_to_create_with_attr_accessible_attributes
- person = TightPerson.create(nested_attributes_hash(:best_friend_of))
- assert_default_attributes(person.best_friend_of, true)
- end
-
- def test_belongs_to_create_with_admin_role_with_attr_protected_attributes
- person = LoosePerson.create(nested_attributes_hash(:best_friend_of), :as => :admin)
- assert_admin_attributes(person.best_friend_of, true)
- end
-
- def test_belongs_to_create_with_admin_role_with_attr_accessible_attributes
- person = TightPerson.create(nested_attributes_hash(:best_friend_of), :as => :admin)
- assert_admin_attributes(person.best_friend_of, true)
- end
-
- def test_belongs_to_create_without_protection
- person = LoosePerson.create(nested_attributes_hash(:best_friend_of, false, nil), :without_protection => true)
- assert_all_attributes(person.best_friend_of)
- end
-
- def test_has_many_create_with_attr_protected_attributes
- person = LoosePerson.create(nested_attributes_hash(:best_friends, true))
- assert_default_attributes(person.best_friends.first, true)
- end
-
- def test_has_many_create_with_attr_accessible_attributes
- person = TightPerson.create(nested_attributes_hash(:best_friends, true))
- assert_default_attributes(person.best_friends.first, true)
- end
-
- def test_has_many_create_with_admin_role_with_attr_protected_attributes
- person = LoosePerson.create(nested_attributes_hash(:best_friends, true), :as => :admin)
- assert_admin_attributes(person.best_friends.first, true)
- end
-
- def test_has_many_create_with_admin_role_with_attr_accessible_attributes
- person = TightPerson.create(nested_attributes_hash(:best_friends, true), :as => :admin)
- assert_admin_attributes(person.best_friends.first, true)
- end
-
- def test_has_many_create_without_protection
- person = LoosePerson.create(nested_attributes_hash(:best_friends, true, nil), :without_protection => true)
- assert_all_attributes(person.best_friends.first)
- end
-
- # create!
-
- def test_has_one_create_with_bang_with_attr_protected_attributes
- person = LoosePerson.create!(nested_attributes_hash(:best_friend))
- assert_default_attributes(person.best_friend, true)
- end
-
- def test_has_one_create_with_bang_with_attr_accessible_attributes
- person = TightPerson.create!(nested_attributes_hash(:best_friend))
- assert_default_attributes(person.best_friend, true)
- end
-
- def test_has_one_create_with_bang_with_admin_role_with_attr_protected_attributes
- person = LoosePerson.create!(nested_attributes_hash(:best_friend), :as => :admin)
- assert_admin_attributes(person.best_friend, true)
- end
-
- def test_has_one_create_with_bang_with_admin_role_with_attr_accessible_attributes
- person = TightPerson.create!(nested_attributes_hash(:best_friend), :as => :admin)
- assert_admin_attributes(person.best_friend, true)
- end
-
- def test_has_one_create_with_bang_without_protection
- person = LoosePerson.create!(nested_attributes_hash(:best_friend, false, nil), :without_protection => true)
- assert_all_attributes(person.best_friend)
- end
-
- def test_belongs_to_create_with_bang_with_attr_protected_attributes
- person = LoosePerson.create!(nested_attributes_hash(:best_friend_of))
- assert_default_attributes(person.best_friend_of, true)
- end
-
- def test_belongs_to_create_with_bang_with_attr_accessible_attributes
- person = TightPerson.create!(nested_attributes_hash(:best_friend_of))
- assert_default_attributes(person.best_friend_of, true)
- end
-
- def test_belongs_to_create_with_bang_with_admin_role_with_attr_protected_attributes
- person = LoosePerson.create!(nested_attributes_hash(:best_friend_of), :as => :admin)
- assert_admin_attributes(person.best_friend_of, true)
- end
-
- def test_belongs_to_create_with_bang_with_admin_role_with_attr_accessible_attributes
- person = TightPerson.create!(nested_attributes_hash(:best_friend_of), :as => :admin)
- assert_admin_attributes(person.best_friend_of, true)
- end
-
- def test_belongs_to_create_with_bang_without_protection
- person = LoosePerson.create!(nested_attributes_hash(:best_friend_of, false, nil), :without_protection => true)
- assert_all_attributes(person.best_friend_of)
- end
-
- def test_has_many_create_with_bang_with_attr_protected_attributes
- person = LoosePerson.create!(nested_attributes_hash(:best_friends, true))
- assert_default_attributes(person.best_friends.first, true)
- end
-
- def test_has_many_create_with_bang_with_attr_accessible_attributes
- person = TightPerson.create!(nested_attributes_hash(:best_friends, true))
- assert_default_attributes(person.best_friends.first, true)
- end
-
- def test_has_many_create_with_bang_with_admin_role_with_attr_protected_attributes
- person = LoosePerson.create!(nested_attributes_hash(:best_friends, true), :as => :admin)
- assert_admin_attributes(person.best_friends.first, true)
- end
-
- def test_has_many_create_with_bang_with_admin_role_with_attr_accessible_attributes
- person = TightPerson.create!(nested_attributes_hash(:best_friends, true), :as => :admin)
- assert_admin_attributes(person.best_friends.first, true)
- end
-
- def test_has_many_create_with_bang_without_protection
- person = LoosePerson.create!(nested_attributes_hash(:best_friends, true, nil), :without_protection => true)
- assert_all_attributes(person.best_friends.first)
- end
-
- def test_mass_assignment_options_are_reset_after_exception
- person = NestedPerson.create!({ :first_name => 'David', :gender => 'm' }, :as => :admin)
- person.create_best_friend!({ :first_name => 'Jeremy', :gender => 'm' }, :as => :admin)
-
- attributes = { :best_friend_attributes => { :comments => 'rides a sweet bike' } }
- assert_raises(RuntimeError) { person.assign_attributes(attributes, :as => :admin) }
- assert_equal 'm', person.best_friend.gender
-
- person.best_friend_attributes = { :gender => 'f' }
- assert_equal 'm', person.best_friend.gender
- end
-
- def test_mass_assignment_options_are_nested_correctly
- person = NestedPerson.create!({ :first_name => 'David', :gender => 'm' }, :as => :admin)
- person.create_best_friend!({ :first_name => 'Jeremy', :gender => 'm' }, :as => :admin)
-
- attributes = { :best_friend_first_name => 'Josh', :best_friend_attributes => { :gender => 'f' } }
- person.assign_attributes(attributes, :as => :admin)
- assert_equal 'Josh', person.best_friend.first_name
- assert_equal 'f', person.best_friend.gender
- end
-
-end
diff --git a/activerecord/test/cases/validations_test.rb b/activerecord/test/cases/validations_test.rb
index b11b330374..3f587d177b 100644
--- a/activerecord/test/cases/validations_test.rb
+++ b/activerecord/test/cases/validations_test.rb
@@ -7,12 +7,6 @@ require 'models/developer'
require 'models/parrot'
require 'models/company'
-class ProtectedPerson < ActiveRecord::Base
- self.table_name = 'people'
- attr_accessor :addon
- attr_protected :first_name
-end
-
class ValidationsTest < ActiveRecord::TestCase
fixtures :topics, :developers