1# Licensed to the Apache Software Foundation (ASF) under one
2# or more contributor license agreements.  See the NOTICE file
3# distributed with this work for additional information
4# regarding copyright ownership.  The ASF licenses this file
5# to you under the Apache License, Version 2.0 (the
6# "License"); you may not use this file except in compliance
7# with the License.  You may obtain a copy of the License at
8#
9#   http://www.apache.org/licenses/LICENSE-2.0
10#
11# Unless required by applicable law or agreed to in writing,
12# software distributed under the License is distributed on an
13# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14# KIND, either express or implied.  See the License for the
15# specific language governing permissions and limitations
16# under the License.
17
18class TestGandivaBooleanNode < Test::Unit::TestCase
19  def setup
20    omit("Gandiva is required") unless defined?(::Gandiva)
21    field1 = Arrow::Field.new("field1", Arrow::Int32DataType.new)
22    field2 = Arrow::Field.new("field2", Arrow::Int32DataType.new)
23    @field1_node = Gandiva::FieldNode.new(field1)
24    @field2_node = Gandiva::FieldNode.new(field2)
25  end
26
27  def test_and
28    and_node = Gandiva::AndNode.new([@field1_node, @field2_node])
29    assert_equal([@field1_node, @field2_node],
30                 and_node.children)
31  end
32
33  def test_or
34    or_node = Gandiva::OrNode.new([@field1_node, @field2_node])
35    assert_equal([@field1_node, @field2_node],
36                 or_node.children)
37  end
38end
39