1*71db0c75SAndroid Build Coastguard Worker //===-- Unittests for queue -----------------------------------------------===//
2*71db0c75SAndroid Build Coastguard Worker //
3*71db0c75SAndroid Build Coastguard Worker // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4*71db0c75SAndroid Build Coastguard Worker // See https://llvm.org/LICENSE.txt for license information.
5*71db0c75SAndroid Build Coastguard Worker // SPDSList-License-Identifier: Apache-2.0 WITH LLVM-exception
6*71db0c75SAndroid Build Coastguard Worker //
7*71db0c75SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
8*71db0c75SAndroid Build Coastguard Worker
9*71db0c75SAndroid Build Coastguard Worker #include "src/__support/CPP/string.h"
10*71db0c75SAndroid Build Coastguard Worker #include "src/__support/char_vector.h"
11*71db0c75SAndroid Build Coastguard Worker #include "src/__support/macros/config.h"
12*71db0c75SAndroid Build Coastguard Worker #include "test/UnitTest/Test.h"
13*71db0c75SAndroid Build Coastguard Worker
14*71db0c75SAndroid Build Coastguard Worker #include "include/llvm-libc-macros/sys-queue-macros.h"
15*71db0c75SAndroid Build Coastguard Worker
16*71db0c75SAndroid Build Coastguard Worker using LIBC_NAMESPACE::CharVector;
17*71db0c75SAndroid Build Coastguard Worker using LIBC_NAMESPACE::cpp::string;
18*71db0c75SAndroid Build Coastguard Worker
19*71db0c75SAndroid Build Coastguard Worker namespace LIBC_NAMESPACE_DECL {
20*71db0c75SAndroid Build Coastguard Worker
TEST(LlvmLibcQueueTest,SList)21*71db0c75SAndroid Build Coastguard Worker TEST(LlvmLibcQueueTest, SList) {
22*71db0c75SAndroid Build Coastguard Worker struct Entry {
23*71db0c75SAndroid Build Coastguard Worker char c;
24*71db0c75SAndroid Build Coastguard Worker SLIST_ENTRY(Entry) entries;
25*71db0c75SAndroid Build Coastguard Worker };
26*71db0c75SAndroid Build Coastguard Worker
27*71db0c75SAndroid Build Coastguard Worker SLIST_HEAD(Head, Entry);
28*71db0c75SAndroid Build Coastguard Worker
29*71db0c75SAndroid Build Coastguard Worker Head head = SLIST_HEAD_INITIALIZER(head);
30*71db0c75SAndroid Build Coastguard Worker
31*71db0c75SAndroid Build Coastguard Worker struct Contains : public testing::Matcher<Head> {
32*71db0c75SAndroid Build Coastguard Worker string s;
33*71db0c75SAndroid Build Coastguard Worker Contains(string s) : s(s) {}
34*71db0c75SAndroid Build Coastguard Worker bool match(Head head) {
35*71db0c75SAndroid Build Coastguard Worker Entry *e;
36*71db0c75SAndroid Build Coastguard Worker CharVector v;
37*71db0c75SAndroid Build Coastguard Worker SLIST_FOREACH(e, &head, entries) { v.append(e->c); }
38*71db0c75SAndroid Build Coastguard Worker return s == v.c_str();
39*71db0c75SAndroid Build Coastguard Worker }
40*71db0c75SAndroid Build Coastguard Worker };
41*71db0c75SAndroid Build Coastguard Worker
42*71db0c75SAndroid Build Coastguard Worker Entry e1 = {'a', {NULL}};
43*71db0c75SAndroid Build Coastguard Worker SLIST_INSERT_HEAD(&head, &e1, entries);
44*71db0c75SAndroid Build Coastguard Worker
45*71db0c75SAndroid Build Coastguard Worker ASSERT_THAT(head, Contains("a"));
46*71db0c75SAndroid Build Coastguard Worker
47*71db0c75SAndroid Build Coastguard Worker Entry e2 = {'b', {NULL}};
48*71db0c75SAndroid Build Coastguard Worker SLIST_INSERT_AFTER(&e1, &e2, entries);
49*71db0c75SAndroid Build Coastguard Worker
50*71db0c75SAndroid Build Coastguard Worker ASSERT_THAT(head, Contains("ab"));
51*71db0c75SAndroid Build Coastguard Worker
52*71db0c75SAndroid Build Coastguard Worker Head head2 = SLIST_HEAD_INITIALIZER(head);
53*71db0c75SAndroid Build Coastguard Worker
54*71db0c75SAndroid Build Coastguard Worker Entry e3 = {'c', {NULL}};
55*71db0c75SAndroid Build Coastguard Worker SLIST_INSERT_HEAD(&head2, &e3, entries);
56*71db0c75SAndroid Build Coastguard Worker
57*71db0c75SAndroid Build Coastguard Worker ASSERT_THAT(head2, Contains("c"));
58*71db0c75SAndroid Build Coastguard Worker
59*71db0c75SAndroid Build Coastguard Worker SLIST_SWAP(&head, &head2, Entry);
60*71db0c75SAndroid Build Coastguard Worker
61*71db0c75SAndroid Build Coastguard Worker ASSERT_THAT(head2, Contains("ab"));
62*71db0c75SAndroid Build Coastguard Worker
63*71db0c75SAndroid Build Coastguard Worker SLIST_CONCAT(&head2, &head, Entry, entries);
64*71db0c75SAndroid Build Coastguard Worker
65*71db0c75SAndroid Build Coastguard Worker ASSERT_THAT(head2, Contains("abc"));
66*71db0c75SAndroid Build Coastguard Worker
67*71db0c75SAndroid Build Coastguard Worker SLIST_CONCAT(&head, &head2, Entry, entries);
68*71db0c75SAndroid Build Coastguard Worker
69*71db0c75SAndroid Build Coastguard Worker ASSERT_THAT(head, Contains("abc"));
70*71db0c75SAndroid Build Coastguard Worker
71*71db0c75SAndroid Build Coastguard Worker Entry *e = NULL, *tmp = NULL;
72*71db0c75SAndroid Build Coastguard Worker SLIST_FOREACH_SAFE(e, &head, entries, tmp) {
73*71db0c75SAndroid Build Coastguard Worker if (e == &e2) {
74*71db0c75SAndroid Build Coastguard Worker SLIST_REMOVE(&head, e, Entry, entries);
75*71db0c75SAndroid Build Coastguard Worker }
76*71db0c75SAndroid Build Coastguard Worker }
77*71db0c75SAndroid Build Coastguard Worker
78*71db0c75SAndroid Build Coastguard Worker ASSERT_THAT(head, Contains("ac"));
79*71db0c75SAndroid Build Coastguard Worker
80*71db0c75SAndroid Build Coastguard Worker while (!SLIST_EMPTY(&head)) {
81*71db0c75SAndroid Build Coastguard Worker e = SLIST_FIRST(&head);
82*71db0c75SAndroid Build Coastguard Worker SLIST_REMOVE_HEAD(&head, entries);
83*71db0c75SAndroid Build Coastguard Worker }
84*71db0c75SAndroid Build Coastguard Worker
85*71db0c75SAndroid Build Coastguard Worker ASSERT_TRUE(SLIST_EMPTY(&head));
86*71db0c75SAndroid Build Coastguard Worker }
87*71db0c75SAndroid Build Coastguard Worker
TEST(LlvmLibcQueueTest,STailQ)88*71db0c75SAndroid Build Coastguard Worker TEST(LlvmLibcQueueTest, STailQ) {
89*71db0c75SAndroid Build Coastguard Worker struct Entry {
90*71db0c75SAndroid Build Coastguard Worker char c;
91*71db0c75SAndroid Build Coastguard Worker STAILQ_ENTRY(Entry) entries;
92*71db0c75SAndroid Build Coastguard Worker };
93*71db0c75SAndroid Build Coastguard Worker
94*71db0c75SAndroid Build Coastguard Worker STAILQ_HEAD(Head, Entry);
95*71db0c75SAndroid Build Coastguard Worker
96*71db0c75SAndroid Build Coastguard Worker Head head = STAILQ_HEAD_INITIALIZER(head);
97*71db0c75SAndroid Build Coastguard Worker
98*71db0c75SAndroid Build Coastguard Worker struct Contains : public testing::Matcher<Head> {
99*71db0c75SAndroid Build Coastguard Worker string s;
100*71db0c75SAndroid Build Coastguard Worker Contains(string s) : s(s) {}
101*71db0c75SAndroid Build Coastguard Worker bool match(Head head) {
102*71db0c75SAndroid Build Coastguard Worker Entry *e;
103*71db0c75SAndroid Build Coastguard Worker CharVector v;
104*71db0c75SAndroid Build Coastguard Worker STAILQ_FOREACH(e, &head, entries) { v.append(e->c); }
105*71db0c75SAndroid Build Coastguard Worker return s == v.c_str();
106*71db0c75SAndroid Build Coastguard Worker }
107*71db0c75SAndroid Build Coastguard Worker };
108*71db0c75SAndroid Build Coastguard Worker
109*71db0c75SAndroid Build Coastguard Worker STAILQ_INIT(&head);
110*71db0c75SAndroid Build Coastguard Worker ASSERT_TRUE(STAILQ_EMPTY(&head));
111*71db0c75SAndroid Build Coastguard Worker
112*71db0c75SAndroid Build Coastguard Worker Entry e1 = {'a', {NULL}};
113*71db0c75SAndroid Build Coastguard Worker STAILQ_INSERT_HEAD(&head, &e1, entries);
114*71db0c75SAndroid Build Coastguard Worker
115*71db0c75SAndroid Build Coastguard Worker ASSERT_THAT(head, Contains("a"));
116*71db0c75SAndroid Build Coastguard Worker
117*71db0c75SAndroid Build Coastguard Worker Entry e2 = {'b', {NULL}};
118*71db0c75SAndroid Build Coastguard Worker STAILQ_INSERT_TAIL(&head, &e2, entries);
119*71db0c75SAndroid Build Coastguard Worker
120*71db0c75SAndroid Build Coastguard Worker ASSERT_THAT(head, Contains("ab"));
121*71db0c75SAndroid Build Coastguard Worker
122*71db0c75SAndroid Build Coastguard Worker Entry e3 = {'c', {NULL}};
123*71db0c75SAndroid Build Coastguard Worker STAILQ_INSERT_AFTER(&head, &e2, &e3, entries);
124*71db0c75SAndroid Build Coastguard Worker
125*71db0c75SAndroid Build Coastguard Worker ASSERT_THAT(head, Contains("abc"));
126*71db0c75SAndroid Build Coastguard Worker
127*71db0c75SAndroid Build Coastguard Worker Head head2 = STAILQ_HEAD_INITIALIZER(head);
128*71db0c75SAndroid Build Coastguard Worker
129*71db0c75SAndroid Build Coastguard Worker Entry e4 = {'d', {NULL}};
130*71db0c75SAndroid Build Coastguard Worker STAILQ_INSERT_HEAD(&head2, &e4, entries);
131*71db0c75SAndroid Build Coastguard Worker
132*71db0c75SAndroid Build Coastguard Worker ASSERT_THAT(head2, Contains("d"));
133*71db0c75SAndroid Build Coastguard Worker
134*71db0c75SAndroid Build Coastguard Worker STAILQ_SWAP(&head, &head2, Entry);
135*71db0c75SAndroid Build Coastguard Worker
136*71db0c75SAndroid Build Coastguard Worker ASSERT_THAT(head2, Contains("abc"));
137*71db0c75SAndroid Build Coastguard Worker
138*71db0c75SAndroid Build Coastguard Worker STAILQ_CONCAT(&head2, &head, Entry, entries);
139*71db0c75SAndroid Build Coastguard Worker
140*71db0c75SAndroid Build Coastguard Worker ASSERT_EQ(STAILQ_FIRST(&head2), &e1);
141*71db0c75SAndroid Build Coastguard Worker ASSERT_EQ(STAILQ_LAST(&head2, Entry, entries), &e4);
142*71db0c75SAndroid Build Coastguard Worker
143*71db0c75SAndroid Build Coastguard Worker ASSERT_THAT(head2, Contains("abcd"));
144*71db0c75SAndroid Build Coastguard Worker
145*71db0c75SAndroid Build Coastguard Worker STAILQ_CONCAT(&head, &head2, Entry, entries);
146*71db0c75SAndroid Build Coastguard Worker
147*71db0c75SAndroid Build Coastguard Worker ASSERT_EQ(STAILQ_FIRST(&head), &e1);
148*71db0c75SAndroid Build Coastguard Worker ASSERT_EQ(STAILQ_LAST(&head, Entry, entries), &e4);
149*71db0c75SAndroid Build Coastguard Worker
150*71db0c75SAndroid Build Coastguard Worker ASSERT_THAT(head, Contains("abcd"));
151*71db0c75SAndroid Build Coastguard Worker
152*71db0c75SAndroid Build Coastguard Worker Entry *e = NULL, *tmp = NULL;
153*71db0c75SAndroid Build Coastguard Worker STAILQ_FOREACH_SAFE(e, &head, entries, tmp) {
154*71db0c75SAndroid Build Coastguard Worker if (e == &e2) {
155*71db0c75SAndroid Build Coastguard Worker STAILQ_REMOVE(&head, e, Entry, entries);
156*71db0c75SAndroid Build Coastguard Worker }
157*71db0c75SAndroid Build Coastguard Worker }
158*71db0c75SAndroid Build Coastguard Worker
159*71db0c75SAndroid Build Coastguard Worker ASSERT_THAT(head, Contains("acd"));
160*71db0c75SAndroid Build Coastguard Worker
161*71db0c75SAndroid Build Coastguard Worker while (!STAILQ_EMPTY(&head)) {
162*71db0c75SAndroid Build Coastguard Worker e = STAILQ_FIRST(&head);
163*71db0c75SAndroid Build Coastguard Worker STAILQ_REMOVE_HEAD(&head, entries);
164*71db0c75SAndroid Build Coastguard Worker }
165*71db0c75SAndroid Build Coastguard Worker
166*71db0c75SAndroid Build Coastguard Worker ASSERT_TRUE(STAILQ_EMPTY(&head));
167*71db0c75SAndroid Build Coastguard Worker }
168*71db0c75SAndroid Build Coastguard Worker
169*71db0c75SAndroid Build Coastguard Worker } // namespace LIBC_NAMESPACE_DECL
170