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
|
// Copyright 2023 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "components/reporting/resources/resource_managed_buffer.h"
#include <array>
#include <cstdint>
#include <string>
#include "base/memory/scoped_refptr.h"
#include "base/task/thread_pool.h"
#include "base/test/task_environment.h"
#include "components/reporting/resources/resource_manager.h"
#include "components/reporting/util/status.h"
#include "components/reporting/util/status_macros.h"
#include "testing/gmock/include/gmock/gmock.h"
#include "testing/gtest/include/gtest/gtest.h"
using ::testing::AllOf;
using ::testing::Eq;
using ::testing::IsEmpty;
using ::testing::Not;
using ::testing::Property;
using ::testing::StrEq;
namespace reporting {
namespace {
class ResourceManagedBufferTest : public ::testing::Test {
protected:
void SetUp() override {
memory_resource_ =
base::MakeRefCounted<ResourceManager>(1u * 1024LLu); // 1 KiB
}
void TearDown() override { EXPECT_THAT(memory_resource_->GetUsed(), Eq(0u)); }
base::test::TaskEnvironment task_environment_;
scoped_refptr<ResourceManager> memory_resource_;
};
TEST_F(ResourceManagedBufferTest, SuccessfulAllocAndClear) {
ResourceManagedBuffer buffer(memory_resource_);
ASSERT_OK(buffer.Allocate(1024LLu));
EXPECT_THAT(buffer.size(), Eq(1024LLu));
EXPECT_THAT(buffer, Not(IsEmpty()));
buffer.Clear();
}
TEST_F(ResourceManagedBufferTest, SuccessfulAllocAndDestruct) {
ResourceManagedBuffer buffer(memory_resource_);
ASSERT_OK(buffer.Allocate(1024LLu));
EXPECT_THAT(buffer.size(), Eq(1024LLu));
EXPECT_THAT(buffer, Not(IsEmpty()));
}
TEST_F(ResourceManagedBufferTest, FailedAlloc) {
ResourceManagedBuffer buffer(memory_resource_);
const auto status = buffer.Allocate(2u * 1024LLu);
EXPECT_THAT(status,
AllOf(Property(&Status::code, Eq(error::RESOURCE_EXHAUSTED)),
Property(&Status::error_message,
StrEq("Not enough memory for the buffer"))));
EXPECT_THAT(buffer, IsEmpty());
}
TEST_F(ResourceManagedBufferTest, SuccessfulAllocAndFillIn) {
ResourceManagedBuffer buffer(memory_resource_);
ASSERT_OK(buffer.Allocate(1024LLu));
EXPECT_THAT(buffer.size(), Eq(1024LLu));
EXPECT_THAT(buffer, Not(IsEmpty()));
constexpr static std::array<char, 18> kData{"ABCDEF 0123456789"};
for (size_t i = 0; kData[i]; ++i) {
*buffer.at(512u + i) = kData[i];
}
EXPECT_THAT(std::string(buffer.at(512u), std::strlen(kData.data())),
StrEq(kData.data()));
}
TEST_F(ResourceManagedBufferTest, MultipleAllocations) {
ResourceManagedBuffer buffer(memory_resource_);
// Every time we allocate something, previous buffer is released.
for (int i = 0; i < 64; ++i) {
ASSERT_OK(buffer.Allocate(1024LLu));
EXPECT_THAT(buffer.size(), Eq(1024LLu));
EXPECT_THAT(buffer, Not(IsEmpty()));
}
}
} // namespace
} // namespace reporting
|