diff options
author | Martin Little <mlittle@tempusfactor.com> | 2011-05-16 09:24:04 -0400 |
---|---|---|
committer | Martin Little <mlittle@tempusfactor.com> | 2011-05-16 09:24:04 -0400 |
commit | ca6e7f71da7ed23aa723adb6611bf1fbb06e2137 (patch) | |
tree | 9e194e8d0cc45fdd9c0f57d06d4fb794ba871815 | |
parent | 85da41912e35eb4c00e10315ecae5edda2c58d4b (diff) | |
download | rails-ca6e7f71da7ed23aa723adb6611bf1fbb06e2137.tar.gz rails-ca6e7f71da7ed23aa723adb6611bf1fbb06e2137.tar.bz2 rails-ca6e7f71da7ed23aa723adb6611bf1fbb06e2137.zip |
Added a basic test for the informix visitor
-rw-r--r-- | lib/arel/visitors.rb | 2 | ||||
-rw-r--r-- | test/visitors/test_informix.rb | 34 |
2 files changed, 36 insertions, 0 deletions
diff --git a/lib/arel/visitors.rb b/lib/arel/visitors.rb index f2644d7205..8276eace2b 100644 --- a/lib/arel/visitors.rb +++ b/lib/arel/visitors.rb @@ -11,6 +11,7 @@ require 'arel/visitors/where_sql' require 'arel/visitors/order_clauses' require 'arel/visitors/dot' require 'arel/visitors/ibm_db' +require 'arel/visitors/informix' module Arel module Visitors @@ -24,6 +25,7 @@ module Arel 'sqlite' => Arel::Visitors::SQLite, 'sqlite3' => Arel::Visitors::SQLite, 'ibm_db' => Arel::Visitors::IBM_DB, + 'informix' => Arel::Visitors::Informix, } ENGINE_VISITORS = Hash.new do |hash, engine| diff --git a/test/visitors/test_informix.rb b/test/visitors/test_informix.rb new file mode 100644 index 0000000000..db5e52b8a4 --- /dev/null +++ b/test/visitors/test_informix.rb @@ -0,0 +1,34 @@ +require 'helper' + +module Arel + module Visitors + describe 'the informix visitor' do + before do + @visitor = Informix.new Table.engine + end + + it 'uses LIMIT n to limit results' do + stmt = Nodes::SelectStatement.new + stmt.limit = Nodes::Limit.new(1) + sql = @visitor.accept(stmt) + sql.must_be_like "SELECT LIMIT 1" + end + + it 'uses LIMIT n in updates with a limit' do + stmt = Nodes::UpdateStatement.new + stmt.limit = Nodes::Limit.new(1) + stmt.key = 'id' + sql = @visitor.accept(stmt) + sql.must_be_like "UPDATE NULL WHERE 'id' IN (SELECT LIMIT 1 'id')" + end + + it 'uses SKIP n to jump results' do + stmt = Nodes::SelectStatement.new + stmt.offset = Nodes::Offset.new(10) + sql = @visitor.accept(stmt) + sql.must_be_like "SELECT SKIP 10" + end + + end + end +end |