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