aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/cases
diff options
context:
space:
mode:
authorJosh Susser <josh@hasmanythrough.com>2008-08-25 21:28:53 -0700
committerJeremy Kemper <jeremy@bitsweat.net>2008-08-25 23:33:16 -0700
commit1092c181b5568d06e84f6a3253aaca81c02a2b2c (patch)
tree3fb246c856bbefddf8fc1e635eb765c540619c41 /activerecord/test/cases
parent143f5fbb21b6dfcaab63d67b44afd922dab9dcf5 (diff)
downloadrails-1092c181b5568d06e84f6a3253aaca81c02a2b2c.tar.gz
rails-1092c181b5568d06e84f6a3253aaca81c02a2b2c.tar.bz2
rails-1092c181b5568d06e84f6a3253aaca81c02a2b2c.zip
add dynamic finder bang version to raise RecordNotFound
[#905 state:resolved] Signed-off-by: Jeremy Kemper <jeremy@bitsweat.net>
Diffstat (limited to 'activerecord/test/cases')
-rw-r--r--activerecord/test/cases/finder_test.rb14
1 files changed, 14 insertions, 0 deletions
diff --git a/activerecord/test/cases/finder_test.rb b/activerecord/test/cases/finder_test.rb
index 875d56f6c1..2ce49ed76f 100644
--- a/activerecord/test/cases/finder_test.rb
+++ b/activerecord/test/cases/finder_test.rb
@@ -25,6 +25,15 @@ class DynamicFinderMatchTest < ActiveRecord::TestCase
assert_equal %w(age sex location), match.attribute_names
end
+ def find_by_bang
+ match = ActiveRecord::DynamicFinderMatch.match("find_by_age_and_sex_and_location!")
+ assert_not_nil match
+ assert match.finder?
+ assert match.bang?
+ assert_equal :find_initial, match.finder
+ assert_equal %w(age sex location), match.attribute_names
+ end
+
def test_find_all_by
match = ActiveRecord::DynamicFinderMatch.match("find_all_by_age_and_sex_and_location")
assert_not_nil match
@@ -482,6 +491,11 @@ class FinderTest < ActiveRecord::TestCase
assert_nil Topic.find_by_title("The First Topic!")
end
+ def test_find_by_one_attribute_bang
+ assert_equal topics(:first), Topic.find_by_title!("The First Topic")
+ assert_raises(ActiveRecord::RecordNotFound) { Topic.find_by_title!("The First Topic!") }
+ end
+
def test_find_by_one_attribute_caches_dynamic_finder
# ensure this test can run independently of order
class << Topic; self; end.send(:remove_method, :find_by_title) if Topic.public_methods.any? { |m| m.to_s == 'find_by_title' }