summaryrefslogtreecommitdiff
path: root/src/mongo/util/histogram_test.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/mongo/util/histogram_test.cpp')
-rw-r--r--src/mongo/util/histogram_test.cpp169
1 files changed, 0 insertions, 169 deletions
diff --git a/src/mongo/util/histogram_test.cpp b/src/mongo/util/histogram_test.cpp
deleted file mode 100644
index 2e883335b6a..00000000000
--- a/src/mongo/util/histogram_test.cpp
+++ /dev/null
@@ -1,169 +0,0 @@
-/**
- * Copyright (C) 2022-present MongoDB, Inc.
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the Server Side Public License, version 1,
- * as published by MongoDB, Inc.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * Server Side Public License for more details.
- *
- * You should have received a copy of the Server Side Public License
- * along with this program. If not, see
- * <http://www.mongodb.com/licensing/server-side-public-license>.
- *
- * As a special exception, the copyright holders give permission to link the
- * code of portions of this program with the OpenSSL library under certain
- * conditions as described in each individual source file and distribute
- * linked combinations including the program with the OpenSSL library. You
- * must comply with the Server Side Public License in all respects for
- * all of the code used other than as permitted herein. If you modify file(s)
- * with this exception, you may extend this exception to your version of the
- * file(s), but you are not obligated to do so. If you do not wish to do so,
- * delete this exception statement from your version. If you delete this
- * exception statement from all source files in the program, then also delete
- * it in the license file.
- */
-
-#include "mongo/util/histogram.h"
-
-#include <boost/optional.hpp>
-
-#include "mongo/unittest/assert_that.h"
-#include "mongo/unittest/unittest.h"
-
-namespace mongo {
-
-namespace {
-
-using namespace unittest::match;
-using namespace std::literals;
-
-class HistogramTest : public unittest::Test {
-public:
- template <typename T>
- struct BucketSpec {
- int64_t count;
- boost::optional<T> lower, upper;
-
- friend bool operator==(const BucketSpec& a, const BucketSpec& b) {
- auto lens = [](auto&& x) { return std::tie(x.count, x.lower, x.upper); };
- return lens(a) == lens(b);
- }
-
- friend std::ostream& operator<<(std::ostream& os, const BucketSpec& b) {
- os << "count: " << b.count;
- if (b.lower)
- os << ", lower: " << *b.lower;
- if (b.upper)
- os << ", upper: " << *b.upper;
- return os;
- }
- };
-
- template <typename T>
- boost::optional<T> ptrToOpt(const T* p) {
- return p ? boost::optional<T>(*p) : boost::none;
- }
-
- template <typename T>
- auto snapshot(const Histogram<T>& h) {
- std::vector<BucketSpec<T>> r;
- std::transform(h.begin(), h.end(), std::back_inserter(r), [&](auto&& b) {
- return BucketSpec<T>{b.count, ptrToOpt(b.lower), ptrToOpt(b.upper)};
- });
- return r;
- }
-};
-
-TEST_F(HistogramTest, CountsIncrementedAndStored) {
- Histogram<int64_t> hist({0, 5, 8, 12});
- for (int64_t i = 0; i < 15; ++i)
- hist.increment(i);
- std::vector<BucketSpec<int64_t>> expected = {
- {0, {}, 0}, {5, 0, 5}, {3, 5, 8}, {4, 8, 12}, {3, 12, {}}};
-
- ASSERT_THAT(snapshot(hist), Eq(expected));
-}
-
-TEST_F(HistogramTest, CountsIncrementedInSmallestBucket) {
- Histogram<int64_t> hist({5, 8, 12});
- for (int64_t i = 0; i < 5; ++i)
- hist.increment(i);
- std::vector<BucketSpec<int64_t>> expected = {{5, {}, 5}, {0, 5, 8}, {0, 8, 12}, {0, 12, {}}};
-
- ASSERT_THAT(snapshot(hist), Eq(expected));
-}
-
-TEST_F(HistogramTest, CountsIncrementedAtPartition) {
- std::vector<int64_t> origPartitions = {5, 8, 12};
- Histogram<int64_t> hist(origPartitions);
- for (auto& p : origPartitions)
- hist.increment(p);
- std::vector<BucketSpec<int64_t>> expected = {{0, {}, 5}, {1, 5, 8}, {1, 8, 12}, {1, 12, {}}};
-
- ASSERT_THAT(snapshot(hist), Eq(expected));
-}
-
-TEST_F(HistogramTest, NegativeValuesIncrementBuckets) {
- Histogram<int64_t> hist({-12, -8, 5});
- for (int64_t i = -15; i < 10; ++i)
- hist.increment(i);
- std::vector<BucketSpec<int64_t>> expected = {
- {3, {}, -12}, {4, -12, -8}, {13, -8, 5}, {5, 5, {}}};
-
- ASSERT_THAT(snapshot(hist), Eq(expected));
-}
-
-TEST_F(HistogramTest, DurationCountsIncrementedAndStored) {
- Histogram<Milliseconds> hist(
- {Milliseconds{0}, Milliseconds{5}, Milliseconds{8}, Milliseconds{12}});
- for (int64_t i = 0; i < 15; ++i)
- hist.increment(Milliseconds{i});
- std::vector<BucketSpec<Milliseconds>> expected = {{0, {}, Milliseconds{0}},
- {5, Milliseconds{0}, Milliseconds{5}},
- {3, Milliseconds{5}, Milliseconds{8}},
- {4, Milliseconds{8}, Milliseconds{12}},
- {3, Milliseconds{12}, {}}};
-
- ASSERT_THAT(snapshot(hist), Eq(expected));
-}
-
-TEST_F(HistogramTest, StringCountsIncrementedAndStoredByLength) {
- Histogram<std::string> hist({"", "aa", "aaaaa", "aaaaaaaaa"});
- for (int64_t i = 0; i < 12; ++i)
- hist.increment(std::string(i, 'a'));
- std::vector<BucketSpec<std::string>> expected = {{0, {}, ""s},
- {2, ""s, "aa"s},
- {3, "aa"s, "aaaaa"s},
- {4, "aaaaa"s, "aaaaaaaaa"s},
- {3, "aaaaaaaaa"s, {}}};
-
- ASSERT_THAT(snapshot(hist), Eq(expected));
-}
-
-TEST_F(HistogramTest, StringCountsIncrementedAndStoredByChar) {
- Histogram<std::string> hist({"a", "h", "r", "z"});
- for (char c = 'a'; c < 'a' + 25; ++c) {
- hist.increment(std::string{c});
- }
- std::vector<BucketSpec<std::string>> expected = {
- {0, {}, "a"s}, {7, "a"s, "h"s}, {10, "h"s, "r"s}, {8, "r"s, "z"s}, {0, "z"s, {}}};
-
- ASSERT_THAT(snapshot(hist), Eq(expected));
-}
-
-TEST_F(HistogramTest, SizeTCountsIncrementedAndStored) {
- Histogram<size_t> hist({0, 5, 8, 12});
- for (size_t i = 0; i < 15; ++i)
- hist.increment(i);
- std::vector<BucketSpec<size_t>> expected = {
- {0, {}, 0}, {5, 0, 5}, {3, 5, 8}, {4, 8, 12}, {3, 12, {}}};
-
- ASSERT_THAT(snapshot(hist), Eq(expected));
-}
-
-} // namespace
-} // namespace mongo