blob: 1f4a8311370a6d5beed7ddcf15df12ea756e48be [file] [log] [blame]
Duncan P. N. Exon Smith9f5c83b2016-08-22 22:21:07 +00001//===- unittests/ADT/IListSentinelTest.cpp - ilist_sentinel unit tests ----===//
2//
Chandler Carruth2946cd72019-01-19 08:50:56 +00003// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
Duncan P. N. Exon Smith9f5c83b2016-08-22 22:21:07 +00006//
7//===----------------------------------------------------------------------===//
8
Duncan P. N. Exon Smith085bbf12016-09-11 16:20:53 +00009#include "llvm/ADT/ilist_node.h"
Duncan P. N. Exon Smith9f5c83b2016-08-22 22:21:07 +000010#include "gtest/gtest.h"
11
12using namespace llvm;
13
14namespace {
15
Duncan P. N. Exon Smith085bbf12016-09-11 16:20:53 +000016template <class T, class... Options> struct PickSentinel {
17 typedef ilist_sentinel<
18 typename ilist_detail::compute_node_options<T, Options...>::type>
19 type;
20};
21
Duncan P. N. Exon Smith9f5c83b2016-08-22 22:21:07 +000022class Node : public ilist_node<Node> {};
Duncan P. N. Exon Smith085bbf12016-09-11 16:20:53 +000023class TrackingNode : public ilist_node<Node, ilist_sentinel_tracking<true>> {};
24typedef PickSentinel<Node>::type Sentinel;
25typedef PickSentinel<Node, ilist_sentinel_tracking<true>>::type
26 TrackingSentinel;
27typedef PickSentinel<Node, ilist_sentinel_tracking<false>>::type
28 NoTrackingSentinel;
Duncan P. N. Exon Smith9f5c83b2016-08-22 22:21:07 +000029
Duncan P. N. Exon Smith34c4d2a2016-09-10 16:55:06 +000030struct LocalAccess : ilist_detail::NodeAccess {
31 using NodeAccess::getPrev;
32 using NodeAccess::getNext;
33};
34
Duncan P. N. Exon Smith9f5c83b2016-08-22 22:21:07 +000035TEST(IListSentinelTest, DefaultConstructor) {
Duncan P. N. Exon Smith085bbf12016-09-11 16:20:53 +000036 Sentinel S;
Duncan P. N. Exon Smith34c4d2a2016-09-10 16:55:06 +000037 EXPECT_EQ(&S, LocalAccess::getPrev(S));
38 EXPECT_EQ(&S, LocalAccess::getNext(S));
Joerg Sonnenbergerece29ea2016-09-30 19:52:27 +000039#if LLVM_ENABLE_ABI_BREAKING_CHECKS
Duncan P. N. Exon Smith9f5c83b2016-08-22 22:21:07 +000040 EXPECT_TRUE(S.isKnownSentinel());
41#else
42 EXPECT_FALSE(S.isKnownSentinel());
43#endif
Duncan P. N. Exon Smith085bbf12016-09-11 16:20:53 +000044
45 TrackingSentinel TS;
46 NoTrackingSentinel NTS;
47 EXPECT_TRUE(TS.isSentinel());
48 EXPECT_TRUE(TS.isKnownSentinel());
49 EXPECT_FALSE(NTS.isKnownSentinel());
Duncan P. N. Exon Smith9f5c83b2016-08-22 22:21:07 +000050}
51
52TEST(IListSentinelTest, NormalNodeIsNotKnownSentinel) {
53 Node N;
Duncan P. N. Exon Smith34c4d2a2016-09-10 16:55:06 +000054 EXPECT_EQ(nullptr, LocalAccess::getPrev(N));
55 EXPECT_EQ(nullptr, LocalAccess::getNext(N));
Duncan P. N. Exon Smith9f5c83b2016-08-22 22:21:07 +000056 EXPECT_FALSE(N.isKnownSentinel());
Duncan P. N. Exon Smith085bbf12016-09-11 16:20:53 +000057
58 TrackingNode TN;
59 EXPECT_FALSE(TN.isSentinel());
Duncan P. N. Exon Smith9f5c83b2016-08-22 22:21:07 +000060}
61
62} // end namespace