1 // Copyright 2019 The Chromium Authors
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #include "base/android/reached_addresses_bitset.h"
9 #include "testing/gmock/include/gmock/gmock.h"
10 #include "testing/gtest/include/gtest/gtest.h"
15 using testing::ElementsAre;
16 using testing::ElementsAreArray;
18 constexpr uintptr_t kStartAddress = 0x1000;
19 constexpr uintptr_t kEndAddress = 0x2000;
20 constexpr size_t kStorageSize = 512;
22 class ReachedAddressesBitsetTest : public testing::Test {
24 ReachedAddressesBitsetTest()
25 : bitset_(kStartAddress, kEndAddress, storage_, kStorageSize) {
26 memset(storage_, 0, kStorageSize * sizeof(uint32_t));
27 EXPECT_TRUE(bitset()->GetReachedOffsets().empty());
30 ReachedAddressesBitset* bitset() { return &bitset_; }
33 std::atomic<uint32_t> storage_[kStorageSize];
34 ReachedAddressesBitset bitset_;
37 TEST_F(ReachedAddressesBitsetTest, RecordStartAddress) {
38 bitset()->RecordAddress(kStartAddress);
39 EXPECT_THAT(bitset()->GetReachedOffsets(), ElementsAre(0));
42 TEST_F(ReachedAddressesBitsetTest, RecordLastAddress) {
43 bitset()->RecordAddress(kEndAddress - 4);
44 EXPECT_THAT(bitset()->GetReachedOffsets(),
45 ElementsAre(kEndAddress - 4 - kStartAddress));
48 TEST_F(ReachedAddressesBitsetTest, RecordAddressOutsideOfRange_Small) {
49 bitset()->RecordAddress(kStartAddress - 4);
50 EXPECT_THAT(bitset()->GetReachedOffsets(), ElementsAre());
53 TEST_F(ReachedAddressesBitsetTest, RecordAddressOutsideOfRange_Large) {
54 bitset()->RecordAddress(kEndAddress);
55 EXPECT_THAT(bitset()->GetReachedOffsets(), ElementsAre());
58 TEST_F(ReachedAddressesBitsetTest, RecordUnalignedAddresses) {
59 constexpr uint32_t aligned_offset = 0x100;
60 bitset()->RecordAddress(kStartAddress + aligned_offset + 1);
61 bitset()->RecordAddress(kStartAddress + aligned_offset + 2);
62 bitset()->RecordAddress(kStartAddress + aligned_offset + 3);
63 EXPECT_THAT(bitset()->GetReachedOffsets(), ElementsAre(aligned_offset));
66 TEST_F(ReachedAddressesBitsetTest, FillBitsetOneByOne) {
67 std::vector<uint32_t> expected_offsets;
68 for (uintptr_t address = kStartAddress; address < kEndAddress; address += 4) {
69 bitset()->RecordAddress(address);
70 expected_offsets.push_back(address - kStartAddress);
71 ASSERT_THAT(bitset()->GetReachedOffsets(),
72 ElementsAreArray(expected_offsets))
73 << "Last added: " << address;
77 } // namespace android