blob: a33c0881b3f2ccfbcbb902debd06587f2e469412 [file] [log] [blame]
Ashlesh Gawande0b2897e2018-06-20 14:40:47 -05001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/*
Ashlesh Gawande5a895472020-01-25 18:07:32 -08003 * Copyright (c) 2014-2020, The University of Memphis
Ashlesh Gawande0b2897e2018-06-20 14:40:47 -05004 *
5 * This file is part of PSync.
6 * See AUTHORS.md for complete list of PSync authors and contributors.
7 *
8 * PSync is free software: you can redistribute it and/or modify it under the terms
Ashlesh Gawande0cf4b602019-01-18 15:58:17 -06009 * of the GNU Lesser General Public License as published by the Free Software Foundation,
Ashlesh Gawande0b2897e2018-06-20 14:40:47 -050010 * either version 3 of the License, or (at your option) any later version.
11 *
12 * PSync is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
13 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
Ashlesh Gawande0cf4b602019-01-18 15:58:17 -060014 * PURPOSE. See the GNU Lesser General Public License for more details.
Ashlesh Gawande0b2897e2018-06-20 14:40:47 -050015 *
Ashlesh Gawande0cf4b602019-01-18 15:58:17 -060016 * You should have received a copy of the GNU Lesser General Public License along with
Ashlesh Gawande0b2897e2018-06-20 14:40:47 -050017 * PSync, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
18 **/
19
Ashlesh Gawande78b94ad2018-12-13 15:29:19 -060020#include "PSync/detail/bloom-filter.hpp"
Ashlesh Gawande0b2897e2018-06-20 14:40:47 -050021
Davide Pesavento5b3cf762020-04-03 16:20:04 -040022#include "tests/boost-test.hpp"
23
Ashlesh Gawande0b2897e2018-06-20 14:40:47 -050024#include <ndn-cxx/name.hpp>
25
26namespace psync {
Davide Pesaventodb789562020-12-19 23:01:08 -050027namespace detail {
Ashlesh Gawande0b2897e2018-06-20 14:40:47 -050028
29BOOST_AUTO_TEST_SUITE(TestBloomFilter)
30
31BOOST_AUTO_TEST_CASE(Basic)
32{
33 BloomFilter bf(100, 0.001);
34
35 std::string insertName("/memphis");
36 bf.insert(insertName);
37 BOOST_CHECK(bf.contains(insertName));
38}
39
40BOOST_AUTO_TEST_CASE(NameAppendAndExtract)
41{
Davide Pesaventodb789562020-12-19 23:01:08 -050042 ndn::Name bfName("/test");
Ashlesh Gawande0b2897e2018-06-20 14:40:47 -050043 BloomFilter bf(100, 0.001);
44 bf.insert("/memphis");
Ashlesh Gawande0b2897e2018-06-20 14:40:47 -050045 bf.appendToName(bfName);
46
Davide Pesavento5b3cf762020-04-03 16:20:04 -040047 BloomFilter bfFromName(100, 0.001, bfName.at(-1));
Ashlesh Gawande0b2897e2018-06-20 14:40:47 -050048
Davide Pesavento5b3cf762020-04-03 16:20:04 -040049 BOOST_CHECK_EQUAL(bfName.at(1).toNumber(), 100);
50 BOOST_CHECK_EQUAL(bfName.at(2).toNumber(), 1);
Ashlesh Gawande0b2897e2018-06-20 14:40:47 -050051 BOOST_CHECK_EQUAL(bf, bfFromName);
52
Davide Pesavento5b3cf762020-04-03 16:20:04 -040053 BOOST_CHECK_THROW(BloomFilter(200, 0.001, bfName.at(-1)), std::runtime_error);
Ashlesh Gawande0b2897e2018-06-20 14:40:47 -050054}
55
56BOOST_AUTO_TEST_SUITE_END()
57
Davide Pesaventodb789562020-12-19 23:01:08 -050058} // namespace detail
Davide Pesavento5b3cf762020-04-03 16:20:04 -040059} // namespace psync