// Copyright (c) 2012 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include "net/base/priority_queue.h" #include "testing/gtest/include/gtest/gtest.h" namespace net { namespace { typedef PriorityQueue::Priority Priority; const Priority kPriorities[] = { 2, 1, 2, 0, 4, 3, 1, 4, 0 }; const Priority kNumPriorities = 5; // max(kPriorities) + 1 const size_t kNumElements = arraysize(kPriorities); const int kFirstMinOrder[kNumElements] = { 3, 8, 1, 6, 0, 2, 5, 4, 7 }; const int kLastMaxOrder[kNumElements] = { 7, 4, 5, 2, 0, 6, 1, 8, 3 }; const int kFirstMaxOrder[kNumElements] = { 4, 7, 5, 0, 2, 1, 6, 3, 8 }; const int kLastMinOrder[kNumElements] = { 8, 3, 6, 1, 2, 0, 5, 7, 4 }; class PriorityQueueTest : public testing::Test { protected: PriorityQueueTest() : queue_(kNumPriorities) {} virtual void SetUp() OVERRIDE { CheckEmpty(); for (size_t i = 0; i < kNumElements; ++i) { EXPECT_EQ(i, queue_.size()); pointers_[i] = queue_.Insert(static_cast(i), kPriorities[i]); } EXPECT_EQ(kNumElements, queue_.size()); } void CheckEmpty() { EXPECT_EQ(0u, queue_.size()); EXPECT_TRUE(queue_.FirstMin().is_null()); EXPECT_TRUE(queue_.LastMin().is_null()); EXPECT_TRUE(queue_.FirstMax().is_null()); EXPECT_TRUE(queue_.LastMax().is_null()); } PriorityQueue queue_; PriorityQueue::Pointer pointers_[kNumElements]; }; TEST_F(PriorityQueueTest, AddAndClear) { for (size_t i = 0; i < kNumElements; ++i) { EXPECT_EQ(kPriorities[i], pointers_[i].priority()); EXPECT_EQ(static_cast(i), pointers_[i].value()); } queue_.Clear(); CheckEmpty(); } TEST_F(PriorityQueueTest, FirstMinOrder) { for (size_t i = 0; i < kNumElements; ++i) { EXPECT_EQ(kNumElements - i, queue_.size()); // Also check Equals. EXPECT_TRUE(queue_.FirstMin().Equals(pointers_[kFirstMinOrder[i]])); EXPECT_EQ(kFirstMinOrder[i], queue_.FirstMin().value()); queue_.Erase(queue_.FirstMin()); } CheckEmpty(); } TEST_F(PriorityQueueTest, LastMinOrder) { for (size_t i = 0; i < kNumElements; ++i) { EXPECT_EQ(kLastMinOrder[i], queue_.LastMin().value()); queue_.Erase(queue_.LastMin()); } CheckEmpty(); } TEST_F(PriorityQueueTest, FirstMaxOrder) { for (size_t i = 0; i < kNumElements; ++i) { EXPECT_EQ(kFirstMaxOrder[i], queue_.FirstMax().value()); queue_.Erase(queue_.FirstMax()); } CheckEmpty(); } TEST_F(PriorityQueueTest, LastMaxOrder) { for (size_t i = 0; i < kNumElements; ++i) { EXPECT_EQ(kLastMaxOrder[i], queue_.LastMax().value()); queue_.Erase(queue_.LastMax()); } CheckEmpty(); } TEST_F(PriorityQueueTest, EraseFromMiddle) { queue_.Erase(pointers_[2]); queue_.Erase(pointers_[3]); int expected_order[] = { 8, 1, 6, 0, 5, 4, 7 }; for (size_t i = 0; i < arraysize(expected_order); ++i) { EXPECT_EQ(expected_order[i], queue_.FirstMin().value()); queue_.Erase(queue_.FirstMin()); } CheckEmpty(); } } // namespace } // namespace net