blob: 12be825fe27f2cc68c6dbd1e11595ce8864fb62c [file] [log] [blame]
akmhoque3d06e792014-05-27 16:23:20 -05001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -05002/**
Ashlesh Gawande85998a12017-12-07 22:22:13 -06003 * Copyright (c) 2014-2019, The University of Memphis,
Nick Gordonf8b5bcd2016-08-11 15:06:50 -05004 * Regents of the University of California
akmhoque3d06e792014-05-27 16:23:20 -05005 *
6 * This file is part of NLSR (Named-data Link State Routing).
7 * See AUTHORS.md for complete list of NLSR authors and contributors.
8 *
9 * NLSR is free software: you can redistribute it and/or modify it under the terms
10 * of the GNU General Public License as published by the Free Software Foundation,
11 * either version 3 of the License, or (at your option) any later version.
12 *
13 * NLSR is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
14 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15 * PURPOSE. See the GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License along with
18 * NLSR, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
19 *
20 * \author Ashlesh Gawande <agawande@memphis.edu>
21 *
22 **/
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -050023#include "route/nexthop.hpp"
24#include <boost/test/unit_test.hpp>
25
26namespace nlsr {
27
28namespace test {
29
30BOOST_AUTO_TEST_SUITE(TestNexthop)
31
Vince Lehman20fe4a92014-09-09 15:57:59 -050032double
33getHyperbolicAdjustedDecimal(unsigned int i)
34{
35 return static_cast<double>(i)/(10*NextHop::HYPERBOLIC_COST_ADJUSTMENT_FACTOR);
36}
37
38uint64_t
39applyHyperbolicFactorAndRound(double d)
40{
41 return round(NextHop::HYPERBOLIC_COST_ADJUSTMENT_FACTOR*d);
42}
43
44BOOST_AUTO_TEST_CASE(LinkStateSetAndGet)
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -050045{
Vince Lehman145064a2014-08-23 11:44:16 -050046 NextHop hop1;
47 hop1.setConnectingFaceUri("udp://test/uri");
48 hop1.setRouteCost(12.34);
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -050049
Vince Lehman145064a2014-08-23 11:44:16 -050050 BOOST_CHECK_EQUAL(hop1.getConnectingFaceUri(), "udp://test/uri");
51 BOOST_CHECK_EQUAL(hop1.getRouteCost(), 12.34);
Vince Lehman20fe4a92014-09-09 15:57:59 -050052 BOOST_CHECK_EQUAL(hop1.getRouteCostAsAdjustedInteger(), 12);
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -050053
Vince Lehman145064a2014-08-23 11:44:16 -050054 NextHop hop2;
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -050055
Vince Lehman145064a2014-08-23 11:44:16 -050056 hop2.setRouteCost(12.34);
57 BOOST_CHECK_EQUAL(hop1.getRouteCostAsAdjustedInteger(), hop2.getRouteCostAsAdjustedInteger());
Vince Lehman20fe4a92014-09-09 15:57:59 -050058}
59
60BOOST_AUTO_TEST_CASE(HyperbolicSetAndGet)
61{
62 NextHop hop1;
63 hop1.setHyperbolic(true);
64 hop1.setConnectingFaceUri("udp://test/uri");
65 hop1.setRouteCost(12.34);
66
67 BOOST_CHECK_EQUAL(hop1.getConnectingFaceUri(), "udp://test/uri");
68 BOOST_CHECK_EQUAL(hop1.getRouteCost(), 12.34);
69 BOOST_CHECK_EQUAL(hop1.getRouteCostAsAdjustedInteger(), applyHyperbolicFactorAndRound(12.34));
70
71 NextHop hop2;
72 hop2.setHyperbolic(true);
73
74 hop2.setRouteCost(12.34);
75 BOOST_CHECK_EQUAL(hop1.getRouteCostAsAdjustedInteger(), hop2.getRouteCostAsAdjustedInteger());
Vince Lehman145064a2014-08-23 11:44:16 -050076
77 hop2.setRouteCost(12.35);
78 BOOST_CHECK(hop1.getRouteCostAsAdjustedInteger() < hop2.getRouteCostAsAdjustedInteger());
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -050079}
80
Vince Lehman20fe4a92014-09-09 15:57:59 -050081BOOST_AUTO_TEST_CASE(HyperbolicRound)
82{
83 NextHop hop1;
84 hop1.setHyperbolic(true);
85 hop1.setConnectingFaceUri("udp://test/uri");
86 hop1.setRouteCost(1 + getHyperbolicAdjustedDecimal(6));
87
88 BOOST_CHECK_EQUAL(hop1.getConnectingFaceUri(), "udp://test/uri");
89 BOOST_CHECK_EQUAL(hop1.getRouteCost(), 1 + getHyperbolicAdjustedDecimal(6));
90 BOOST_CHECK_EQUAL(hop1.getRouteCostAsAdjustedInteger(),
91 applyHyperbolicFactorAndRound((1 + getHyperbolicAdjustedDecimal(6))));
92
93 NextHop hop2;
94 hop2.setHyperbolic(true);
95
96 hop2.setRouteCost(1 + getHyperbolicAdjustedDecimal(6));
97 BOOST_CHECK_EQUAL(hop1.getRouteCostAsAdjustedInteger(), hop2.getRouteCostAsAdjustedInteger());
98
99 hop2.setRouteCost(1 + getHyperbolicAdjustedDecimal(5));
100 BOOST_CHECK_EQUAL(hop1.getRouteCostAsAdjustedInteger(), hop2.getRouteCostAsAdjustedInteger());
101
102 hop2.setRouteCost(1 + getHyperbolicAdjustedDecimal(4));
103 BOOST_CHECK(hop1.getRouteCostAsAdjustedInteger() > hop2.getRouteCostAsAdjustedInteger());
104}
105
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -0500106BOOST_AUTO_TEST_SUITE_END()
107
Nick Gordonfad8e252016-08-11 14:21:38 -0500108} // namespace test
109} // namespace nlsr