mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
Ensure whitespaces are stripped when merging string joins. [#1297 state:resolved]
Signed-off-by: Pratik Naik <pratiknaik@gmail.com>
This commit is contained in:
parent
f725b19710
commit
a0d8202bb9
2 changed files with 11 additions and 1 deletions
|
@ -1715,7 +1715,7 @@ module ActiveRecord #:nodoc:
|
||||||
end
|
end
|
||||||
join
|
join
|
||||||
end
|
end
|
||||||
joins.flatten.uniq
|
joins.flatten.map{|j| j.strip}.uniq
|
||||||
else
|
else
|
||||||
joins.collect{|j| safe_to_array(j)}.flatten.uniq
|
joins.collect{|j| safe_to_array(j)}.flatten.uniq
|
||||||
end
|
end
|
||||||
|
|
|
@ -186,6 +186,16 @@ class MethodScopingTest < ActiveRecord::TestCase
|
||||||
assert_equal authors(:david).attributes, scoped_authors.first.attributes
|
assert_equal authors(:david).attributes, scoped_authors.first.attributes
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_scoped_find_strips_spaces_from_string_joins_and_eliminates_duplicate_string_joins
|
||||||
|
scoped_authors = Author.with_scope(:find => { :joins => ' INNER JOIN posts ON posts.author_id = authors.id '}) do
|
||||||
|
Author.find(:all, :select => 'DISTINCT authors.*', :joins => ['INNER JOIN posts ON posts.author_id = authors.id'], :conditions => 'posts.id = 1')
|
||||||
|
end
|
||||||
|
assert scoped_authors.include?(authors(:david))
|
||||||
|
assert !scoped_authors.include?(authors(:mary))
|
||||||
|
assert_equal 1, scoped_authors.size
|
||||||
|
assert_equal authors(:david).attributes, scoped_authors.first.attributes
|
||||||
|
end
|
||||||
|
|
||||||
def test_scoped_count_include
|
def test_scoped_count_include
|
||||||
# with the include, will retrieve only developers for the given project
|
# with the include, will retrieve only developers for the given project
|
||||||
Developer.with_scope(:find => { :include => :projects }) do
|
Developer.with_scope(:find => { :include => :projects }) do
|
||||||
|
|
Loading…
Reference in a new issue