2 * Copyright (c) 2020 Samsung Electronics Co., Ltd. All Rights Reserved
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
17 #include "luci/IR/Nodes/CircleSum.h"
19 #include "luci/IR/CircleDialect.h"
20 #include "luci/IR/CircleNodeVisitor.h"
22 #include <gtest/gtest.h>
24 TEST(CircleSumTest, constructor_P)
26 luci::CircleSum sum_node;
28 ASSERT_EQ(luci::CircleDialect::get(), sum_node.dialect());
29 ASSERT_EQ(luci::CircleOpcode::SUM, sum_node.opcode());
31 ASSERT_EQ(nullptr, sum_node.input());
32 ASSERT_EQ(nullptr, sum_node.reduction_indices());
33 ASSERT_EQ(false, sum_node.keep_dims());
36 TEST(CircleSumTest, input_NEG)
38 luci::CircleSum sum_node;
41 sum_node.input(&node);
42 sum_node.reduction_indices(&node);
43 ASSERT_NE(nullptr, sum_node.input());
44 ASSERT_NE(nullptr, sum_node.reduction_indices());
46 sum_node.input(nullptr);
47 sum_node.reduction_indices(nullptr);
48 ASSERT_EQ(nullptr, sum_node.input());
49 ASSERT_EQ(nullptr, sum_node.reduction_indices());
51 sum_node.keep_dims(true);
52 ASSERT_TRUE(sum_node.keep_dims());
55 TEST(CircleSumTest, arity_NEG)
57 luci::CircleSum sum_node;
59 ASSERT_NO_THROW(sum_node.arg(1));
60 ASSERT_THROW(sum_node.arg(2), std::out_of_range);
63 TEST(CircleSumTest, visit_mutable_NEG)
65 struct TestVisitor final : public luci::CircleNodeMutableVisitor<void>
69 luci::CircleSum sum_node;
72 ASSERT_THROW(sum_node.accept(&tv), std::exception);
75 TEST(CircleSumTest, visit_NEG)
77 struct TestVisitor final : public luci::CircleNodeVisitor<void>
81 luci::CircleSum sum_node;
84 ASSERT_THROW(sum_node.accept(&tv), std::exception);