aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/finder_test.rb
diff options
context:
space:
mode:
authorTobias Lütke <tobias.luetke@gmail.com>2007-10-10 19:11:50 +0000
committerTobias Lütke <tobias.luetke@gmail.com>2007-10-10 19:11:50 +0000
commit0ad5365bf4f71adb32ea543f74615e86edce7b28 (patch)
tree2147838c9b7c460a5a3de7553812f34e51d6533e /activerecord/test/finder_test.rb
parent6637f9069c8bd819edc175cca13b667861aa3a0b (diff)
downloadrails-0ad5365bf4f71adb32ea543f74615e86edce7b28.tar.gz
rails-0ad5365bf4f71adb32ea543f74615e86edce7b28.tar.bz2
rails-0ad5365bf4f71adb32ea543f74615e86edce7b28.zip
find_and_(initialize|create)_by methods can now properly initialize protected attributes
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@7826 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'activerecord/test/finder_test.rb')
-rw-r--r--activerecord/test/finder_test.rb16
1 files changed, 16 insertions, 0 deletions
diff --git a/activerecord/test/finder_test.rb b/activerecord/test/finder_test.rb
index 53fa24194e..b45aabb1fb 100644
--- a/activerecord/test/finder_test.rb
+++ b/activerecord/test/finder_test.rb
@@ -469,6 +469,22 @@ class FinderTest < Test::Unit::TestCase
assert_equal "38signals", sig38.name
assert sig38.new_record?
end
+
+ def test_find_or_initialize_from_one_attribute_should_set_attribute_even_when_protected
+ c = Company.find_or_initialize_by_name_and_rating("Fortune 1000", 1000)
+ assert_equal "Fortune 1000", c.name
+ assert_equal 1000, c.rating
+ assert c.valid?
+ assert c.new_record?
+ end
+
+ def test_find_or_create_from_one_attribute_should_set_attribute_even_when_protected
+ c = Company.find_or_create_by_name_and_rating("Fortune 1000", 1000)
+ assert_equal "Fortune 1000", c.name
+ assert_equal 1000, c.rating
+ assert c.valid?
+ assert !c.new_record?
+ end
def test_dynamic_find_or_initialize_from_one_attribute_caches_method
class << Company; self; end.send(:remove_method, :find_or_initialize_by_name) if Company.respond_to?(:find_or_initialize_by_name)