blob: 2e6a6ffe535b50ea8ed6783684a2cc30f4ac3a33 [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,
Vince Lehmanc2e51f62015-01-20 15:03:11 -06004 * Regents of the University of California,
5 * Arizona Board of Regents.
akmhoque3d06e792014-05-27 16:23:20 -05006 *
7 * This file is part of NLSR (Named-data Link State Routing).
8 * See AUTHORS.md for complete list of NLSR authors and contributors.
9 *
10 * NLSR is free software: you can redistribute it and/or modify it under the terms
11 * of the GNU General Public License as published by the Free Software Foundation,
12 * either version 3 of the License, or (at your option) any later version.
13 *
14 * NLSR is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
15 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
16 * PURPOSE. See the GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License along with
19 * NLSR, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
akmhoque3d06e792014-05-27 16:23:20 -050020 **/
Vince Lehman7c603292014-09-11 17:48:16 -050021
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -050022#include "lsdb.hpp"
Muktadir Chowdhuryc3ea26f2018-01-05 21:40:59 +000023
Nick Gordon098aae42017-08-23 15:18:46 -050024#include "test-common.hpp"
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -050025#include "nlsr.hpp"
26#include "lsa.hpp"
27#include "name-prefix-list.hpp"
28#include <boost/test/unit_test.hpp>
29
Muktadir R Chowdhuryc69da0a2015-12-18 13:24:38 -060030#include <ndn-cxx/util/dummy-client-face.hpp>
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -050031#include <ndn-cxx/util/segment-fetcher.hpp>
Muktadir R Chowdhuryc69da0a2015-12-18 13:24:38 -060032
Muktadir Chowdhuryf04f9892017-08-20 20:42:56 -050033#include <unistd.h>
34
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -050035namespace nlsr {
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -050036namespace test {
37
Ashlesh Gawande85998a12017-12-07 22:22:13 -060038using namespace ndn::time_literals;
Vince Lehman904c2412014-09-23 19:36:11 -050039
Muktadir Chowdhuryf04f9892017-08-20 20:42:56 -050040class LsdbFixture : public UnitTestTimeFixture
Vince Lehman904c2412014-09-23 19:36:11 -050041{
42public:
43 LsdbFixture()
Ashlesh Gawande939b6f82018-12-09 16:51:09 -060044 : face(m_ioService, m_keyChain, {true, true})
Ashlesh Gawande85998a12017-12-07 22:22:13 -060045 , conf(face)
46 , confProcessor(conf)
47 , nlsr(face, m_keyChain, conf)
48 , lsdb(nlsr.m_lsdb)
Vince Lehman904c2412014-09-23 19:36:11 -050049 , REGISTER_COMMAND_PREFIX("/localhost/nfd/rib")
50 , REGISTER_VERB("register")
51 {
Muktadir Chowdhuryf04f9892017-08-20 20:42:56 -050052 addIdentity("/ndn/site/%C1.Router/this-router");
Vince Lehmanf1aa5232014-10-06 17:57:35 -050053
54 nlsr.initialize();
55
Ashlesh Gawande85998a12017-12-07 22:22:13 -060056 advanceClocks(10_ms);
Muktadir Chowdhuryf04f9892017-08-20 20:42:56 -050057 face.sentInterests.clear();
Vince Lehman904c2412014-09-23 19:36:11 -050058 }
59
Vince Lehmanf1aa5232014-10-06 17:57:35 -050060 void
61 extractParameters(ndn::Interest& interest, ndn::Name::Component& verb,
62 ndn::nfd::ControlParameters& extractedParameters)
Vince Lehman904c2412014-09-23 19:36:11 -050063 {
64 const ndn::Name& name = interest.getName();
65 verb = name[REGISTER_COMMAND_PREFIX.size()];
66 const ndn::Name::Component& parameterComponent = name[REGISTER_COMMAND_PREFIX.size() + 1];
67
68 ndn::Block rawParameters = parameterComponent.blockFromValue();
69 extractedParameters.wireDecode(rawParameters);
70 }
71
Vince Lehmanf1aa5232014-10-06 17:57:35 -050072 void
73 areNamePrefixListsEqual(NamePrefixList& lhs, NamePrefixList& rhs)
74 {
Nick Gordonf14ec352017-07-24 16:09:58 -050075
Vince Lehmanf1aa5232014-10-06 17:57:35 -050076 typedef std::list<ndn::Name> NameList;
77
Nick Gordonf14ec352017-07-24 16:09:58 -050078 NameList lhsList = lhs.getNames();
79 NameList rhsList = rhs.getNames();
Vince Lehmanf1aa5232014-10-06 17:57:35 -050080
81 BOOST_REQUIRE_EQUAL(lhsList.size(), rhsList.size());
82
83 NameList::iterator i = lhsList.begin();
84 NameList::iterator j = rhsList.begin();
85
86 for (; i != lhsList.end(); ++i, ++j) {
87 BOOST_CHECK_EQUAL(*i, *j);
88 }
89 }
90
Vince Lehman904c2412014-09-23 19:36:11 -050091public:
Muktadir Chowdhuryf04f9892017-08-20 20:42:56 -050092 ndn::util::DummyClientFace face;
Ashlesh Gawande85998a12017-12-07 22:22:13 -060093 ConfParameter conf;
94 DummyConfFileProcessor confProcessor;
Vince Lehman904c2412014-09-23 19:36:11 -050095 Nlsr nlsr;
Vince Lehmanf1aa5232014-10-06 17:57:35 -050096 Lsdb& lsdb;
Vince Lehmanf1aa5232014-10-06 17:57:35 -050097
Vince Lehman904c2412014-09-23 19:36:11 -050098 ndn::Name REGISTER_COMMAND_PREFIX;
99 ndn::Name::Component REGISTER_VERB;
100};
101
102BOOST_FIXTURE_TEST_SUITE(TestLsdb, LsdbFixture)
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -0500103
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500104BOOST_AUTO_TEST_CASE(LsdbSync)
105{
106 ndn::Name interestName("/ndn/NLSR/LSA/cs/%C1.Router/router2/name");
107 uint64_t oldSeqNo = 82;
108
109 ndn::Name oldInterestName = interestName;
110 oldInterestName.appendNumber(oldSeqNo);
111
112 lsdb.expressInterest(oldInterestName, 0);
Ashlesh Gawande85998a12017-12-07 22:22:13 -0600113 advanceClocks(10_ms);
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500114
Muktadir Chowdhuryf04f9892017-08-20 20:42:56 -0500115 std::vector<ndn::Interest>& interests = face.sentInterests;
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500116
117 BOOST_REQUIRE(interests.size() > 0);
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500118
Nick Gordon098aae42017-08-23 15:18:46 -0500119 bool didFindInterest = false;
120 for (const auto& interest : interests) {
121 didFindInterest = didFindInterest || interest.getName() == oldInterestName;
122 }
123
124 BOOST_CHECK(didFindInterest);
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500125 interests.clear();
126
Nick Gordone98480b2017-05-24 11:23:03 -0500127 ndn::time::steady_clock::TimePoint deadline = ndn::time::steady_clock::now() +
128 ndn::time::seconds(LSA_REFRESH_TIME_MAX);
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500129
130 // Simulate an LSA interest timeout
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500131 lsdb.onFetchLsaError(ndn::util::SegmentFetcher::ErrorCode::INTEREST_TIMEOUT, "Timeout",
132 oldInterestName, 0, deadline, interestName, oldSeqNo);
Ashlesh Gawande85998a12017-12-07 22:22:13 -0600133 advanceClocks(10_ms);
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500134
135 BOOST_REQUIRE(interests.size() > 0);
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500136
Nick Gordon098aae42017-08-23 15:18:46 -0500137 didFindInterest = false;
138 for (const auto& interest : interests) {
139 didFindInterest = didFindInterest || interest.getName() == oldInterestName;
140 }
141
142 BOOST_CHECK(didFindInterest);
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500143 interests.clear();
144
145 uint64_t newSeqNo = 83;
146
147 ndn::Name newInterestName = interestName;
148 newInterestName.appendNumber(newSeqNo);
149
150 lsdb.expressInterest(newInterestName, 0);
Ashlesh Gawande85998a12017-12-07 22:22:13 -0600151 advanceClocks(10_ms);
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500152
153 BOOST_REQUIRE(interests.size() > 0);
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500154
Nick Gordon098aae42017-08-23 15:18:46 -0500155 didFindInterest = false;
156 for (const auto& interest : interests) {
157 didFindInterest = didFindInterest || interest.getName() == newInterestName;
158 }
159
160 BOOST_CHECK(didFindInterest);
161
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500162 interests.clear();
163
164 // Simulate an LSA interest timeout where the sequence number is outdated
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500165 lsdb.onFetchLsaError(ndn::util::SegmentFetcher::ErrorCode::INTEREST_TIMEOUT, "Timeout",
166 oldInterestName, 0, deadline, interestName, oldSeqNo);
Ashlesh Gawande85998a12017-12-07 22:22:13 -0600167 advanceClocks(10_ms);
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500168
169 // Interest should not be expressed for outdated sequence number
170 BOOST_CHECK_EQUAL(interests.size(), 0);
171}
172
Ashlesh Gawande939b6f82018-12-09 16:51:09 -0600173BOOST_AUTO_TEST_CASE(LsdbSegmentedData)
174{
175 // Add a lot of NameLSAs to exceed max packet size
176 ndn::Name lsaKey("/ndn/site/%C1.Router/this-router/NAME");
177
178 NameLsa* nameLsa = lsdb.findNameLsa(lsaKey);
179 uint64_t seqNo = nameLsa->getLsSeqNo();
180
181 ndn::Name prefix("/ndn/edu/memphis/netlab/research/nlsr/test/prefix/");
182
183 int nPrefixes = 0;
184 while (nameLsa->serialize().size() < ndn::MAX_NDN_PACKET_SIZE) {
185 nameLsa->addName(ndn::Name(prefix).appendNumber(++nPrefixes));
Ashlesh Gawande6b388fc2019-09-30 10:14:41 -0500186 break;
Ashlesh Gawande939b6f82018-12-09 16:51:09 -0600187 }
188 lsdb.installNameLsa(*nameLsa);
189
190 // Create another Lsdb and expressInterest
191 ndn::util::DummyClientFace face2(m_ioService, m_keyChain, {true, true});
192 face.linkTo(face2);
Ashlesh Gawande6b388fc2019-09-30 10:14:41 -0500193
Ashlesh Gawande85998a12017-12-07 22:22:13 -0600194 ConfParameter conf2(face2);
Ashlesh Gawande939b6f82018-12-09 16:51:09 -0600195 std::string config = R"CONF(
196 trust-anchor
197 {
198 type any
199 }
200 )CONF";
Ashlesh Gawande85998a12017-12-07 22:22:13 -0600201 conf2.getValidator().load(config, "config-file-from-string");
Ashlesh Gawande6b388fc2019-09-30 10:14:41 -0500202 Nlsr nlsr2(face2, m_keyChain, conf2);
Ashlesh Gawande939b6f82018-12-09 16:51:09 -0600203
Ashlesh Gawande85998a12017-12-07 22:22:13 -0600204 Lsdb& lsdb2(nlsr2.m_lsdb);
Ashlesh Gawande939b6f82018-12-09 16:51:09 -0600205
Ashlesh Gawande6b388fc2019-09-30 10:14:41 -0500206 advanceClocks(ndn::time::milliseconds(10), 10);
Ashlesh Gawande939b6f82018-12-09 16:51:09 -0600207
208 ndn::Name interestName("/localhop/ndn/nlsr/LSA/site/%C1.Router/this-router/NAME");
209 interestName.appendNumber(seqNo);
Ashlesh Gawande6b388fc2019-09-30 10:14:41 -0500210 lsdb2.expressInterest(interestName, 0/*= timeout count*/);
Ashlesh Gawande939b6f82018-12-09 16:51:09 -0600211
Ashlesh Gawande6b388fc2019-09-30 10:14:41 -0500212 advanceClocks(ndn::time::milliseconds(200), 20);
Ashlesh Gawande939b6f82018-12-09 16:51:09 -0600213
Ashlesh Gawande6b388fc2019-09-30 10:14:41 -0500214 BOOST_CHECK_EQUAL(lsdb.getNameLsdb().front().getNpl(), lsdb2.getNameLsdb().back().getNpl());
Ashlesh Gawande939b6f82018-12-09 16:51:09 -0600215}
216
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500217BOOST_AUTO_TEST_CASE(SegmentLsaData)
218{
Muktadir Chowdhuryc3ea26f2018-01-05 21:40:59 +0000219 ndn::Name lsaKey("/ndn/site/%C1.Router/this-router/NAME");
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500220
Muktadir Chowdhuryc3ea26f2018-01-05 21:40:59 +0000221 NameLsa* lsa = lsdb.findNameLsa(lsaKey);
222 uint64_t seqNo = lsa->getLsSeqNo();
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500223
224 ndn::Name prefix("/ndn/edu/memphis/netlab/research/nlsr/test/prefix/");
225
226 int nPrefixes = 0;
Muktadir Chowdhuryc3ea26f2018-01-05 21:40:59 +0000227 while (lsa->serialize().size() < ndn::MAX_NDN_PACKET_SIZE) {
228 lsa->addName(ndn::Name(prefix).appendNumber(++nPrefixes));
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500229 }
Muktadir Chowdhuryc3ea26f2018-01-05 21:40:59 +0000230 lsdb.installNameLsa(*lsa);
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500231
Muktadir Chowdhuryc3ea26f2018-01-05 21:40:59 +0000232 std::string expectedDataContent = lsa->serialize();
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500233
Ashlesh Gawande939b6f82018-12-09 16:51:09 -0600234 ndn::Name interestName("/localhop/ndn/nlsr/LSA/site/%C1.Router/this-router/NAME/");
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500235 interestName.appendNumber(seqNo);
236
Ashlesh Gawande939b6f82018-12-09 16:51:09 -0600237 ndn::util::DummyClientFace face2(m_ioService, m_keyChain, {true, true});
238 face.linkTo(face2);
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500239
Ashlesh Gawande939b6f82018-12-09 16:51:09 -0600240 auto fetcher = ndn::util::SegmentFetcher::start(face2, ndn::Interest(interestName),
241 ndn::security::v2::getAcceptAllValidator());
242 fetcher->onComplete.connect([&expectedDataContent] (ndn::ConstBufferPtr bufferPtr) {
243 ndn::Block block(bufferPtr);
244 BOOST_CHECK_EQUAL(expectedDataContent, readString(block));
245 });
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500246
Ashlesh Gawande939b6f82018-12-09 16:51:09 -0600247 advanceClocks(ndn::time::milliseconds(1), 100);
248 fetcher->stop();
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500249}
250
251BOOST_AUTO_TEST_CASE(ReceiveSegmentedLsaData)
252{
253 ndn::Name router("/ndn/cs/%C1.Router/router1");
254 uint64_t seqNo = 12;
255 NamePrefixList prefixList;
256
257 NameLsa lsa(router, seqNo, ndn::time::system_clock::now(), prefixList);
258
259 ndn::Name prefix("/prefix/");
260
261 for (int nPrefixes = 0; nPrefixes < 3; ++nPrefixes) {
262 lsa.addName(ndn::Name(prefix).appendNumber(nPrefixes));
263 }
264
Ashlesh Gawande939b6f82018-12-09 16:51:09 -0600265 ndn::Name interestName("/localhop/ndn/nlsr/LSA/cs/%C1.Router/router1/NAME/");
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500266 interestName.appendNumber(seqNo);
267
Ashlesh Gawande939b6f82018-12-09 16:51:09 -0600268 ndn::Block block = ndn::encoding::makeStringBlock(ndn::tlv::Content, lsa.serialize());
269 lsdb.afterFetchLsa(block.getBuffer(), interestName);
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500270
271 NameLsa* foundLsa = lsdb.findNameLsa(lsa.getKey());
272 BOOST_REQUIRE(foundLsa != nullptr);
273
Nick Gordonfaf49f42017-10-23 12:36:28 -0500274 BOOST_CHECK_EQUAL(foundLsa->serialize(), lsa.serialize());
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500275}
276
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -0500277BOOST_AUTO_TEST_CASE(LsdbRemoveAndExists)
278{
akmhoquec7a79b22014-05-26 08:06:19 -0500279 ndn::time::system_clock::TimePoint testTimePoint = ndn::time::system_clock::now();
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -0500280 NamePrefixList npl1;
281
akmhoquefdbddb12014-05-02 18:35:19 -0500282 std::string s1 = "name1";
283 std::string s2 = "name2";
284 std::string router1 = "router1/1";
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -0500285
286 npl1.insert(s1);
287 npl1.insert(s2);
288
Ashlesh Gawande85998a12017-12-07 22:22:13 -0600289 // For NameLsa lsType is name.
290 // 12 is seqNo, randomly generated.
291 // 1800 seconds is the default life time.
Ashlesh Gawanded02c3882015-12-29 16:02:51 -0600292 NameLsa nlsa1(ndn::Name("/router1/1"), 12, testTimePoint, npl1);
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -0500293
Ashlesh Gawande85998a12017-12-07 22:22:13 -0600294 Lsdb& lsdb1(nlsr.m_lsdb);
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -0500295
akmhoque31d1d4b2014-05-05 22:08:14 -0500296 lsdb1.installNameLsa(nlsa1);
Alexander Afanasyev411ee4b2014-08-16 23:17:03 -0700297 lsdb1.writeNameLsdbLog();
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -0500298
Nick Gordon727d4832017-10-13 18:04:25 -0500299 BOOST_CHECK(lsdb1.doesLsaExist(ndn::Name("/router1/1/NAME"), Lsa::Type::NAME));
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -0500300
akmhoque31d1d4b2014-05-05 22:08:14 -0500301 lsdb1.removeNameLsa(router1);
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -0500302
Nick Gordon727d4832017-10-13 18:04:25 -0500303 BOOST_CHECK_EQUAL(lsdb1.doesLsaExist(ndn::Name("/router1/1"), Lsa::Type::NAME), false);
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -0500304}
305
Vince Lehmanf1aa5232014-10-06 17:57:35 -0500306BOOST_AUTO_TEST_CASE(InstallNameLsa)
307{
308 // Install lsa with name1 and name2
309 ndn::Name name1("/ndn/name1");
310 ndn::Name name2("/ndn/name2");
311
312 NamePrefixList prefixes;
313 prefixes.insert(name1);
314 prefixes.insert(name2);
315
316 std::string otherRouter("/ndn/site/%C1.router/other-router");
317 ndn::time::system_clock::TimePoint MAX_TIME = ndn::time::system_clock::TimePoint::max();
318
Ashlesh Gawanded02c3882015-12-29 16:02:51 -0600319 NameLsa lsa(otherRouter, 1, MAX_TIME, prefixes);
Vince Lehmanf1aa5232014-10-06 17:57:35 -0500320 lsdb.installNameLsa(lsa);
321
Nick Gordon727d4832017-10-13 18:04:25 -0500322 BOOST_REQUIRE_EQUAL(lsdb.doesLsaExist(otherRouter + "/NAME", Lsa::Type::NAME), true);
323 NamePrefixList& nameList = lsdb.findNameLsa(otherRouter + "/NAME")->getNpl();
Vince Lehmanf1aa5232014-10-06 17:57:35 -0500324
Nick Gordonf14ec352017-07-24 16:09:58 -0500325 BOOST_CHECK_EQUAL(nameList, prefixes);
326 //areNamePrefixListsEqual(nameList, prefixes);
Vince Lehmanf1aa5232014-10-06 17:57:35 -0500327
328 // Add a prefix: name3
329 ndn::Name name3("/ndn/name3");
330 prefixes.insert(name3);
331
Ashlesh Gawanded02c3882015-12-29 16:02:51 -0600332 NameLsa addLsa(otherRouter, 2, MAX_TIME, prefixes);
Vince Lehmanf1aa5232014-10-06 17:57:35 -0500333 lsdb.installNameLsa(addLsa);
334
335 // Lsa should include name1, name2, and name3
Nick Gordonf14ec352017-07-24 16:09:58 -0500336 BOOST_CHECK_EQUAL(nameList, prefixes);
Vince Lehmanf1aa5232014-10-06 17:57:35 -0500337
338 // Remove a prefix: name2
339 prefixes.remove(name2);
340
Ashlesh Gawanded02c3882015-12-29 16:02:51 -0600341 NameLsa removeLsa(otherRouter, 3, MAX_TIME, prefixes);
Vince Lehmanf1aa5232014-10-06 17:57:35 -0500342 lsdb.installNameLsa(removeLsa);
343
344 // Lsa should include name1 and name3
Nick Gordonf14ec352017-07-24 16:09:58 -0500345 BOOST_CHECK_EQUAL(nameList, prefixes);
Vince Lehmanf1aa5232014-10-06 17:57:35 -0500346
347 // Add and remove a prefix: add name2, remove name3
348 prefixes.insert(name2);
349 prefixes.remove(name3);
350
Ashlesh Gawanded02c3882015-12-29 16:02:51 -0600351 NameLsa addAndRemoveLsa(otherRouter, 4, MAX_TIME, prefixes);
Vince Lehmanf1aa5232014-10-06 17:57:35 -0500352 lsdb.installNameLsa(addAndRemoveLsa);
353
354 // Lsa should include name1 and name2
Nick Gordonf14ec352017-07-24 16:09:58 -0500355 BOOST_CHECK_EQUAL(nameList, prefixes);
Vince Lehmanf1aa5232014-10-06 17:57:35 -0500356
357 // Install a completely new list of prefixes
358 ndn::Name name4("/ndn/name4");
359 ndn::Name name5("/ndn/name5");
360
361 NamePrefixList newPrefixes;
362 newPrefixes.insert(name4);
363 newPrefixes.insert(name5);
364
Ashlesh Gawanded02c3882015-12-29 16:02:51 -0600365 NameLsa newLsa(otherRouter, 5, MAX_TIME, newPrefixes);
Vince Lehmanf1aa5232014-10-06 17:57:35 -0500366 lsdb.installNameLsa(newLsa);
367
368 // Lsa should include name4 and name5
Nick Gordonf14ec352017-07-24 16:09:58 -0500369 BOOST_CHECK_EQUAL(nameList, newPrefixes);
Vince Lehmanf1aa5232014-10-06 17:57:35 -0500370}
371
Nick Gordon8f23b5d2017-08-31 17:53:07 -0500372BOOST_AUTO_TEST_CASE(TestIsLsaNew)
373{
374 const ndn::Name::Component CONFIG_NETWORK{"/ndn"};
375 const ndn::Name::Component CONFIG_SITE{"/memphis"};
376 ndn::Name originRouter{};
377 originRouter.append(CONFIG_NETWORK).append(CONFIG_SITE).append("/%C1.Router/other-router");
378
379 // Install Name LSA
380 NamePrefixList nameList;
381 NameLsa lsa(originRouter, 999, ndn::time::system_clock::TimePoint::max(), nameList);
382
383 lsdb.installNameLsa(lsa);
384
385 // Lower NameLSA sequence number
386 uint64_t lowerSeqNo = 998;
Nick Gordon727d4832017-10-13 18:04:25 -0500387 BOOST_CHECK(!lsdb.isLsaNew(originRouter, Lsa::Type::NAME, lowerSeqNo));
Nick Gordon8f23b5d2017-08-31 17:53:07 -0500388
389 // Same NameLSA sequence number
390 uint64_t sameSeqNo = 999;
Nick Gordon727d4832017-10-13 18:04:25 -0500391 BOOST_CHECK(!lsdb.isLsaNew(originRouter, Lsa::Type::NAME, sameSeqNo));
Nick Gordon8f23b5d2017-08-31 17:53:07 -0500392
393 // Higher NameLSA sequence number
394 uint64_t higherSeqNo = 1000;
Nick Gordon727d4832017-10-13 18:04:25 -0500395 BOOST_CHECK(lsdb.isLsaNew(originRouter, Lsa::Type::NAME, higherSeqNo));
Nick Gordon8f23b5d2017-08-31 17:53:07 -0500396}
397
398BOOST_AUTO_TEST_SUITE_END() // TestLsdb
Ashlesh Gawandeeb582eb2014-05-01 14:25:20 -0500399
Nick Gordonfad8e252016-08-11 14:21:38 -0500400} // namespace test
401} // namespace nlsr