xref: /aosp_15_r20/external/libchrome/base/metrics/bucket_ranges_unittest.cc (revision 635a864187cb8b6c713ff48b7e790a6b21769273)
1*635a8641SAndroid Build Coastguard Worker // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2*635a8641SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*635a8641SAndroid Build Coastguard Worker // found in the LICENSE file.
4*635a8641SAndroid Build Coastguard Worker 
5*635a8641SAndroid Build Coastguard Worker #include "base/metrics/bucket_ranges.h"
6*635a8641SAndroid Build Coastguard Worker 
7*635a8641SAndroid Build Coastguard Worker #include <stdint.h>
8*635a8641SAndroid Build Coastguard Worker 
9*635a8641SAndroid Build Coastguard Worker #include "testing/gtest/include/gtest/gtest.h"
10*635a8641SAndroid Build Coastguard Worker 
11*635a8641SAndroid Build Coastguard Worker namespace base {
12*635a8641SAndroid Build Coastguard Worker namespace {
13*635a8641SAndroid Build Coastguard Worker 
TEST(BucketRangesTest,NormalSetup)14*635a8641SAndroid Build Coastguard Worker TEST(BucketRangesTest, NormalSetup) {
15*635a8641SAndroid Build Coastguard Worker   BucketRanges ranges(5);
16*635a8641SAndroid Build Coastguard Worker   ASSERT_EQ(5u, ranges.size());
17*635a8641SAndroid Build Coastguard Worker   ASSERT_EQ(4u, ranges.bucket_count());
18*635a8641SAndroid Build Coastguard Worker 
19*635a8641SAndroid Build Coastguard Worker   for (int i = 0; i < 5; ++i) {
20*635a8641SAndroid Build Coastguard Worker     EXPECT_EQ(0, ranges.range(i));
21*635a8641SAndroid Build Coastguard Worker   }
22*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(0u, ranges.checksum());
23*635a8641SAndroid Build Coastguard Worker 
24*635a8641SAndroid Build Coastguard Worker   ranges.set_range(3, 100);
25*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(100, ranges.range(3));
26*635a8641SAndroid Build Coastguard Worker }
27*635a8641SAndroid Build Coastguard Worker 
TEST(BucketRangesTest,Equals)28*635a8641SAndroid Build Coastguard Worker TEST(BucketRangesTest, Equals) {
29*635a8641SAndroid Build Coastguard Worker   // Compare empty ranges.
30*635a8641SAndroid Build Coastguard Worker   BucketRanges ranges1(3);
31*635a8641SAndroid Build Coastguard Worker   BucketRanges ranges2(3);
32*635a8641SAndroid Build Coastguard Worker   BucketRanges ranges3(5);
33*635a8641SAndroid Build Coastguard Worker 
34*635a8641SAndroid Build Coastguard Worker   EXPECT_TRUE(ranges1.Equals(&ranges2));
35*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(ranges1.Equals(&ranges3));
36*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(ranges2.Equals(&ranges3));
37*635a8641SAndroid Build Coastguard Worker 
38*635a8641SAndroid Build Coastguard Worker   // Compare full filled ranges.
39*635a8641SAndroid Build Coastguard Worker   ranges1.set_range(0, 0);
40*635a8641SAndroid Build Coastguard Worker   ranges1.set_range(1, 1);
41*635a8641SAndroid Build Coastguard Worker   ranges1.set_range(2, 2);
42*635a8641SAndroid Build Coastguard Worker   ranges1.set_checksum(100);
43*635a8641SAndroid Build Coastguard Worker   ranges2.set_range(0, 0);
44*635a8641SAndroid Build Coastguard Worker   ranges2.set_range(1, 1);
45*635a8641SAndroid Build Coastguard Worker   ranges2.set_range(2, 2);
46*635a8641SAndroid Build Coastguard Worker   ranges2.set_checksum(100);
47*635a8641SAndroid Build Coastguard Worker 
48*635a8641SAndroid Build Coastguard Worker   EXPECT_TRUE(ranges1.Equals(&ranges2));
49*635a8641SAndroid Build Coastguard Worker 
50*635a8641SAndroid Build Coastguard Worker   // Checksum does not match.
51*635a8641SAndroid Build Coastguard Worker   ranges1.set_checksum(99);
52*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(ranges1.Equals(&ranges2));
53*635a8641SAndroid Build Coastguard Worker   ranges1.set_checksum(100);
54*635a8641SAndroid Build Coastguard Worker 
55*635a8641SAndroid Build Coastguard Worker   // Range does not match.
56*635a8641SAndroid Build Coastguard Worker   ranges1.set_range(1, 3);
57*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(ranges1.Equals(&ranges2));
58*635a8641SAndroid Build Coastguard Worker }
59*635a8641SAndroid Build Coastguard Worker 
TEST(BucketRangesTest,Checksum)60*635a8641SAndroid Build Coastguard Worker TEST(BucketRangesTest, Checksum) {
61*635a8641SAndroid Build Coastguard Worker   BucketRanges ranges(3);
62*635a8641SAndroid Build Coastguard Worker   ranges.set_range(0, 0);
63*635a8641SAndroid Build Coastguard Worker   ranges.set_range(1, 1);
64*635a8641SAndroid Build Coastguard Worker   ranges.set_range(2, 2);
65*635a8641SAndroid Build Coastguard Worker 
66*635a8641SAndroid Build Coastguard Worker   ranges.ResetChecksum();
67*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(289217253u, ranges.checksum());
68*635a8641SAndroid Build Coastguard Worker 
69*635a8641SAndroid Build Coastguard Worker   ranges.set_range(2, 3);
70*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(ranges.HasValidChecksum());
71*635a8641SAndroid Build Coastguard Worker 
72*635a8641SAndroid Build Coastguard Worker   ranges.ResetChecksum();
73*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(2843835776u, ranges.checksum());
74*635a8641SAndroid Build Coastguard Worker   EXPECT_TRUE(ranges.HasValidChecksum());
75*635a8641SAndroid Build Coastguard Worker }
76*635a8641SAndroid Build Coastguard Worker 
77*635a8641SAndroid Build Coastguard Worker // Table was generated similarly to sample code for CRC-32 given on:
78*635a8641SAndroid Build Coastguard Worker // http://www.w3.org/TR/PNG/#D-CRCAppendix.
TEST(BucketRangesTest,Crc32TableTest)79*635a8641SAndroid Build Coastguard Worker TEST(BucketRangesTest, Crc32TableTest) {
80*635a8641SAndroid Build Coastguard Worker   for (int i = 0; i < 256; ++i) {
81*635a8641SAndroid Build Coastguard Worker     uint32_t checksum = i;
82*635a8641SAndroid Build Coastguard Worker     for (int j = 0; j < 8; ++j) {
83*635a8641SAndroid Build Coastguard Worker       const uint32_t kReversedPolynomial = 0xedb88320L;
84*635a8641SAndroid Build Coastguard Worker       if (checksum & 1)
85*635a8641SAndroid Build Coastguard Worker         checksum = kReversedPolynomial ^ (checksum >> 1);
86*635a8641SAndroid Build Coastguard Worker       else
87*635a8641SAndroid Build Coastguard Worker         checksum >>= 1;
88*635a8641SAndroid Build Coastguard Worker     }
89*635a8641SAndroid Build Coastguard Worker     EXPECT_EQ(kCrcTable[i], checksum);
90*635a8641SAndroid Build Coastguard Worker   }
91*635a8641SAndroid Build Coastguard Worker }
92*635a8641SAndroid Build Coastguard Worker 
93*635a8641SAndroid Build Coastguard Worker }  // namespace
94*635a8641SAndroid Build Coastguard Worker }  // namespace base
95