aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--doc/TODO1
-rw-r--r--lib/arel/relations/join.rb14
-rw-r--r--lib/arel/relations/relation.rb4
-rw-r--r--spec/arel/unit/relations/join_spec.rb33
4 files changed, 31 insertions, 21 deletions
diff --git a/doc/TODO b/doc/TODO
index acd6ea7a1e..f959964652 100644
--- a/doc/TODO
+++ b/doc/TODO
@@ -8,7 +8,6 @@ todo:
- limit clauses with left outer joins ?
- see add_limited_ids_condition
- select_limited_ids_list
-- count queries
- extract adapters
- arbitrary sql relationships
- consider this code from has_many:
diff --git a/lib/arel/relations/join.rb b/lib/arel/relations/join.rb
index d5ec9d43bd..e5ca49c284 100644
--- a/lib/arel/relations/join.rb
+++ b/lib/arel/relations/join.rb
@@ -24,17 +24,9 @@ module Arel
end
def prefix_for(attribute)
- if relation1[attribute] && !relation2[attribute]
- externalize(relation1).prefix_for(attribute)
- elsif relation2[attribute] && !relation1[attribute]
- externalize(relation2).prefix_for(attribute)
- else
- if (attribute % relation1[attribute]).size < (attribute % relation2[attribute]).size
- externalize(relation1).prefix_for(attribute)
- else
- externalize(relation2).prefix_for(attribute)
- end
- end
+ externalize([relation1[attribute], relation2[attribute]].select { |a| a =~ attribute }.min do |a1, a2|
+ (attribute % a1).size <=> (attribute % a2).size
+ end.relation).prefix_for(attribute)
end
# TESTME: Not sure which scenario needs this method, was driven by failing tests in ActiveRecord
diff --git a/lib/arel/relations/relation.rb b/lib/arel/relations/relation.rb
index c8602d22e3..3bd40e8f6b 100644
--- a/lib/arel/relations/relation.rb
+++ b/lib/arel/relations/relation.rb
@@ -139,7 +139,9 @@ module Arel
end
def attribute_for_attribute(attribute)
- attributes.detect { |a| a =~ attribute }
+ attributes.select { |a| a =~ attribute }.min do |a1, a2|
+ (attribute % a1).size <=> (attribute % a2).size
+ end
end
end
include AttributeAccessors
diff --git a/spec/arel/unit/relations/join_spec.rb b/spec/arel/unit/relations/join_spec.rb
index f9d0d9561e..12b7d7a593 100644
--- a/spec/arel/unit/relations/join_spec.rb
+++ b/spec/arel/unit/relations/join_spec.rb
@@ -145,14 +145,31 @@ module Arel
end
describe 'when joining aliased relations' do
- it 'aliases the table and attributes properly' do
- aliased_relation = @relation1.as(:alias)
- @relation1.join(aliased_relation).on(@relation1[:id].eq(aliased_relation[:id])).to_sql.should be_like("
- SELECT `users`.`id`, `users`.`name`, `alias`.`id`, `alias`.`name`
- FROM `users`
- INNER JOIN `users` AS `alias`
- ON `users`.`id` = `alias`.`id`
- ")
+ before do
+ @aliased_relation = @relation1.as(:alias)
+ end
+
+ describe '#to_sql' do
+ it 'aliases the table and attributes properly' do
+ @relation1.join(@aliased_relation).on(@relation1[:id].eq(@aliased_relation[:id])).to_sql.should be_like("
+ SELECT `users`.`id`, `users`.`name`, `alias`.`id`, `alias`.`name`
+ FROM `users`
+ INNER JOIN `users` AS `alias`
+ ON `users`.`id` = `alias`.`id`
+ ")
+ end
+ end
+
+ describe 'when joining the same relation to itself' do
+ describe '[]' do
+ describe 'when given an attribute belonging to both sub-relations' do
+ it '' do
+ relation = @relation1.join(@aliased_relation).on(@relation1[:id].eq(@aliased_relation[:id]))
+ relation[@relation1[:id]].ancestor.should == @relation1[:id]
+ relation[@aliased_relation[:id]].ancestor.should == @aliased_relation[:id]
+ end
+ end
+ end
end
end