diff options
author | Pratik Naik <pratiknaik@gmail.com> | 2008-05-15 13:41:54 +0100 |
---|---|---|
committer | Pratik Naik <pratiknaik@gmail.com> | 2008-05-15 13:47:05 +0100 |
commit | 802034ff5f1c3e3b576b664d5660e76c8f44909d (patch) | |
tree | 9bb32bab53553ec3f06b2b80e71d60b522abc6e5 /activerecord | |
parent | b28b54cab090bed8f099ef375b419a8f92390dd4 (diff) | |
download | rails-802034ff5f1c3e3b576b664d5660e76c8f44909d.tar.gz rails-802034ff5f1c3e3b576b664d5660e76c8f44909d.tar.bz2 rails-802034ff5f1c3e3b576b664d5660e76c8f44909d.zip |
DRY associations code and improve eager loading tests.
Diffstat (limited to 'activerecord')
-rw-r--r-- | activerecord/lib/active_record/associations.rb | 25 | ||||
-rw-r--r-- | activerecord/test/cases/finder_test.rb | 5 |
2 files changed, 9 insertions, 21 deletions
diff --git a/activerecord/lib/active_record/associations.rb b/activerecord/lib/active_record/associations.rb index 7862f8ad9d..c17e35f5e0 100644 --- a/activerecord/lib/active_record/associations.rb +++ b/activerecord/lib/active_record/associations.rb @@ -1451,9 +1451,6 @@ module ActiveRecord join_dependency.joins_for_table_name(table) }.flatten.compact.uniq - - - is_distinct = !options[:joins].blank? || include_eager_conditions?(options, tables_from_conditions) || include_eager_order?(options, tables_from_order) sql = "SELECT " if is_distinct @@ -1507,29 +1504,17 @@ module ActiveRecord end # Checks if the conditions reference a table other than the current model table - def include_eager_conditions?(options,tables = nil) - tables = conditions_tables(options) - return false unless tables.any? - tables.any? do |condition_table_name| - condition_table_name != table_name - end + def include_eager_conditions?(options, tables = nil) + ((tables || conditions_tables(options)) - [table_name]).any? end # Checks if the query order references a table other than the current model's table. - def include_eager_order?(options,tables = nil) - tables = order_tables(options) - return false unless tables.any? - tables.any? do |order_table_name| - order_table_name != table_name - end + def include_eager_order?(options, tables = nil) + ((tables || order_tables(options)) - [table_name]).any? end def include_eager_select?(options) - selects = selects_tables(options) - return false unless selects.any? - selects.any? do |select| - select != table_name - end + (selects_tables(options) - [table_name]).any? end def references_eager_loaded_tables?(options) diff --git a/activerecord/test/cases/finder_test.rb b/activerecord/test/cases/finder_test.rb index d3e2f33f99..5c0f0e2ef1 100644 --- a/activerecord/test/cases/finder_test.rb +++ b/activerecord/test/cases/finder_test.rb @@ -9,6 +9,7 @@ require 'models/developer' require 'models/post' require 'models/customer' require 'models/job' +require 'models/categorization' class FinderTest < ActiveRecord::TestCase fixtures :companies, :topics, :entrants, :developers, :developers_projects, :posts, :comments, :accounts, :authors, :customers @@ -866,7 +867,9 @@ class FinderTest < ActiveRecord::TestCase end def test_with_limiting_with_custom_select - assert_equal 3, Post.find(:all, :include => :author, :select => ' posts.*, authors.id as "author_id"', :limit => 3).size + posts = Post.find(:all, :include => :author, :select => ' posts.*, authors.id as "author_id"', :limit => 3) + assert_equal 3, posts.size + assert_equal [0, 1, 1], posts.map(&:author_id).sort end protected |