# frozen_string_literal: true
require_relative "../helper"
module Arel
module Nodes
class NodesTest < Arel::Spec
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
assert_not_same dolly.case, node.case
assert_equal dolly.conditions, node.conditions
assert_not_same dolly.conditions, node.conditions
assert_equal dolly.default, node.default
assert_not_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
describe "#as" do
it "allows aliasing" do
node = Case.new "foo"
as = node.as("bar")
assert_equal node, as.left
assert_kind_of Arel::Nodes::SqlLiteral, as.right
end
end
end
end
end
end