aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/cases/finder_test.rb
diff options
context:
space:
mode:
authorKen Miller <ken.miller@doubledyno.com>2008-10-15 17:34:57 -0700
committerMichael Koziarski <michael@koziarski.com>2008-10-24 21:35:05 +0200
commit8a77c4abfa760e5829b566698400f2115409b7ff (patch)
tree1d915f15d3184898af7612aa404a03175aacd1b2 /activerecord/test/cases/finder_test.rb
parenta17fc20eb122d45a017e99e592e5e159025ab26b (diff)
downloadrails-8a77c4abfa760e5829b566698400f2115409b7ff.tar.gz
rails-8a77c4abfa760e5829b566698400f2115409b7ff.tar.bz2
rails-8a77c4abfa760e5829b566698400f2115409b7ff.zip
Fixed issue where block is not called on the very first invocation of a find_or_create_by_ automatic finder.
[#1224 state:committed]
Diffstat (limited to 'activerecord/test/cases/finder_test.rb')
-rw-r--r--activerecord/test/cases/finder_test.rb11
1 files changed, 11 insertions, 0 deletions
diff --git a/activerecord/test/cases/finder_test.rb b/activerecord/test/cases/finder_test.rb
index 853474916c..153880afbd 100644
--- a/activerecord/test/cases/finder_test.rb
+++ b/activerecord/test/cases/finder_test.rb
@@ -846,6 +846,17 @@ class FinderTest < ActiveRecord::TestCase
assert !c.new_record?
end
+ def test_find_or_create_should_work_with_block_on_first_call
+ class << Company
+ undef_method(:find_or_create_by_name) if method_defined?(:find_or_create_by_name)
+ end
+ 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
+ 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.public_methods.any? { |m| m.to_s == 'find_or_initialize_by_name' }
assert !Company.public_methods.any? { |m| m.to_s == 'find_or_initialize_by_name' }