X-Git-Url: http://plrg.eecs.uci.edu/git/?a=blobdiff_plain;f=folly%2Ftest%2FHistogramTest.cpp;h=c2997a35ecdf5e55a44d18e24924d47a6298d884;hb=fa172175980b13569ba42008202a857af6e959dd;hp=8ddb6a380ee243904e586adb7794e221226ac8be;hpb=275ca94d04e44f28cfa411668eb1c1dd8db90b80;p=folly.git diff --git a/folly/test/HistogramTest.cpp b/folly/test/HistogramTest.cpp index 8ddb6a38..c2997a35 100644 --- a/folly/test/HistogramTest.cpp +++ b/folly/test/HistogramTest.cpp @@ -1,5 +1,5 @@ /* - * Copyright 2015 Facebook, Inc. + * Copyright 2017 Facebook, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -17,8 +17,7 @@ #include #include -#include -#include +#include using folly::Histogram; @@ -203,3 +202,22 @@ TEST(Histogram, TestDoubleWidthTooBig) { EXPECT_EQ(1, h.getBucketByIndex(2).count); EXPECT_EQ(3.0, h.getPercentileEstimate(0.5)); } + +// Test that we get counts right +TEST(Histogram, Counts) { + Histogram h(1, 0, 10); + EXPECT_EQ(12, h.getNumBuckets()); + EXPECT_EQ(0, h.computeTotalCount()); + + // Add one to each bucket, make sure the counts match + for (int32_t i = 0; i < 10; i++) { + h.addValue(i); + EXPECT_EQ(i+1, h.computeTotalCount()); + } + + // Add a lot to one bucket, make sure the counts still make sense + for (int32_t i = 0; i < 100; i++) { + h.addValue(0); + } + EXPECT_EQ(110, h.computeTotalCount()); +}