-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathqueue_test.cpp
More file actions
57 lines (50 loc) · 1.12 KB
/
Copy pathqueue_test.cpp
File metadata and controls
57 lines (50 loc) · 1.12 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
#include <gtest/gtest.h>
#include <gmock/gmock.h>
#include <vector>
#include "queue.h"
using namespace ::testing;
template<typename T>
std::vector<T> drain(Queue<T>& q) {
std::vector<T> elements{};
while (!q.empty()) {
elements.push_back(q.front());
q.dequeue();
}
return elements;
}
TEST(Queue, BasicResize) {
Queue<int> q(4);
for (int i = 0; i < 10; i++) {
q.enqueue(i);
}
ASSERT_THAT(drain(q), ElementsAre(0, 1, 2, 3, 4, 5, 6, 7, 8, 9));
}
TEST(Queue, WrapAround) {
std::vector<int> elements{};
Queue<int> q(4);
for (int i = 0; i < 10; i++) {
q.enqueue(i);
elements.push_back(q.front());
q.dequeue();
}
ASSERT_THAT(elements, ElementsAre(0, 1, 2, 3, 4, 5, 6, 7, 8, 9));
}
TEST(Queue, WrapAroundResize) {
Queue<int> q(4);
for (int i = 0; i < 3; i++) {
q.enqueue(i);
q.dequeue();
}
for (int i = 6; i < 20; i++) {
q.enqueue(i);
}
ASSERT_THAT(drain(q), ElementsAre(6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19));
}
TEST(Queue, Front) {
Queue<int> q(4);
q.enqueue(1234);
for (int i = 0; i < 10; i++) {
q.enqueue(i);
ASSERT_EQ(q.front(), 1234);
}
}