1 #include "chre/util/priority_queue.h"
2 #include "gtest/gtest.h"
3 
4 using chre::PriorityQueue;
5 
6 namespace {
7 class DummyElement {
8  public:
9   DummyElement(){};
10   DummyElement(int index, int value) {
11     mValue = value;
12     mIndex = index;
13   };
14   ~DummyElement(){};
15   void setValue(int value) {
16     mValue = value;
17   }
18   int getValue() const {
19     return mValue;
20   }
21   int getIndex() const {
22     return mIndex;
23   }
24 
25  private:
26   int mIndex = -1;
27   int mValue = -1;
28 };
29 
30 bool compareFunction(const DummyElement &left, const DummyElement &right) {
31   return left.getValue() > right.getValue();
32 };
33 
34 class CompareClass {
35  public:
36   bool operator()(const DummyElement &left, const DummyElement &right) const {
37     return left.getValue() > right.getValue();
38   }
39 };
40 }  // namespace
41 
42 TEST(PriorityQueueTest, IsEmptyInitially) {
43   PriorityQueue<int> q;
44   EXPECT_TRUE(q.empty());
45   EXPECT_EQ(0, q.size());
46   EXPECT_EQ(0, q.capacity());
47 }
48 
49 TEST(PriorityQueueTest, SimplePushPop) {
50   PriorityQueue<int> q;
51 
52   EXPECT_TRUE(q.push(0));
53   EXPECT_TRUE(q.push(2));
54   EXPECT_TRUE(q.push(3));
55   EXPECT_TRUE(q.push(1));
56   q.pop();
57   EXPECT_TRUE(q.push(4));
58 }
59 
60 TEST(PriorityQueueTest, TestSize) {
61   PriorityQueue<int> q;
62 
63   q.push(1);
64   EXPECT_EQ(1, q.size());
65   q.push(2);
66   EXPECT_EQ(2, q.size());
67   q.pop();
68   EXPECT_EQ(1, q.size());
69 }
70 
71 TEST(PriorityQueueTest, TestEmpty) {
72   PriorityQueue<int> q;
73 
74   q.push(1);
75   EXPECT_FALSE(q.empty());
76   q.push(2);
77   EXPECT_FALSE(q.empty());
78   q.pop();
79   EXPECT_FALSE(q.empty());
80   q.pop();
81   EXPECT_TRUE(q.empty());
82 }
83 
84 TEST(PriorityQueueTest, TestCapacity) {
85   PriorityQueue<int> q;
86 
87   q.push(1);
88   EXPECT_EQ(1, q.capacity());
89   q.push(2);
90   EXPECT_EQ(2, q.capacity());
91   q.push(3);
92   EXPECT_EQ(4, q.capacity());
93 }
94 
95 TEST(PriorityQueueTest, PopWhenEmpty) {
96   PriorityQueue<int> q;
97   q.pop();
98   EXPECT_EQ(0, q.size());
99 }
100 
101 TEST(PriorityQueueDeathTest, TopWhenEmpty) {
102   PriorityQueue<int> q;
103   EXPECT_DEATH(q.top(), "");
104 }
105 
106 TEST(PriorityQueueTest, TestTop) {
107   PriorityQueue<int> q;
108   q.push(1);
109   EXPECT_EQ(1, q.top());
110   q.push(2);
111   q.push(3);
112   EXPECT_EQ(3, q.top());
113   q.pop();
114   EXPECT_EQ(2, q.top());
115   q.pop();
116   EXPECT_EQ(1, q.top());
117 }
118 
119 TEST(PriorityQueueDeathTest, InvalidSubscript) {
120   PriorityQueue<int> q;
121   EXPECT_DEATH(q[0], "");
122 }
123 
124 TEST(PriorityQueueTest, Subscript) {
125   PriorityQueue<int> q;
126   q.push(1);
127   q.push(2);
128   EXPECT_EQ(2, q[0]);
129   EXPECT_EQ(1, q[1]);
130 
131   q.pop();
132   EXPECT_EQ(1, q[0]);
133 }
134 
135 TEST(PriorityQueueDeathTest, RemoveWithInvalidIndex) {
136   PriorityQueue<int> q;
137   EXPECT_DEATH(q.remove(0), "");
138   EXPECT_EQ(0, q.size());
139 }
140 
141 TEST(PriorityQueueTest, RemoveWithIndex) {
142   PriorityQueue<int> q;
143   q.push(1);
144   q.push(2);
145   q.remove(0);
146   EXPECT_EQ(1, q.top());
147   EXPECT_EQ(1, q.size());
148 
149   q.push(3);
150   q.remove(1);
151   EXPECT_EQ(3, q.top());
152   EXPECT_EQ(1, q.size());
153 }
154 
155 TEST(PriorityQueueTest, CompareGreater) {
156   PriorityQueue<int, std::greater<int>> q;
157 
158   EXPECT_TRUE(q.push(0));
159   EXPECT_TRUE(q.push(2));
160   EXPECT_TRUE(q.push(3));
161   EXPECT_TRUE(q.push(1));
162 
163   for (size_t i = 0; i < 4; i++) {
164     EXPECT_EQ(i, q.top());
165     q.pop();
166   }
167 }
168 
169 TEST(PriorityQueueTest, EmplaceCompareLambda) {
170   auto cmp = [](const DummyElement &left, const DummyElement &right) {
171     return left.getValue() > right.getValue();
172   };
173   PriorityQueue<DummyElement, decltype(cmp)> q(cmp);
174 
175   EXPECT_TRUE(q.emplace(0, 0));
176   EXPECT_TRUE(q.emplace(1, 2));
177   EXPECT_TRUE(q.emplace(2, 1));
178   EXPECT_EQ(3, q.size());
179 
180   EXPECT_EQ(0, q.top().getValue());
181   EXPECT_EQ(0, q.top().getIndex());
182 
183   q.pop();
184   EXPECT_EQ(1, q.top().getValue());
185   EXPECT_EQ(2, q.top().getIndex());
186 
187   q.pop();
188   EXPECT_EQ(2, q.top().getValue());
189   EXPECT_EQ(1, q.top().getIndex());
190 }
191 
192 TEST(PriorityQueueTest, EmplaceCompareFunction) {
193   PriorityQueue<DummyElement,
194                 std::function<bool(const DummyElement &, const DummyElement &)>>
195       q(compareFunction);
196 
197   EXPECT_TRUE(q.emplace(0, 0));
198   EXPECT_TRUE(q.emplace(1, 2));
199   EXPECT_TRUE(q.emplace(2, 1));
200   EXPECT_EQ(3, q.size());
201 
202   EXPECT_EQ(0, q.top().getValue());
203   EXPECT_EQ(0, q.top().getIndex());
204 
205   q.pop();
206   EXPECT_EQ(1, q.top().getValue());
207   EXPECT_EQ(2, q.top().getIndex());
208 
209   q.pop();
210   EXPECT_EQ(2, q.top().getValue());
211   EXPECT_EQ(1, q.top().getIndex());
212 }
213 
214 TEST(PriorityQueueTest, EmplaceCompareClass) {
215   PriorityQueue<DummyElement, CompareClass> q;
216 
217   EXPECT_TRUE(q.emplace(0, 0));
218   EXPECT_TRUE(q.emplace(1, 2));
219   EXPECT_TRUE(q.emplace(2, 1));
220   EXPECT_EQ(3, q.size());
221 
222   EXPECT_EQ(0, q.top().getValue());
223   EXPECT_EQ(0, q.top().getIndex());
224 
225   q.pop();
226   EXPECT_EQ(1, q.top().getValue());
227   EXPECT_EQ(2, q.top().getIndex());
228 
229   q.pop();
230   EXPECT_EQ(2, q.top().getValue());
231   EXPECT_EQ(1, q.top().getIndex());
232 }
233 
234 TEST(PriorityQueuetest, Iterator) {
235   PriorityQueue<int> q;
236   q.push(0);
237   q.push(1);
238   q.push(2);
239 
240   PriorityQueue<int>::iterator it = q.begin();
241   EXPECT_EQ(q[0], *it);
242 
243   it += q.size();
244   EXPECT_TRUE(it == q.end());
245 }
246 
247 TEST(PriorityQueuetest, ConstIterator) {
248   PriorityQueue<int> q;
249   q.push(0);
250   q.push(1);
251   q.push(2);
252 
253   PriorityQueue<int>::const_iterator cit = q.cbegin();
254   EXPECT_EQ(q[0], *cit);
255 
256   cit += q.size();
257   EXPECT_TRUE(cit == q.cend());
258 }
259