aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/finder_test.rb
diff options
context:
space:
mode:
authorJeremy Kemper <jeremy@bitsweat.net>2006-07-08 00:38:06 +0000
committerJeremy Kemper <jeremy@bitsweat.net>2006-07-08 00:38:06 +0000
commit7767e33b4320231b8cdff48c36f180381370e585 (patch)
tree052a8349dd9f64f9f21fbaf42e64211372cc530f /activerecord/test/finder_test.rb
parent91317ad61febda0476aa72c3fb1e4763c777227b (diff)
downloadrails-7767e33b4320231b8cdff48c36f180381370e585.tar.gz
rails-7767e33b4320231b8cdff48c36f180381370e585.tar.bz2
rails-7767e33b4320231b8cdff48c36f180381370e585.zip
Don't modify options parameters in-place. Closes #3819.
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@4584 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'activerecord/test/finder_test.rb')
-rw-r--r--activerecord/test/finder_test.rb15
1 files changed, 14 insertions, 1 deletions
diff --git a/activerecord/test/finder_test.rb b/activerecord/test/finder_test.rb
index 23b6508f99..229de2aa18 100644
--- a/activerecord/test/finder_test.rb
+++ b/activerecord/test/finder_test.rb
@@ -5,9 +5,10 @@ require 'fixtures/reply'
require 'fixtures/entrant'
require 'fixtures/developer'
require 'fixtures/post'
+require 'fixtures/author'
class FinderTest < Test::Unit::TestCase
- fixtures :companies, :topics, :entrants, :developers, :developers_projects, :posts, :accounts
+ fixtures :authors, :companies, :topics, :entrants, :developers, :developers_projects, :posts, :accounts
def test_find
assert_equal(topics(:first).title, Topic.find(1).title)
@@ -449,6 +450,18 @@ class FinderTest < Test::Unit::TestCase
assert_equal ["37signals","Summit","Microsoft", "Flamboyant Software", "Ex Nihilo", "RailsCore", "Leetsoft", "Jadedpixel"], Company.connection.select_values("SELECT name FROM companies ORDER BY id")
end
+ def test_find_doesnt_mangle_parameters
+ author = Author.find(1)
+
+ args = [:all, {:conditions => "body like '%t%'"}]
+
+ author.posts.each do |p|
+ assert_equal Post.find(p.id).comments.length,
+ p.comments.find(*args).length,
+ "Post ##{p.id} doesn't find correct number of comments"
+ end
+ end
+
protected
def bind(statement, *vars)
if vars.first.is_a?(Hash)