Sha256: f5b7f32f29c6349c3e22018034ff18a11dd2cc36dcae6d59f2a7036174bb58ea

Contents?: true

Size: 1.75 KB

Versions: 8

Compression:

Stored size: 1.75 KB

Contents

/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */

#include <catch2/catch.hpp>

#include <reverse_purge_hash_map.hpp>

namespace datasketches {

TEST_CASE("reverse purge hash map: empty", "[frequent_items_sketch]") {
  reverse_purge_hash_map<int> map(3, 3, std::equal_to<int>(), std::allocator<int>());
  REQUIRE(map.get_num_active() == 0);
  REQUIRE(map.get_lg_cur_size() == 3);  // static_cast<uint8_t>(3)
}

TEST_CASE("reverse purge hash map: one item", "[frequent_items_sketch]") {
  reverse_purge_hash_map<int> map(3, 3, std::equal_to<int>(), std::allocator<int>());
  map.adjust_or_insert(1, 1);
  REQUIRE(map.get_num_active() == 1);
  REQUIRE(map.get(1) == 1);
}

TEST_CASE("reverse purge hash map: iterator", "[frequent_items_sketch]") {
  reverse_purge_hash_map<int> map(3, 4, std::equal_to<int>(), std::allocator<int>());
  for (int i = 0; i < 11; i++) map.adjust_or_insert(i, 1); // this should fit with no purge
  uint64_t sum = 0;
  for (auto it: map) sum += it.second;
  REQUIRE(sum == 11);
}

} /* namespace datasketches */

Version data entries

8 entries across 8 versions & 1 rubygems

Version Path
datasketches-0.4.4 vendor/datasketches-cpp/fi/test/reverse_purge_hash_map_test.cpp
datasketches-0.4.3 vendor/datasketches-cpp/fi/test/reverse_purge_hash_map_test.cpp
datasketches-0.4.2 vendor/datasketches-cpp/fi/test/reverse_purge_hash_map_test.cpp
datasketches-0.4.1 vendor/datasketches-cpp/fi/test/reverse_purge_hash_map_test.cpp
datasketches-0.4.0 vendor/datasketches-cpp/fi/test/reverse_purge_hash_map_test.cpp
datasketches-0.3.2 vendor/datasketches-cpp/fi/test/reverse_purge_hash_map_test.cpp
datasketches-0.3.1 vendor/datasketches-cpp/fi/test/reverse_purge_hash_map_test.cpp
datasketches-0.3.0 vendor/datasketches-cpp/fi/test/reverse_purge_hash_map_test.cpp