mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
fixing sql_literal tests
This commit is contained in:
parent
59b1d98a5f
commit
307f893123
1 changed files with 9 additions and 5 deletions
|
@ -8,6 +8,10 @@ module Arel
|
||||||
@visitor = Visitors::ToSql.new Table.engine.connection
|
@visitor = Visitors::ToSql.new Table.engine.connection
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def compile node
|
||||||
|
@visitor.accept(node, Collectors::SQLString.new).value
|
||||||
|
end
|
||||||
|
|
||||||
describe 'sql' do
|
describe 'sql' do
|
||||||
it 'makes a sql literal node' do
|
it 'makes a sql literal node' do
|
||||||
sql = Arel.sql 'foo'
|
sql = Arel.sql 'foo'
|
||||||
|
@ -18,19 +22,19 @@ module Arel
|
||||||
describe 'count' do
|
describe 'count' do
|
||||||
it 'makes a count node' do
|
it 'makes a count node' do
|
||||||
node = SqlLiteral.new('*').count
|
node = SqlLiteral.new('*').count
|
||||||
@visitor.accept(node).must_be_like %{ COUNT(*) }
|
compile(node).must_be_like %{ COUNT(*) }
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'makes a distinct node' do
|
it 'makes a distinct node' do
|
||||||
node = SqlLiteral.new('*').count true
|
node = SqlLiteral.new('*').count true
|
||||||
@visitor.accept(node).must_be_like %{ COUNT(DISTINCT *) }
|
compile(node).must_be_like %{ COUNT(DISTINCT *) }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'equality' do
|
describe 'equality' do
|
||||||
it 'makes an equality node' do
|
it 'makes an equality node' do
|
||||||
node = SqlLiteral.new('foo').eq(1)
|
node = SqlLiteral.new('foo').eq(1)
|
||||||
@visitor.accept(node).must_be_like %{ foo = 1 }
|
compile(node).must_be_like %{ foo = 1 }
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'is equal with equal contents' do
|
it 'is equal with equal contents' do
|
||||||
|
@ -47,14 +51,14 @@ module Arel
|
||||||
describe 'grouped "or" equality' do
|
describe 'grouped "or" equality' do
|
||||||
it 'makes a grouping node with an or node' do
|
it 'makes a grouping node with an or node' do
|
||||||
node = SqlLiteral.new('foo').eq_any([1,2])
|
node = SqlLiteral.new('foo').eq_any([1,2])
|
||||||
@visitor.accept(node).must_be_like %{ (foo = 1 OR foo = 2) }
|
compile(node).must_be_like %{ (foo = 1 OR foo = 2) }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'grouped "and" equality' do
|
describe 'grouped "and" equality' do
|
||||||
it 'makes a grouping node with an or node' do
|
it 'makes a grouping node with an or node' do
|
||||||
node = SqlLiteral.new('foo').eq_all([1,2])
|
node = SqlLiteral.new('foo').eq_all([1,2])
|
||||||
@visitor.accept(node).must_be_like %{ (foo = 1 AND foo = 2) }
|
compile(node).must_be_like %{ (foo = 1 AND foo = 2) }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue