OLD | NEW |
(Empty) | |
| 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. |
| 4 |
| 5 #include "net/disk_cache/bitmap.h" |
| 6 #include "testing/gtest/include/gtest/gtest.h" |
| 7 |
| 8 TEST(BitmapTest, OverAllocate) { |
| 9 // Test that we don't over allocate on boundaries. |
| 10 disk_cache::Bitmap map32(32, false); |
| 11 EXPECT_EQ(1, map32.ArraySize()); |
| 12 |
| 13 disk_cache::Bitmap map64(64, false); |
| 14 EXPECT_EQ(2, map64.ArraySize()); |
| 15 } |
| 16 |
| 17 TEST(BitmapTest, DefaultConstructor) { |
| 18 // Verify that the default constructor doesn't allocate a bitmap. |
| 19 disk_cache::Bitmap map; |
| 20 EXPECT_EQ(0, map.Size()); |
| 21 EXPECT_EQ(0, map.ArraySize()); |
| 22 EXPECT_TRUE(NULL == map.GetMap()); |
| 23 } |
| 24 |
| 25 TEST(BitmapTest, Basics) { |
| 26 disk_cache::Bitmap bitmap(80, true); |
| 27 const uint32 kValue = 0x74f10060; |
| 28 |
| 29 // Test proper allocation size. |
| 30 EXPECT_EQ(80, bitmap.Size()); |
| 31 EXPECT_EQ(3, bitmap.ArraySize()); |
| 32 |
| 33 // Test Set/GetMapElement. |
| 34 EXPECT_EQ(0U, bitmap.GetMapElement(1)); |
| 35 bitmap.SetMapElement(1, kValue); |
| 36 EXPECT_EQ(kValue, bitmap.GetMapElement(1)); |
| 37 |
| 38 // Test Set/Get. |
| 39 EXPECT_TRUE(bitmap.Get(48)); |
| 40 EXPECT_FALSE(bitmap.Get(49)); |
| 41 EXPECT_FALSE(bitmap.Get(50)); |
| 42 bitmap.Set(49, true); |
| 43 EXPECT_TRUE(bitmap.Get(48)); |
| 44 EXPECT_TRUE(bitmap.Get(49)); |
| 45 EXPECT_FALSE(bitmap.Get(50)); |
| 46 bitmap.Set(49, false); |
| 47 EXPECT_TRUE(bitmap.Get(48)); |
| 48 EXPECT_FALSE(bitmap.Get(49)); |
| 49 EXPECT_FALSE(bitmap.Get(50)); |
| 50 |
| 51 for (int i = 0; i < 80; i++) |
| 52 bitmap.Set(i, (i % 7) == 0); |
| 53 for (int i = 0; i < 80; i++) |
| 54 EXPECT_EQ(bitmap.Get(i), (i % 7) == 0); |
| 55 } |
| 56 |
| 57 TEST(BitmapTest, Toggle) { |
| 58 static const int kSize = 100; |
| 59 disk_cache::Bitmap map(kSize, true); |
| 60 for (int i = 0; i < 100; i += 3) |
| 61 map.Toggle(i); |
| 62 for (int i = 0; i < 100; i += 9) |
| 63 map.Toggle(i); |
| 64 for (int i = 0; i < 100; ++i) |
| 65 EXPECT_EQ((i % 3 == 0) && (i % 9 != 0), map.Get(i)); |
| 66 } |
| 67 |
| 68 TEST(BitmapTest, Resize) { |
| 69 const int kSize1 = 50; |
| 70 const int kSize2 = 100; |
| 71 const int kSize3 = 30; |
| 72 disk_cache::Bitmap map(kSize1, true); |
| 73 map.Resize(kSize1, true); |
| 74 EXPECT_EQ(kSize1, map.Size()); |
| 75 EXPECT_FALSE(map.Get(0)); |
| 76 EXPECT_FALSE(map.Get(kSize1 - 1)); |
| 77 |
| 78 map.Resize(kSize2, true); |
| 79 EXPECT_FALSE(map.Get(kSize1 - 1)); |
| 80 EXPECT_FALSE(map.Get(kSize1)); |
| 81 EXPECT_FALSE(map.Get(kSize2 - 1)); |
| 82 EXPECT_EQ(kSize2, map.Size()); |
| 83 |
| 84 map.Resize(kSize3, true); |
| 85 EXPECT_FALSE(map.Get(kSize3 - 1)); |
| 86 EXPECT_EQ(kSize3, map.Size()); |
| 87 } |
| 88 |
| 89 TEST(BitmapTest, Map) { |
| 90 // Tests Set/GetMap and the constructor that takes an array. |
| 91 const int kMapSize = 80; |
| 92 char local_map[kMapSize]; |
| 93 for (int i = 0; i < kMapSize; i++) |
| 94 local_map[i] = static_cast<char>(i); |
| 95 |
| 96 disk_cache::Bitmap bitmap(kMapSize * 8, false); |
| 97 bitmap.SetMap(reinterpret_cast<uint32*>(local_map), kMapSize / 4); |
| 98 for (int i = 0; i < kMapSize; i++) { |
| 99 if (i % 2) |
| 100 EXPECT_TRUE(bitmap.Get(i * 8)); |
| 101 else |
| 102 EXPECT_FALSE(bitmap.Get(i * 8)); |
| 103 } |
| 104 |
| 105 EXPECT_EQ(0, memcmp(local_map, bitmap.GetMap(), kMapSize)); |
| 106 |
| 107 // Now let's create a bitmap that shares local_map as storage. |
| 108 disk_cache::Bitmap bitmap2(reinterpret_cast<uint32*>(local_map), |
| 109 kMapSize * 8, kMapSize / 4); |
| 110 EXPECT_EQ(0, memcmp(local_map, bitmap2.GetMap(), kMapSize)); |
| 111 |
| 112 local_map[kMapSize / 2] = 'a'; |
| 113 EXPECT_EQ(0, memcmp(local_map, bitmap2.GetMap(), kMapSize)); |
| 114 EXPECT_NE(0, memcmp(local_map, bitmap.GetMap(), kMapSize)); |
| 115 } |
| 116 |
| 117 TEST(BitmapTest, SetAll) { |
| 118 // Tests SetAll and Clear. |
| 119 const int kMapSize = 80; |
| 120 char ones[kMapSize]; |
| 121 char zeros[kMapSize]; |
| 122 memset(ones, 0xff, kMapSize); |
| 123 memset(zeros, 0, kMapSize); |
| 124 |
| 125 disk_cache::Bitmap map(kMapSize * 8, true); |
| 126 EXPECT_EQ(0, memcmp(zeros, map.GetMap(), kMapSize)); |
| 127 map.SetAll(true); |
| 128 EXPECT_EQ(0, memcmp(ones, map.GetMap(), kMapSize)); |
| 129 map.SetAll(false); |
| 130 EXPECT_EQ(0, memcmp(zeros, map.GetMap(), kMapSize)); |
| 131 map.SetAll(true); |
| 132 map.Clear(); |
| 133 EXPECT_EQ(0, memcmp(zeros, map.GetMap(), kMapSize)); |
| 134 } |
| 135 |
| 136 TEST(BitmapTest, Range) { |
| 137 // Tests SetRange() and TestRange(). |
| 138 disk_cache::Bitmap map(100, true); |
| 139 EXPECT_FALSE(map.TestRange(0, 100, true)); |
| 140 map.Set(50, true); |
| 141 EXPECT_TRUE(map.TestRange(0, 100, true)); |
| 142 |
| 143 map.SetAll(false); |
| 144 EXPECT_FALSE(map.TestRange(0, 1, true)); |
| 145 EXPECT_FALSE(map.TestRange(30, 31, true)); |
| 146 EXPECT_FALSE(map.TestRange(98, 99, true)); |
| 147 EXPECT_FALSE(map.TestRange(99, 100, true)); |
| 148 EXPECT_FALSE(map.TestRange(0, 100, true)); |
| 149 |
| 150 EXPECT_TRUE(map.TestRange(0, 1, false)); |
| 151 EXPECT_TRUE(map.TestRange(31, 32, false)); |
| 152 EXPECT_TRUE(map.TestRange(32, 33, false)); |
| 153 EXPECT_TRUE(map.TestRange(99, 100, false)); |
| 154 EXPECT_TRUE(map.TestRange(0, 32, false)); |
| 155 |
| 156 map.SetRange(11, 21, true); |
| 157 for (int i = 0; i < 100; i++) |
| 158 EXPECT_EQ(map.Get(i), (i >= 11) && (i < 21)); |
| 159 |
| 160 EXPECT_TRUE(map.TestRange(0, 32, true)); |
| 161 EXPECT_TRUE(map.TestRange(0, 100, true)); |
| 162 EXPECT_TRUE(map.TestRange(11, 21, true)); |
| 163 EXPECT_TRUE(map.TestRange(15, 16, true)); |
| 164 EXPECT_TRUE(map.TestRange(5, 12, true)); |
| 165 EXPECT_TRUE(map.TestRange(5, 11, false)); |
| 166 EXPECT_TRUE(map.TestRange(20, 60, true)); |
| 167 EXPECT_TRUE(map.TestRange(21, 60, false)); |
| 168 |
| 169 map.SetAll(true); |
| 170 EXPECT_FALSE(map.TestRange(0, 100, false)); |
| 171 |
| 172 map.SetRange(70, 99, false); |
| 173 EXPECT_TRUE(map.TestRange(69, 99, false)); |
| 174 EXPECT_TRUE(map.TestRange(70, 100, false)); |
| 175 EXPECT_FALSE(map.TestRange(70, 99, true)); |
| 176 } |
| 177 |
| 178 TEST(BitmapTest, FindNextSetBitBeforeLimit) { |
| 179 // Test FindNextSetBitBeforeLimit. Only check bits from 111 to 277 (limit |
| 180 // bit == 278). Should find all multiples of 27 in that range. |
| 181 disk_cache::Bitmap map(500, true); |
| 182 for (int i = 0; i < 500; i++) |
| 183 map.Set(i, (i % 27) == 0); |
| 184 |
| 185 int find_me = 135; // First one expected. |
| 186 for (int index = 111; map.FindNextSetBitBeforeLimit(&index, 278); |
| 187 ++index) { |
| 188 EXPECT_EQ(index, find_me); |
| 189 find_me += 27; |
| 190 } |
| 191 EXPECT_EQ(find_me, 297); // The next find_me after 278. |
| 192 } |
| 193 |
| 194 TEST(BitmapTest, FindNextSetBitBeforeLimitAligned) { |
| 195 // Test FindNextSetBitBeforeLimit on aligned scans. |
| 196 disk_cache::Bitmap map(256, true); |
| 197 for (int i = 0; i < 256; i++) |
| 198 map.Set(i, (i % 32) == 0); |
| 199 for (int i = 0; i < 256; i += 32) { |
| 200 int index = i + 1; |
| 201 EXPECT_FALSE(map.FindNextSetBitBeforeLimit(&index, i + 32)); |
| 202 } |
| 203 } |
| 204 |
| 205 TEST(BitmapTest, FindNextSetBit) { |
| 206 // Test FindNextSetBit. Check all bits in map. Should find multiples |
| 207 // of 7 from 0 to 98. |
| 208 disk_cache::Bitmap map(100, true); |
| 209 for (int i = 0; i < 100; i++) |
| 210 map.Set(i, (i % 7) == 0); |
| 211 |
| 212 int find_me = 0; // First one expected. |
| 213 for (int index = 0; map.FindNextSetBit(&index); ++index) { |
| 214 EXPECT_EQ(index, find_me); |
| 215 find_me += 7; |
| 216 } |
| 217 EXPECT_EQ(find_me, 105); // The next find_me after 98. |
| 218 } |
| 219 |
| 220 TEST(BitmapTest, FindNextBit) { |
| 221 // Almost the same test as FindNextSetBit, but find zeros instead of ones. |
| 222 disk_cache::Bitmap map(100, false); |
| 223 map.SetAll(true); |
| 224 for (int i = 0; i < 100; i++) |
| 225 map.Set(i, (i % 7) != 0); |
| 226 |
| 227 int find_me = 0; // First one expected. |
| 228 for (int index = 0; map.FindNextBit(&index, 100, false); ++index) { |
| 229 EXPECT_EQ(index, find_me); |
| 230 find_me += 7; |
| 231 } |
| 232 EXPECT_EQ(find_me, 105); // The next find_me after 98. |
| 233 } |
| 234 |
| 235 TEST(BitmapTest, SimpleFindBits) { |
| 236 disk_cache::Bitmap bitmap(64, true); |
| 237 bitmap.SetMapElement(0, 0x7ff10060); |
| 238 |
| 239 // Bit at index off. |
| 240 int index = 0; |
| 241 EXPECT_EQ(5, bitmap.FindBits(&index, 63, false)); |
| 242 EXPECT_EQ(0, index); |
| 243 |
| 244 EXPECT_EQ(2, bitmap.FindBits(&index, 63, true)); |
| 245 EXPECT_EQ(5, index); |
| 246 |
| 247 index = 0; |
| 248 EXPECT_EQ(2, bitmap.FindBits(&index, 63, true)); |
| 249 EXPECT_EQ(5, index); |
| 250 |
| 251 index = 6; |
| 252 EXPECT_EQ(9, bitmap.FindBits(&index, 63, false)); |
| 253 EXPECT_EQ(7, index); |
| 254 |
| 255 // Bit at index on. |
| 256 index = 16; |
| 257 EXPECT_EQ(1, bitmap.FindBits(&index, 63, true)); |
| 258 EXPECT_EQ(16, index); |
| 259 |
| 260 index = 17; |
| 261 EXPECT_EQ(11, bitmap.FindBits(&index, 63, true)); |
| 262 EXPECT_EQ(20, index); |
| 263 |
| 264 index = 31; |
| 265 EXPECT_EQ(0, bitmap.FindBits(&index, 63, true)); |
| 266 EXPECT_EQ(31, index); |
| 267 |
| 268 // With a limit. |
| 269 index = 8; |
| 270 EXPECT_EQ(0, bitmap.FindBits(&index, 16, true)); |
| 271 } |
| 272 |
| 273 TEST(BitmapTest, MultiWordFindBits) { |
| 274 disk_cache::Bitmap bitmap(500, true); |
| 275 bitmap.SetMapElement(10, 0xff00); |
| 276 |
| 277 int index = 0; |
| 278 EXPECT_EQ(0, bitmap.FindBits(&index, 300, true)); |
| 279 |
| 280 EXPECT_EQ(8, bitmap.FindBits(&index, 500, true)); |
| 281 EXPECT_EQ(328, index); |
| 282 |
| 283 bitmap.SetMapElement(10, 0xff000000); |
| 284 bitmap.SetMapElement(11, 0xff); |
| 285 |
| 286 index = 0; |
| 287 EXPECT_EQ(16, bitmap.FindBits(&index, 500, true)); |
| 288 EXPECT_EQ(344, index); |
| 289 |
| 290 index = 0; |
| 291 EXPECT_EQ(4, bitmap.FindBits(&index, 348, true)); |
| 292 EXPECT_EQ(344, index); |
| 293 } |
OLD | NEW |