Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(81)

Side by Side Diff: net/base/priority_queue_unittest.cc

Issue 8965025: Refactoring of job dispatch in HostResolverImpl in preparation for DnsClient. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fixes from try bots. Created 8 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "net/base/priority_queue.h"
6 #include "testing/gtest/include/gtest/gtest.h"
7
8 namespace net {
9
10 namespace {
11
12 const size_t kPriorities[] = { 2, 1, 2, 0, 4, 3, 1, 4, 0 };
13 const size_t kNumPriorities = 5; // max(kPriorities) + 1
14 const size_t kNumElements = arraysize(kPriorities);
15 const size_t kMinOrder[kNumElements] = { 3, 8, 1, 6, 0, 2, 5, 4, 7 };
16 const size_t kMaxOrder[kNumElements] = { 4, 7, 5, 0, 2, 1, 6, 3, 8 };
17
18 void CheckEmpty(PriorityQueue<size_t>* queue) {
19 EXPECT_EQ(0u, queue->size());
20 EXPECT_TRUE(queue->FirstMin().is_null());
21 EXPECT_TRUE(queue->LastMin().is_null());
22 EXPECT_TRUE(queue->FirstMax().is_null());
23 EXPECT_TRUE(queue->LastMax().is_null());
24 }
25
26 TEST(PriorityQueueTest, AddAndClear) {
27 PriorityQueue<size_t> queue(kNumPriorities);
28 PriorityQueue<size_t>::Pointer pointers[kNumElements];
29
30 CheckEmpty(&queue);
31 for (size_t i = 0; i < kNumElements; ++i) {
32 EXPECT_EQ(i, queue.size());
33 pointers[i] = queue.Insert(i, kPriorities[i]);
34 }
35 EXPECT_EQ(kNumElements, queue.size());
36
37 for (size_t i = 0; i < kNumElements; ++i) {
38 EXPECT_EQ(kPriorities[i], pointers[i].priority());
39 EXPECT_EQ(i, pointers[i].value());
40 }
41
42 queue.Clear();
43 CheckEmpty(&queue);
44 }
45
46 TEST(PriorityQueueTest, FirstMinOrder) {
47 PriorityQueue<size_t> queue(kNumPriorities);
48 PriorityQueue<size_t>::Pointer pointers[kNumElements];
49
50 for (size_t i = 0; i < kNumElements; ++i) {
51 pointers[i] = queue.Insert(i, kPriorities[i]);
52 }
53
54 for (size_t i = 0; i < kNumElements; ++i) {
55 EXPECT_EQ(kNumElements - i, queue.size());
56 // Also check Equals.
57 EXPECT_TRUE(queue.FirstMin().Equals(pointers[kMinOrder[i]]));
58 EXPECT_EQ(kMinOrder[i], queue.FirstMin().value());
59 queue.Erase(queue.FirstMin());
60 }
61 CheckEmpty(&queue);
62 }
63
64 TEST(PriorityQueueTest, LastMinOrder) {
65 PriorityQueue<size_t> queue(kNumPriorities);
66
67 for (size_t i = 0; i < kNumElements; ++i) {
68 queue.Insert(i, kPriorities[i]);
69 }
70
71 for (size_t i = 0; i < kNumElements; ++i) {
72 EXPECT_EQ(kMaxOrder[kNumElements - i - 1], queue.LastMin().value());
cbentzel 2012/01/05 18:32:20 Clever reuse of kMaxOrder - but may be clearer to
73 queue.Erase(queue.LastMin());
74 }
75 CheckEmpty(&queue);
76 }
77
78 TEST(PriorityQueueTest, FirstMaxOrder) {
79 PriorityQueue<size_t> queue(kNumPriorities);
80
81 for (size_t i = 0; i < kNumElements; ++i) {
82 queue.Insert(i, kPriorities[i]);
83 }
84
85 for (size_t i = 0; i < kNumElements; ++i) {
86 EXPECT_EQ(kMaxOrder[i], queue.FirstMax().value());
87 queue.Erase(queue.FirstMax());
88 }
89 CheckEmpty(&queue);
90 }
91
92 TEST(PriorityQueueTest, LastMaxOrder) {
93 PriorityQueue<size_t> queue(kNumPriorities);
94
95 for (size_t i = 0; i < kNumElements; ++i) {
96 queue.Insert(i, kPriorities[i]);
97 }
98
99 for (size_t i = 0; i < kNumElements; ++i) {
100 EXPECT_EQ(kMinOrder[kNumElements - i - 1], queue.LastMax().value());
101 queue.Erase(queue.LastMax());
102 }
103 CheckEmpty(&queue);
104 }
105
106 TEST(PriorityQueueTest, EraseFromMiddle) {
107 PriorityQueue<size_t> queue(kNumPriorities);
108 PriorityQueue<size_t>::Pointer pointers[kNumElements];
109
110 for (size_t i = 0; i < kNumElements; ++i) {
111 pointers[i] = queue.Insert(i, kPriorities[i]);
112 }
113
114 queue.Erase(pointers[2]);
115 queue.Erase(pointers[3]);
116
117 size_t expected_order[] = { 8, 1, 6, 0, 5, 4, 7 };
118
119 for (size_t i = 0; i < arraysize(expected_order); ++i) {
120 EXPECT_EQ(expected_order[i], queue.FirstMin().value());
121 queue.Erase(queue.FirstMin());
122 }
123 CheckEmpty(&queue);
124 }
125
126 } // namespace
127
128 } // namespace net
129
OLDNEW
« net/base/priority_queue.h ('K') | « net/base/priority_queue.h ('k') | net/net.gyp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698