mindspore/tests/ut/cpp/utils/baseref_test.cc

101 lines
2.7 KiB
C++

/**
* Copyright 2020 Huawei Technologies Co., Ltd
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include <iostream>
#include <memory>
#include "common/common_test.h"
#include "ir/anf.h"
#include "utils/base_ref.h"
namespace mindspore {
namespace utils {
class TestBaseRef : public UT::Common {
public:
TestBaseRef() {}
virtual void SetUp() {}
virtual void TearDown() {}
};
TEST_F(TestBaseRef, TestScalar) {
BaseRef a = 1;
BaseRef b = 1.0;
if (isa<int>(a)) {
ASSERT_EQ(cast<int>(a), 1);
Int32ImmPtr c = cast<Int32ImmPtr>(a);
ASSERT_EQ(cast<int>(c), 1);
}
ASSERT_TRUE(isa<Int32Imm>(a));
ASSERT_TRUE(isa<BaseRef>(a));
ASSERT_TRUE(isa<double>(b));
ASSERT_TRUE(isa<FP64Imm>(b));
BaseRef c = 1;
ASSERT_EQ(a == c, true);
}
void func(const BaseRef& sexp) {
if (isa<VectorRef>(sexp)) {
const VectorRef& a = cast<VectorRef>(sexp);
for (size_t i = 0; i < a.size(); i++) {
BaseRef v = a[i];
MS_LOG(INFO) << "for is i:" << i << ", " << v.ToString() << "\n";
}
MS_LOG(INFO) << "in func is valuesequeue:" << sexp.ToString() << "\n";
}
}
TEST_F(TestBaseRef, TestNode) {
AnfNodePtr anf = NewValueNode(1);
BaseRef d = anf;
MS_LOG(INFO) << "anf typeid:" << dyn_cast<AnfNode>(anf).get();
MS_LOG(INFO) << "anf typeid:" << NewValueNode(1)->tid();
MS_LOG(INFO) << "node reftypeid:" << d.tid();
ASSERT_EQ(isa<AnfNodePtr>(d), true);
ASSERT_EQ(isa<AnfNode>(d), true);
ASSERT_EQ(isa<ValueNode>(d), true);
AnfNodePtr c = cast<ValueNodePtr>(d);
ASSERT_NE(c, nullptr);
}
TEST_F(TestBaseRef, TestVector) {
AnfNodePtr anf = NewValueNode(1);
VectorRef a({1, 2, anf, NewValueNode(1)});
ASSERT_TRUE(isa<VectorRef>(a));
func(a);
BaseRef b;
b = 1;
ASSERT_TRUE(isa<int>(b));
std::vector<int> int_t({1, 2, 3});
VectorRef k;
k.insert(k.end(), int_t.begin(), int_t.end());
k = a;
func(k);
BaseRef c = std::make_shared<VectorRef>(a);
BaseRef c1 = std::make_shared<VectorRef>(a);
ASSERT_TRUE(c == c1);
ASSERT_TRUE(isa<VectorRef>(c));
VectorRefPtr d = cast<VectorRefPtr>(c);
ASSERT_TRUE(isa<VectorRef>(d));
VectorRef e1({1, 2, anf});
VectorRef e({1, 2, anf});
ASSERT_EQ(e1 == e, true);
}
} // namespace utils
} // namespace mindspore