blob: 3a6a5fd269a8a7e177116bda83fbde39097d8215 [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>
akmhoque3d06e792014-05-27 16:23:20 -050021 **/
Davide Pesaventocb065f12019-12-27 01:03:34 -050022
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -050023#include "route/nexthop.hpp"
Davide Pesaventocb065f12019-12-27 01:03:34 -050024#include "tests/boost-test.hpp"
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -050025
26namespace nlsr {
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -050027namespace test {
28
29BOOST_AUTO_TEST_SUITE(TestNexthop)
30
Vince Lehman20fe4a92014-09-09 15:57:59 -050031double
32getHyperbolicAdjustedDecimal(unsigned int i)
33{
34 return static_cast<double>(i)/(10*NextHop::HYPERBOLIC_COST_ADJUSTMENT_FACTOR);
35}
36
37uint64_t
38applyHyperbolicFactorAndRound(double d)
39{
40 return round(NextHop::HYPERBOLIC_COST_ADJUSTMENT_FACTOR*d);
41}
42
43BOOST_AUTO_TEST_CASE(LinkStateSetAndGet)
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -050044{
Vince Lehman145064a2014-08-23 11:44:16 -050045 NextHop hop1;
46 hop1.setConnectingFaceUri("udp://test/uri");
47 hop1.setRouteCost(12.34);
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -050048
Vince Lehman145064a2014-08-23 11:44:16 -050049 BOOST_CHECK_EQUAL(hop1.getConnectingFaceUri(), "udp://test/uri");
50 BOOST_CHECK_EQUAL(hop1.getRouteCost(), 12.34);
Vince Lehman20fe4a92014-09-09 15:57:59 -050051 BOOST_CHECK_EQUAL(hop1.getRouteCostAsAdjustedInteger(), 12);
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -050052
Vince Lehman145064a2014-08-23 11:44:16 -050053 NextHop hop2;
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -050054
Vince Lehman145064a2014-08-23 11:44:16 -050055 hop2.setRouteCost(12.34);
56 BOOST_CHECK_EQUAL(hop1.getRouteCostAsAdjustedInteger(), hop2.getRouteCostAsAdjustedInteger());
Vince Lehman20fe4a92014-09-09 15:57:59 -050057}
58
59BOOST_AUTO_TEST_CASE(HyperbolicSetAndGet)
60{
61 NextHop hop1;
62 hop1.setHyperbolic(true);
63 hop1.setConnectingFaceUri("udp://test/uri");
64 hop1.setRouteCost(12.34);
65
66 BOOST_CHECK_EQUAL(hop1.getConnectingFaceUri(), "udp://test/uri");
67 BOOST_CHECK_EQUAL(hop1.getRouteCost(), 12.34);
68 BOOST_CHECK_EQUAL(hop1.getRouteCostAsAdjustedInteger(), applyHyperbolicFactorAndRound(12.34));
69
70 NextHop hop2;
71 hop2.setHyperbolic(true);
72
73 hop2.setRouteCost(12.34);
74 BOOST_CHECK_EQUAL(hop1.getRouteCostAsAdjustedInteger(), hop2.getRouteCostAsAdjustedInteger());
Vince Lehman145064a2014-08-23 11:44:16 -050075
76 hop2.setRouteCost(12.35);
77 BOOST_CHECK(hop1.getRouteCostAsAdjustedInteger() < hop2.getRouteCostAsAdjustedInteger());
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -050078}
79
Vince Lehman20fe4a92014-09-09 15:57:59 -050080BOOST_AUTO_TEST_CASE(HyperbolicRound)
81{
82 NextHop hop1;
83 hop1.setHyperbolic(true);
84 hop1.setConnectingFaceUri("udp://test/uri");
85 hop1.setRouteCost(1 + getHyperbolicAdjustedDecimal(6));
86
87 BOOST_CHECK_EQUAL(hop1.getConnectingFaceUri(), "udp://test/uri");
88 BOOST_CHECK_EQUAL(hop1.getRouteCost(), 1 + getHyperbolicAdjustedDecimal(6));
89 BOOST_CHECK_EQUAL(hop1.getRouteCostAsAdjustedInteger(),
90 applyHyperbolicFactorAndRound((1 + getHyperbolicAdjustedDecimal(6))));
91
92 NextHop hop2;
93 hop2.setHyperbolic(true);
94
95 hop2.setRouteCost(1 + getHyperbolicAdjustedDecimal(6));
96 BOOST_CHECK_EQUAL(hop1.getRouteCostAsAdjustedInteger(), hop2.getRouteCostAsAdjustedInteger());
97
98 hop2.setRouteCost(1 + getHyperbolicAdjustedDecimal(5));
99 BOOST_CHECK_EQUAL(hop1.getRouteCostAsAdjustedInteger(), hop2.getRouteCostAsAdjustedInteger());
100
101 hop2.setRouteCost(1 + getHyperbolicAdjustedDecimal(4));
102 BOOST_CHECK(hop1.getRouteCostAsAdjustedInteger() > hop2.getRouteCostAsAdjustedInteger());
103}
104
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -0500105BOOST_AUTO_TEST_SUITE_END()
106
Nick Gordonfad8e252016-08-11 14:21:38 -0500107} // namespace test
108} // namespace nlsr