blob: 21ff670e05b7006d7601ab1314be6855da9f7dd7 (
plain) (
tree)
|
|
# frozen_string_literal: true
require 'helper'
module Arel
module Nodes
describe 'Case' do
describe '#initialize' do
it 'sets case expression from first argument' do
node = Case.new 'foo'
assert_equal 'foo', node.case
end
it 'sets default case from second argument' do
node = Case.new nil, 'bar'
assert_equal 'bar', node.default
end
end
describe '#clone' do
it 'clones case, conditions and default' do
foo = Nodes.build_quoted 'foo'
node = Case.new
node.case = foo
node.conditions = [When.new(foo, foo)]
node.default = foo
dolly = node.clone
assert_equal dolly.case, node.case
refute_same dolly.case, node.case
assert_equal dolly.conditions, node.conditions
refute_same dolly.conditions, node.conditions
assert_equal dolly.default, node.default
refute_same dolly.default, node.default
end
end
describe 'equality' do
it 'is equal with equal ivars' do
foo = Nodes.build_quoted 'foo'
one = Nodes.build_quoted 1
zero = Nodes.build_quoted 0
case1 = Case.new foo
case1.conditions = [When.new(foo, one)]
case1.default = Else.new zero
case2 = Case.new foo
case2.conditions = [When.new(foo, one)]
case2.default = Else.new zero
array = [case1, case2]
assert_equal 1, array.uniq.size
end
it 'is not equal with different ivars' do
foo = Nodes.build_quoted 'foo'
bar = Nodes.build_quoted 'bar'
one = Nodes.build_quoted 1
zero = Nodes.build_quoted 0
case1 = Case.new foo
case1.conditions = [When.new(foo, one)]
case1.default = Else.new zero
case2 = Case.new foo
case2.conditions = [When.new(bar, one)]
case2.default = Else.new zero
array = [case1, case2]
assert_equal 2, array.uniq.size
end
end
end
end
end
|