aboutsummaryrefslogtreecommitdiffstats
path: root/spec
diff options
context:
space:
mode:
authorBryan Helmkamp <bryan@brynary.com>2009-05-17 16:02:10 -0400
committerBryan Helmkamp <bryan@brynary.com>2009-05-17 16:12:06 -0400
commit7a51983efc50c8f9092785b1b586f8884dedc01a (patch)
tree5b915ee48c7aa454207312ba20bb13c4dadfdf70 /spec
parent07833d39c2885a5cddf38eeb860d79353c0f447b (diff)
downloadrails-7a51983efc50c8f9092785b1b586f8884dedc01a.tar.gz
rails-7a51983efc50c8f9092785b1b586f8884dedc01a.tar.bz2
rails-7a51983efc50c8f9092785b1b586f8884dedc01a.zip
initial implementation of cross-engine join
Conflicts: lib/arel/engines/memory/relations/array.rb lib/arel/engines/sql/primitives.rb
Diffstat (limited to 'spec')
-rw-r--r--spec/arel/engines/memory/integration/joins/cross_engine_spec.rb31
1 files changed, 31 insertions, 0 deletions
diff --git a/spec/arel/engines/memory/integration/joins/cross_engine_spec.rb b/spec/arel/engines/memory/integration/joins/cross_engine_spec.rb
new file mode 100644
index 0000000000..dd923ee6eb
--- /dev/null
+++ b/spec/arel/engines/memory/integration/joins/cross_engine_spec.rb
@@ -0,0 +1,31 @@
+require File.join(File.dirname(__FILE__), '..', '..', '..', '..', '..', 'spec_helper')
+
+module Arel
+ describe Join do
+ before do
+ @users = Array.new([
+ [1, 'bryan' ],
+ [2, 'emilio' ],
+ [3, 'nick']
+ ], [:id, :name])
+ @photos = Table.new(:photos)
+ @photos.delete
+ @photos \
+ .insert(@photos[:id] => 1, @photos[:user_id] => 1, @photos[:camera_id] => 6) \
+ .insert(@photos[:id] => 2, @photos[:user_id] => 2, @photos[:camera_id] => 42)
+ end
+
+ it 'joins across engines' do
+ @users \
+ .join(@photos) \
+ .on(@users[:id].eq(@photos[:user_id])) \
+ .project(@users[:name], @photos[:camera_id]) \
+ .let do |relation|
+ relation.call.should == [
+ Row.new(relation, ['bryan', '6']),
+ Row.new(relation, ['emilio', '42'])
+ ]
+ end
+ end
+ end
+end \ No newline at end of file