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 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
|
// Copyright 2021 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "third_party/blink/renderer/modules/ad_auction/join_leave_queue.h"
#include <memory>
#include <vector>
#include "base/functional/bind.h"
#include "testing/gmock/include/gmock/gmock.h"
#include "testing/gtest/include/gtest/gtest.h"
#include "third_party/blink/renderer/platform/testing/task_environment.h"
#include "third_party/blink/renderer/platform/wtf/functional.h"
namespace blink {
class JoinLeaveQueueTest : public testing::Test {
public:
JoinLeaveQueueTest()
: queue_(std::make_unique<JoinLeaveQueue<int>>(
/*max_active=*/2,
WTF::BindRepeating(&JoinLeaveQueueTest::Start,
base::Unretained(this)))) {}
protected:
void Start(int&& i) { start_order_.push_back(i); }
test::TaskEnvironment task_environment_;
std::unique_ptr<JoinLeaveQueue<int>> queue_;
std::vector<int> start_order_;
};
TEST_F(JoinLeaveQueueTest, Basic) {
EXPECT_EQ(0, queue_->num_active_for_testing());
queue_->Enqueue(0);
EXPECT_THAT(start_order_, testing::ElementsAre(0));
EXPECT_EQ(1, queue_->num_active_for_testing());
queue_->Enqueue(1);
EXPECT_THAT(start_order_, testing::ElementsAre(0, 1));
EXPECT_EQ(2, queue_->num_active_for_testing());
queue_->OnComplete();
queue_->OnComplete();
EXPECT_THAT(start_order_, testing::ElementsAre(0, 1));
EXPECT_EQ(0, queue_->num_active_for_testing());
}
TEST_F(JoinLeaveQueueTest, ExceedsLimit) {
queue_->Enqueue(0);
queue_->Enqueue(1);
queue_->Enqueue(2);
queue_->Enqueue(3);
queue_->Enqueue(4);
EXPECT_THAT(start_order_, testing::ElementsAre(0, 1));
EXPECT_EQ(2, queue_->num_active_for_testing());
queue_->OnComplete();
EXPECT_THAT(start_order_, testing::ElementsAre(0, 1, 2));
EXPECT_EQ(2, queue_->num_active_for_testing());
queue_->OnComplete();
EXPECT_THAT(start_order_, testing::ElementsAre(0, 1, 2, 3));
EXPECT_EQ(2, queue_->num_active_for_testing());
queue_->OnComplete();
EXPECT_THAT(start_order_, testing::ElementsAre(0, 1, 2, 3, 4));
EXPECT_EQ(2, queue_->num_active_for_testing());
queue_->OnComplete();
EXPECT_THAT(start_order_, testing::ElementsAre(0, 1, 2, 3, 4));
EXPECT_EQ(1, queue_->num_active_for_testing());
queue_->OnComplete();
EXPECT_THAT(start_order_, testing::ElementsAre(0, 1, 2, 3, 4));
EXPECT_EQ(0, queue_->num_active_for_testing());
}
TEST_F(JoinLeaveQueueTest, DestroyedWithRequestsQueued) {
queue_->Enqueue(0);
queue_->Enqueue(1);
queue_->Enqueue(2);
queue_->Enqueue(3);
EXPECT_THAT(start_order_, testing::ElementsAre(0, 1));
EXPECT_EQ(2, queue_->num_active_for_testing());
queue_.reset();
EXPECT_THAT(start_order_, testing::ElementsAre(0, 1));
}
} // namespace blink
|