//===- llvm/unittest/ADT/PointerUnionTest.cpp - Optional unit tests -------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// #include "llvm/ADT/PointerUnion.h" #include "gtest/gtest.h" using namespace llvm; namespace { typedef PointerUnion PU; struct PointerUnionTest : public testing::Test { float f; int i; PU a, b, c, n; PointerUnionTest() : f(3.14f), i(42), a(&f), b(&i), c(&i), n() {} }; TEST_F(PointerUnionTest, Comparison) { EXPECT_TRUE(a == a); EXPECT_FALSE(a != a); EXPECT_TRUE(a != b); EXPECT_FALSE(a == b); EXPECT_TRUE(b == c); EXPECT_FALSE(b != c); EXPECT_TRUE(b != n); EXPECT_FALSE(b == n); } TEST_F(PointerUnionTest, Null) { EXPECT_FALSE(a.isNull()); EXPECT_FALSE(b.isNull()); EXPECT_TRUE(n.isNull()); EXPECT_FALSE(!a); EXPECT_FALSE(!b); EXPECT_TRUE(!n); // workaround an issue with EXPECT macros and explicit bool EXPECT_TRUE((bool)a); EXPECT_TRUE((bool)b); EXPECT_FALSE(n); EXPECT_NE(n, b); EXPECT_EQ(b, c); b = nullptr; EXPECT_EQ(n, b); EXPECT_NE(b, c); } TEST_F(PointerUnionTest, Is) { EXPECT_FALSE(a.is()); EXPECT_TRUE(a.is()); EXPECT_TRUE(b.is()); EXPECT_FALSE(b.is()); EXPECT_TRUE(n.is()); EXPECT_FALSE(n.is()); } TEST_F(PointerUnionTest, Get) { EXPECT_EQ(a.get(), &f); EXPECT_EQ(b.get(), &i); EXPECT_EQ(n.get(), (int *)nullptr); } template struct alignas(8) Aligned {}; typedef PointerUnion *, Aligned<1> *, Aligned<2> *, Aligned<3> *, Aligned<4> *, Aligned<5> *, Aligned<6> *, Aligned<7> *> PU8; TEST_F(PointerUnionTest, ManyElements) { Aligned<0> a0; Aligned<7> a7; PU8 a = &a0; EXPECT_TRUE(a.is*>()); EXPECT_FALSE(a.is*>()); EXPECT_FALSE(a.is*>()); EXPECT_FALSE(a.is*>()); EXPECT_FALSE(a.is*>()); EXPECT_FALSE(a.is*>()); EXPECT_FALSE(a.is*>()); EXPECT_FALSE(a.is*>()); EXPECT_EQ(a.dyn_cast*>(), &a0); EXPECT_EQ(*a.getAddrOfPtr1(), &a0); a = &a7; EXPECT_FALSE(a.is*>()); EXPECT_FALSE(a.is*>()); EXPECT_FALSE(a.is*>()); EXPECT_FALSE(a.is*>()); EXPECT_FALSE(a.is*>()); EXPECT_FALSE(a.is*>()); EXPECT_FALSE(a.is*>()); EXPECT_TRUE(a.is*>()); EXPECT_EQ(a.dyn_cast*>(), &a7); EXPECT_TRUE(a == PU8(&a7)); EXPECT_TRUE(a != PU8(&a0)); } } // end anonymous namespace