blob: 4d557bbb187d09315abc0e30dd2447c25e334154 [file] [log] [blame]
/*
* Copyright (C) 2017 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include "src/tracing/core/id_allocator.h"
#include "test/gtest_and_gmock.h"
namespace perfetto {
namespace {
TEST(IdAllocatorTest, IdAllocation) {
using IdType = uint32_t;
const IdType kMaxId = 1023;
IdAllocator<IdType> id_allocator(kMaxId);
for (int repetition = 0; repetition < 3; repetition++) {
std::set<IdType> ids;
for (IdType i = 1; i <= kMaxId; i++) {
auto id = id_allocator.Allocate();
EXPECT_NE(0u, id);
ASSERT_EQ(0u, ids.count(id));
ids.insert(id);
}
// A further call should fail as we exhausted IDs.
ASSERT_EQ(0u, id_allocator.Allocate());
// Removing one ID should be enough to make room for another one.
for (int i = 0; i < 3; i++) {
id_allocator.Free(42);
auto id = id_allocator.Allocate();
ASSERT_EQ(42u, id);
}
// Remove the IDs at the boundaries and saturate again.
id_allocator.Free(1);
id_allocator.Free(kMaxId);
ASSERT_EQ(kMaxId, id_allocator.Allocate());
ASSERT_EQ(1u, id_allocator.Allocate());
// Should be saturated again.
ASSERT_EQ(0u, id_allocator.Allocate());
// Release IDs in reverse order.
for (IdType i = 0; i < kMaxId; i++)
id_allocator.Free(kMaxId - i);
}
}
// Tests corner cases that might be caused by using all 2 ** sizeof(T) - 1 IDs.
TEST(IdAllocatorTest, IdAllocation_U8) {
IdAllocator<uint8_t> id_allocator(0xff);
for (size_t i = 0; i < 0xff; i++) {
uint8_t id = id_allocator.Allocate();
ASSERT_EQ(i + 1, id);
}
ASSERT_EQ(0u, id_allocator.Allocate());
id_allocator.Free(0xff);
ASSERT_EQ(0xff, id_allocator.Allocate());
}
} // namespace
} // namespace perfetto