diff options
| author | Anthony Crumley <anthony.crumley@gmail.com> | 2009-05-04 09:49:43 -0500 | 
|---|---|---|
| committer | Michael Koziarski <michael@koziarski.com> | 2009-05-10 13:36:51 +1200 | 
| commit | 026b78f9076216990bddb1aa5d83d23a647c02a5 (patch) | |
| tree | 70cdf5bc99af0613d64effc892b0969d461aba43 | |
| parent | 9e0cfdb7f951c0446cdfd3b2cc26443712fe657a (diff) | |
| download | rails-026b78f9076216990bddb1aa5d83d23a647c02a5.tar.gz rails-026b78f9076216990bddb1aa5d83d23a647c02a5.tar.bz2 rails-026b78f9076216990bddb1aa5d83d23a647c02a5.zip | |
Fixed eager load error on find with include => [:table_name] and hash conditions like {:table_name => {:column => 'value'}}
Signed-off-by: Michael Koziarski <michael@koziarski.com>
| -rwxr-xr-x | activerecord/lib/active_record/associations.rb | 20 | ||||
| -rw-r--r-- | activerecord/test/cases/associations/eager_test.rb | 12 | 
2 files changed, 28 insertions, 4 deletions
| diff --git a/activerecord/lib/active_record/associations.rb b/activerecord/lib/active_record/associations.rb index 2928b0bf83..781a0290e8 100755 --- a/activerecord/lib/active_record/associations.rb +++ b/activerecord/lib/active_record/associations.rb @@ -1671,17 +1671,29 @@ module ActiveRecord            string.scan(/([\.a-zA-Z_]+).?\./).flatten          end +        def tables_in_hash(hash) +          return [] if hash.blank? +          tables = hash.map do |key, value| +            if value.is_a?(Hash) +              key.to_s +            else +              tables_in_string(key) if key.is_a?(String) +            end +          end +          tables.flatten.compact +        end +          def conditions_tables(options)            # look in both sets of conditions            conditions = [scope(:find, :conditions), options[:conditions]].inject([]) do |all, cond|              case cond                when nil   then all -              when Array then all << cond.first -              when Hash  then all << cond.keys -              else            all << cond +              when Array then all << tables_in_string(cond.first) +              when Hash  then all << tables_in_hash(cond) +              else            all << tables_in_string(cond)              end            end -          tables_in_string(conditions.join(' ')) +          conditions.flatten          end          def order_tables(options) diff --git a/activerecord/test/cases/associations/eager_test.rb b/activerecord/test/cases/associations/eager_test.rb index 40723814c5..d23f86b700 100644 --- a/activerecord/test/cases/associations/eager_test.rb +++ b/activerecord/test/cases/associations/eager_test.rb @@ -223,6 +223,18 @@ class EagerAssociationTest < ActiveRecord::TestCase      end    end +  def test_eager_association_loading_with_belongs_to_and_conditions_hash +    comments = [] +    assert_nothing_raised do +      comments = Comment.find(:all, :include => :post, :conditions => {:posts => {:id => 4}}, :limit => 3, :order => 'comments.id') +    end +    assert_equal 3, comments.length +    assert_equal [5,6,7], comments.collect { |c| c.id } +    assert_no_queries do +      comments.first.post +    end +  end +    def test_eager_association_loading_with_belongs_to_and_conditions_string_with_quoted_table_name      quoted_posts_id= Comment.connection.quote_table_name('posts') + '.' + Comment.connection.quote_column_name('id')      assert_nothing_raised do | 
