/* * Copyright (C) 2017 ScyllaDB */ /* * This file is part of Scylla. * * Scylla is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Scylla 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 * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with Scylla. If not, see . */ #define BOOST_TEST_MODULE core #include #include #include "utils/log_heap.hh" template struct node : public log_heap_hook { size_t v; node(size_t v) : v(v) {} }; template void test_with_options() { std::vector>> nodes; log_heap, opts> hist; BOOST_REQUIRE(hist.empty()); unsigned i = 0; for (; i < opts.min_size; ++i) { nodes.push_back(std::make_unique>(i)); hist.push(*nodes.back()); BOOST_REQUIRE(!hist.contains_above_min()); BOOST_REQUIRE(!hist.empty()); } for (; i <= opts.max_size; ++i) { nodes.push_back(std::make_unique>(i)); hist.push(*nodes.back()); BOOST_REQUIRE(hist.contains_above_min()); BOOST_REQUIRE(!hist.empty()); } size_t count = 0; // Check monotonicity of buckets size_t prev_key = 0; for (auto&& bucket : hist.buckets()) { size_t max_key = 0; for (auto&& t : bucket) { ++count; auto key = t.v; if (prev_key) { assert(key > prev_key); } max_key = std::max(max_key, key); } if (max_key) { prev_key = max_key; } } BOOST_REQUIRE(count == (opts.max_size + 1)); } extern constexpr log_heap_options opts1{(1 << 4) + 3, 3, (1 << 6) + 2}; extern constexpr log_heap_options opts2{(1 << 4) + 2, 1, (1 << 17) + 2}; extern constexpr log_heap_options opts3{(1 << 4) + 1, 0, (1 << 17) + 2}; extern constexpr log_heap_options opts4{(1 << 4) + 0, 3, (1 << 17)}; template<> size_t hist_key>(const node& n) { return n.v; } template<> size_t hist_key>(const node& n) { return n.v; } template<> size_t hist_key>(const node& n) { return n.v; } template<> size_t hist_key>(const node& n) { return n.v; } BOOST_AUTO_TEST_CASE(test_log_heap) { test_with_options(); test_with_options(); test_with_options(); test_with_options(); }