blob: 2e876d5e473a94ff2d4786c4da998e413377b93b [file] [log] [blame]
Vince Lehman72446ec2014-07-09 10:50:02 -05001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Junxiao Shi75306352018-02-01 21:59:44 +00002/*
jaczhib0657682025-01-08 23:01:45 -08003 * Copyright (c) 2014-2025, Regents of the University of California,
Alexander Afanasyev7c10b3b2015-01-20 12:24:27 -08004 * Arizona Board of Regents,
5 * Colorado State University,
6 * University Pierre & Marie Curie, Sorbonne University,
7 * Washington University in St. Louis,
8 * Beijing Institute of Technology,
9 * The University of Memphis.
Vince Lehman72446ec2014-07-09 10:50:02 -050010 *
11 * This file is part of NFD (Named Data Networking Forwarding Daemon).
12 * See AUTHORS.md for complete list of NFD authors and contributors.
13 *
14 * NFD is free software: you can redistribute it and/or modify it under the terms
15 * of the GNU General Public License as published by the Free Software Foundation,
16 * either version 3 of the License, or (at your option) any later version.
17 *
18 * NFD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
19 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
20 * PURPOSE. See the GNU General Public License for more details.
21 *
22 * You should have received a copy of the GNU General Public License along with
23 * NFD, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
24 */
25
Davide Pesavento8a05c7f2019-02-28 02:26:19 -050026#include "mgmt/rib-manager.hpp"
Vince Lehman72446ec2014-07-09 10:50:02 -050027
Davide Pesavento78ddcab2019-02-28 22:00:03 -050028#include "manager-common-fixture.hpp"
Junxiao Shidf1dc652019-08-30 19:03:19 +000029#include "tests/daemon/rib/fib-updates-common.hpp"
Davide Pesavento0064c1d2018-03-03 18:43:53 -050030
Junxiao Shicbc8e942016-09-06 03:17:45 +000031#include <ndn-cxx/lp/tags.hpp>
Davide Pesaventod2ea2352017-03-12 20:38:09 -040032#include <ndn-cxx/mgmt/nfd/face-status.hpp>
33#include <ndn-cxx/mgmt/nfd/rib-entry.hpp>
Zhiyi Zhanga499aa22019-09-24 15:00:40 -070034
Davide Pesaventof56cf632024-01-27 22:22:06 -050035#include <boost/mp11/algorithm.hpp>
Zhiyi Zhanga499aa22019-09-24 15:00:40 -070036#include <boost/property_tree/info_parser.hpp>
Vince Lehman26b215c2014-08-17 15:00:41 -050037
Davide Pesaventoe422f9e2022-06-03 01:30:23 -040038namespace nfd::tests {
Vince Lehman72446ec2014-07-09 10:50:02 -050039
Yanbiao Licf0db022016-01-29 00:54:25 -080040struct ConfigurationStatus
Vince Lehman72446ec2014-07-09 10:50:02 -050041{
Yanbiao Licf0db022016-01-29 00:54:25 -080042 bool isLocalhostConfigured;
43 bool isLocalhopConfigured;
Vince Lehman72446ec2014-07-09 10:50:02 -050044};
45
Junxiao Shif4cfed12018-08-22 23:26:29 +000046static ConfigSection
47getValidatorConfigSection()
48{
49 ConfigSection section;
50 section.put("trust-anchor.type", "any");
51 return section;
52}
53
Zhiyi Zhanga499aa22019-09-24 15:00:40 -070054static ConfigSection
55makeSection(const std::string& config)
56{
57 std::istringstream inputStream(config);
58 ConfigSection section;
59 boost::property_tree::read_info(inputStream, section);
60 return section;
61}
62
63static ConfigSection
64getLocalhopValidatorConfigSection()
65{
66 std::string config = R"CONF(
67 rule
68 {
69 id rule-id1
70 for interest
71 filter
72 {
73 type name
74 name /localhop/nfd/rib
75 relation is-prefix-of
76 }
77 checker
78 {
79 type customized
80 sig-type ecdsa-sha256
81 key-locator
82 {
83 type name
84 name /TrustAnchor-identity/Derived-identity
85 relation is-prefix-of
86 }
87 }
88 }
89 rule
90 {
91 id rule-id2
92 for data
93 filter
94 {
95 type name
96 name /TrustAnchor-identity/Derived-identity/KEY
97 relation is-prefix-of
98 }
99 checker
100 {
101 type customized
102 sig-type ecdsa-sha256
103 key-locator
104 {
105 type name
106 name /TrustAnchor-identity
107 relation is-prefix-of
108 }
109 }
110 }
111 trust-anchor
112 {
113 type file
114 file-name signer.ndncert
115 }
116 )CONF";
117 return makeSection(config);
118}
119
jaczhib0657682025-01-08 23:01:45 -0800120static ConfigSection
121getPaValidatorConfigSection()
122{
123 ConfigSection section;
124 section.put("trust-anchor.type", "any");
125 return section;
126}
127
Yanbiao Licf0db022016-01-29 00:54:25 -0800128class RibManagerFixture : public ManagerCommonFixture
Vince Lehman72446ec2014-07-09 10:50:02 -0500129{
130public:
Davide Pesaventoe1bdc082018-10-11 21:20:23 -0400131 RibManagerFixture(const ConfigurationStatus& status, bool shouldClearRib)
Junxiao Shidf1dc652019-08-30 19:03:19 +0000132 : m_status(status)
Zhiyi Zhanga499aa22019-09-24 15:00:40 -0700133 , m_anchorId("/TrustAnchor-identity")
134 , m_derivedId("/TrustAnchor-identity/Derived-identity")
Davide Pesavento9f8b10e2018-08-22 08:45:37 +0000135 , m_nfdController(m_face, m_keyChain)
136 , m_fibUpdater(m_rib, m_nfdController)
Davide Pesavento0a71dd32019-03-17 20:36:18 -0400137 , m_manager(m_rib, m_face, m_keyChain, m_nfdController, m_dispatcher)
Vince Lehman72446ec2014-07-09 10:50:02 -0500138 {
Junxiao Shi4b84a2c2022-04-28 03:17:05 +0000139 auto anchorIdentity = m_keyChain.createIdentity(m_anchorId);
Davide Pesavento21353752020-11-20 00:43:44 -0500140 saveIdentityCert(m_anchorId, "signer.ndncert", true);
Zhiyi Zhanga499aa22019-09-24 15:00:40 -0700141
Junxiao Shi4b84a2c2022-04-28 03:17:05 +0000142 auto derivedKey = m_keyChain.createIdentity(m_derivedId).getDefaultKey();
143 auto derivedSelfSigned = derivedKey.getDefaultCertificate();
144 ndn::security::MakeCertificateOptions opts;
145 opts.validity = derivedSelfSigned.getValidityPeriod();
146 auto derivedCert = m_keyChain.makeCertificate(derivedSelfSigned,
Davide Pesavento20cafa82022-07-25 01:15:03 -0400147 ndn::security::signingByIdentity(anchorIdentity),
148 opts);
Junxiao Shi4b84a2c2022-04-28 03:17:05 +0000149 m_keyChain.setDefaultCertificate(derivedKey, derivedCert);
150
Yanbiao Licf0db022016-01-29 00:54:25 -0800151 if (m_status.isLocalhostConfigured) {
Junxiao Shif4cfed12018-08-22 23:26:29 +0000152 m_manager.applyLocalhostConfig(getValidatorConfigSection(), "test");
Yanbiao Licf0db022016-01-29 00:54:25 -0800153 }
Davide Pesavento20cafa82022-07-25 01:15:03 -0400154
Yanbiao Licf0db022016-01-29 00:54:25 -0800155 if (m_status.isLocalhopConfigured) {
Zhiyi Zhanga499aa22019-09-24 15:00:40 -0700156 m_manager.enableLocalhop(getLocalhopValidatorConfigSection(), "test");
Yanbiao Licf0db022016-01-29 00:54:25 -0800157 }
Junxiao Shif4cfed12018-08-22 23:26:29 +0000158 else {
159 m_manager.disableLocalhop();
160 }
Yanbiao Licf0db022016-01-29 00:54:25 -0800161
jaczhib0657682025-01-08 23:01:45 -0800162 m_manager.applyPaConfig(getPaValidatorConfigSection(), "testPa");
163
Yanbiao Licf0db022016-01-29 00:54:25 -0800164 registerWithNfd();
165
166 if (shouldClearRib) {
167 clearRib();
168 }
Zhiyi Zhanga499aa22019-09-24 15:00:40 -0700169
Junxiao Shi4b84a2c2022-04-28 03:17:05 +0000170 m_face.onSendInterest.connect([=] (const Interest& interest) {
171 if (interest.matchesData(derivedCert) &&
172 m_status.isLocalhopConfigured &&
Davide Pesaventob83d3df2022-09-13 14:04:34 -0400173 interest.getTag<lp::NextHopFaceIdTag>() != nullptr) {
Junxiao Shi4b84a2c2022-04-28 03:17:05 +0000174 m_face.put(derivedCert);
Zhiyi Zhanga499aa22019-09-24 15:00:40 -0700175 }
176 });
Yanbiao Licf0db022016-01-29 00:54:25 -0800177 }
178
179private:
180 void
181 registerWithNfd()
182 {
183 m_manager.registerWithNfd();
Davide Pesavento8a05c7f2019-02-28 02:26:19 -0500184 advanceClocks(1_ms);
Yanbiao Licf0db022016-01-29 00:54:25 -0800185
186 auto replyFibAddCommand = [this] (const Interest& interest) {
Davide Pesavento6d6f2072022-09-12 23:08:34 -0400187 ControlParameters params(interest.getName().at(4).blockFromValue());
Junxiao Shifde3f542016-07-10 19:54:53 +0000188 BOOST_CHECK(params.getName() == "/localhost/nfd/rib" || params.getName() == "/localhop/nfd/rib");
Davide Pesavento20cafa82022-07-25 01:15:03 -0400189 params.setFaceId(1)
190 .setCost(0);
Davide Pesavento78ddcab2019-02-28 22:00:03 -0500191 ControlResponse resp;
Davide Pesavento20cafa82022-07-25 01:15:03 -0400192 resp.setCode(200)
193 .setBody(params.wireEncode());
Yanbiao Licf0db022016-01-29 00:54:25 -0800194
Davide Pesavento20cafa82022-07-25 01:15:03 -0400195 auto data = make_shared<Data>(interest.getName());
Yanbiao Licf0db022016-01-29 00:54:25 -0800196 data->setContent(resp.wireEncode());
Yanbiao Licf0db022016-01-29 00:54:25 -0800197 m_keyChain.sign(*data, ndn::security::SigningInfo(ndn::security::SigningInfo::SIGNER_TYPE_SHA256));
198
Davide Pesaventoe277f8b2023-11-11 17:14:02 -0500199 boost::asio::post(m_face.getIoContext(), [this, data] { m_face.receive(*data); });
Yanbiao Licf0db022016-01-29 00:54:25 -0800200 };
201
Davide Pesavento1d2d3372025-01-14 12:04:12 -0500202 const Name commandPrefix = Name("/localhost/nfd").append(ndn::nfd::FibAddNextHopCommand::getName());
Junxiao Shidf1dc652019-08-30 19:03:19 +0000203 for (const auto& command : m_face.sentInterests) {
Yanbiao Licf0db022016-01-29 00:54:25 -0800204 if (commandPrefix.isPrefixOf(command.getName())) {
205 replyFibAddCommand(command);
Davide Pesavento8a05c7f2019-02-28 02:26:19 -0500206 advanceClocks(1_ms);
Yanbiao Licf0db022016-01-29 00:54:25 -0800207 }
208 }
209
210 // clear commands and responses
211 m_responses.clear();
Junxiao Shidf1dc652019-08-30 19:03:19 +0000212 m_face.sentInterests.clear();
Yanbiao Licf0db022016-01-29 00:54:25 -0800213 }
214
Davide Pesaventoe94804b2016-09-19 17:23:21 +0000215 void
216 clearRib()
Yanbiao Licf0db022016-01-29 00:54:25 -0800217 {
218 while (!m_rib.empty()) {
Davide Pesaventoe94804b2016-09-19 17:23:21 +0000219 m_rib.erase(m_rib.begin()->first, *m_rib.begin()->second->begin());
Yanbiao Licf0db022016-01-29 00:54:25 -0800220 }
221 }
222
223public:
Davide Pesavento22db5392017-04-14 00:56:43 -0400224 static ControlParameters
225 makeRegisterParameters(const Name& name, uint64_t faceId = 0,
Davide Pesaventod2ea2352017-03-12 20:38:09 -0400226 time::milliseconds expiry = time::milliseconds::max())
Yanbiao Licf0db022016-01-29 00:54:25 -0800227 {
228 return ControlParameters()
229 .setName(name)
Davide Pesavento22db5392017-04-14 00:56:43 -0400230 .setFaceId(faceId)
231 .setOrigin(ndn::nfd::ROUTE_ORIGIN_NLSR)
Yanbiao Licf0db022016-01-29 00:54:25 -0800232 .setCost(10)
233 .setFlags(0)
234 .setExpirationPeriod(expiry);
235 }
236
Davide Pesavento22db5392017-04-14 00:56:43 -0400237 static ControlParameters
238 makeUnregisterParameters(const Name& name, uint64_t faceId = 0)
Yanbiao Licf0db022016-01-29 00:54:25 -0800239 {
240 return ControlParameters()
241 .setName(name)
Davide Pesavento22db5392017-04-14 00:56:43 -0400242 .setFaceId(faceId)
243 .setOrigin(ndn::nfd::ROUTE_ORIGIN_NLSR);
Yanbiao Licf0db022016-01-29 00:54:25 -0800244 }
245
Davide Pesavento9f8b10e2018-08-22 08:45:37 +0000246protected:
Davide Pesavento1d2d3372025-01-14 12:04:12 -0500247 static inline const Name REG_REQUEST = Name("/localhost/nfd").append(ndn::nfd::RibRegisterCommand::getName());
248 static inline const Name UNREG_REQUEST = Name("/localhost/nfd").append(ndn::nfd::RibUnregisterCommand::getName());
249 static inline const Name ANNOUNCE_REQUEST = Name("/localhost/nfd").append(ndn::nfd::RibAnnounceCommand::getName());
250
Yanbiao Licf0db022016-01-29 00:54:25 -0800251 ConfigurationStatus m_status;
Zhiyi Zhanga499aa22019-09-24 15:00:40 -0700252 Name m_anchorId;
253 Name m_derivedId;
Yanbiao Licf0db022016-01-29 00:54:25 -0800254
Davide Pesavento9f8b10e2018-08-22 08:45:37 +0000255 ndn::nfd::Controller m_nfdController;
Davide Pesavento8a05c7f2019-02-28 02:26:19 -0500256 rib::Rib m_rib;
Davide Pesaventoe422f9e2022-06-03 01:30:23 -0400257 MockFibUpdater m_fibUpdater;
Yanbiao Licf0db022016-01-29 00:54:25 -0800258 RibManager m_manager;
Yanbiao Licf0db022016-01-29 00:54:25 -0800259};
260
Davide Pesavento8a05c7f2019-02-28 02:26:19 -0500261BOOST_AUTO_TEST_SUITE(Mgmt)
Yanbiao Licf0db022016-01-29 00:54:25 -0800262BOOST_AUTO_TEST_SUITE(TestRibManager)
263
264class AddTopPrefixFixture : public RibManagerFixture
265{
266public:
267 AddTopPrefixFixture()
268 : RibManagerFixture({true, true}, false)
269 {
Vince Lehman72446ec2014-07-09 10:50:02 -0500270 }
271};
272
Yanbiao Licf0db022016-01-29 00:54:25 -0800273BOOST_FIXTURE_TEST_CASE(AddTopPrefix, AddTopPrefixFixture)
Steve DiBenedettocd4ee5f2014-12-08 16:09:11 -0700274{
Davide Pesaventob83d3df2022-09-13 14:04:34 -0400275 BOOST_REQUIRE_EQUAL(m_rib.size(), 2);
Vince Lehman76c751c2014-11-18 17:36:38 -0600276
Yanbiao Licf0db022016-01-29 00:54:25 -0800277 std::vector<Name> ribEntryNames;
278 for (auto&& entry : m_rib) {
279 ribEntryNames.push_back(entry.first);
280 }
281 BOOST_CHECK_EQUAL(ribEntryNames[0], "/localhop/nfd");
282 BOOST_CHECK_EQUAL(ribEntryNames[1], "/localhost/nfd");
Steve DiBenedettocd4ee5f2014-12-08 16:09:11 -0700283}
284
Yanbiao Licf0db022016-01-29 00:54:25 -0800285class UnauthorizedRibManagerFixture : public RibManagerFixture
Vince Lehman72446ec2014-07-09 10:50:02 -0500286{
Yanbiao Licf0db022016-01-29 00:54:25 -0800287public:
288 UnauthorizedRibManagerFixture()
289 : RibManagerFixture({false, false}, true)
290 {
291 }
292};
Vince Lehman72446ec2014-07-09 10:50:02 -0500293
Yanbiao Licf0db022016-01-29 00:54:25 -0800294class LocalhostAuthorizedRibManagerFixture : public RibManagerFixture
295{
296public:
297 LocalhostAuthorizedRibManagerFixture()
298 : RibManagerFixture({true, false}, true)
299 {
300 }
301};
Vince Lehman72446ec2014-07-09 10:50:02 -0500302
Yanbiao Licf0db022016-01-29 00:54:25 -0800303class LocalhopAuthorizedRibManagerFixture : public RibManagerFixture
304{
305public:
306 LocalhopAuthorizedRibManagerFixture()
307 : RibManagerFixture({false, true}, true)
308 {
309 }
310};
311
312class AuthorizedRibManagerFixture : public RibManagerFixture
313{
314public:
315 AuthorizedRibManagerFixture()
316 : RibManagerFixture({true, true}, true)
317 {
318 }
319};
320
Davide Pesaventof56cf632024-01-27 22:22:06 -0500321template<typename Fixture, typename Format>
Davide Pesaventob83d3df2022-09-13 14:04:34 -0400322struct FixtureWithFormat : public Fixture
323{
Davide Pesaventof56cf632024-01-27 22:22:06 -0500324 static constexpr ndn::security::SignedInterestFormat signedInterestFmt = Format::value;
Davide Pesaventob83d3df2022-09-13 14:04:34 -0400325};
326
Davide Pesaventof56cf632024-01-27 22:22:06 -0500327using AllFixtures = boost::mp11::mp_product<
328 FixtureWithFormat,
329 boost::mp11::mp_list<UnauthorizedRibManagerFixture,
330 LocalhostAuthorizedRibManagerFixture,
331 LocalhopAuthorizedRibManagerFixture,
332 AuthorizedRibManagerFixture>,
333 boost::mp11::mp_list_c<ndn::security::SignedInterestFormat,
334 ndn::security::SignedInterestFormat::V02,
335 ndn::security::SignedInterestFormat::V03>
Davide Pesaventod2ea2352017-03-12 20:38:09 -0400336>;
Yanbiao Licf0db022016-01-29 00:54:25 -0800337
338BOOST_FIXTURE_TEST_CASE_TEMPLATE(CommandAuthorization, T, AllFixtures, T)
339{
340 auto parameters = this->makeRegisterParameters("/test-authorization", 9527);
Davide Pesavento1d2d3372025-01-14 12:04:12 -0500341 auto commandHost = this->makeControlCommandRequest(this->REG_REQUEST, parameters, T::signedInterestFmt);
342 auto commandHop = this->makeControlCommandRequest(
343 Name("/localhop/nfd").append(ndn::nfd::RibRegisterCommand::getName()),
344 parameters, T::signedInterestFmt, this->m_derivedId);
Zhiyi Zhanga499aa22019-09-24 15:00:40 -0700345 if (this->m_status.isLocalhopConfigured) {
Davide Pesaventob83d3df2022-09-13 14:04:34 -0400346 commandHop.setTag(std::make_shared<lp::IncomingFaceIdTag>(123));
Zhiyi Zhanga499aa22019-09-24 15:00:40 -0700347 }
Davide Pesavento21e24f92025-01-10 22:22:43 -0500348 auto successResp = this->makeResponse(200, "OK", parameters);
Yanbiao Licf0db022016-01-29 00:54:25 -0800349 auto failureResp = ControlResponse(403, "authorization rejected");
350
351 BOOST_CHECK_EQUAL(this->m_responses.size(), 0);
352 this->receiveInterest(commandHost);
353 this->receiveInterest(commandHop);
354
355 auto nExpectedResponses = this->m_status.isLocalhopConfigured ? 2 : 1;
356 auto expectedLocalhostResponse = this->m_status.isLocalhostConfigured ? successResp : failureResp;
357 auto expectedLocalhopResponse = this->m_status.isLocalhopConfigured ? successResp : failureResp;
358
359 BOOST_REQUIRE_EQUAL(this->m_responses.size(), nExpectedResponses);
Junxiao Shi8a1f1702017-07-03 00:05:08 +0000360 BOOST_CHECK_EQUAL(this->checkResponse(0, commandHost.getName(), expectedLocalhostResponse),
Yanbiao Licf0db022016-01-29 00:54:25 -0800361 ManagerCommonFixture::CheckResponseResult::OK);
362 if (nExpectedResponses == 2) {
Junxiao Shi8a1f1702017-07-03 00:05:08 +0000363 BOOST_CHECK_EQUAL(this->checkResponse(1, commandHop.getName(), expectedLocalhopResponse),
Yanbiao Licf0db022016-01-29 00:54:25 -0800364 ManagerCommonFixture::CheckResponseResult::OK);
365 }
Vince Lehman72446ec2014-07-09 10:50:02 -0500366}
367
Yanbiao Licf0db022016-01-29 00:54:25 -0800368BOOST_FIXTURE_TEST_SUITE(RegisterUnregister, LocalhostAuthorizedRibManagerFixture)
369
370BOOST_AUTO_TEST_CASE(Basic)
Vince Lehman72446ec2014-07-09 10:50:02 -0500371{
Yanbiao Licf0db022016-01-29 00:54:25 -0800372 auto paramsRegister = makeRegisterParameters("/test-register-unregister", 9527);
373 auto paramsUnregister = makeUnregisterParameters("/test-register-unregister", 9527);
Vince Lehman72446ec2014-07-09 10:50:02 -0500374
Davide Pesavento1d2d3372025-01-14 12:04:12 -0500375 auto commandRegister = makeControlCommandRequest(REG_REQUEST, paramsRegister);
Junxiao Shi8a1f1702017-07-03 00:05:08 +0000376 commandRegister.setTag(make_shared<lp::IncomingFaceIdTag>(1234));
Davide Pesavento1d2d3372025-01-14 12:04:12 -0500377 auto commandUnregister = makeControlCommandRequest(UNREG_REQUEST, paramsUnregister);
Junxiao Shi8a1f1702017-07-03 00:05:08 +0000378 commandUnregister.setTag(make_shared<lp::IncomingFaceIdTag>(1234));
Vince Lehman72446ec2014-07-09 10:50:02 -0500379
Yanbiao Licf0db022016-01-29 00:54:25 -0800380 receiveInterest(commandRegister);
381 receiveInterest(commandUnregister);
Vince Lehman72446ec2014-07-09 10:50:02 -0500382
Yanbiao Licf0db022016-01-29 00:54:25 -0800383 BOOST_REQUIRE_EQUAL(m_responses.size(), 2);
Davide Pesavento21e24f92025-01-10 22:22:43 -0500384 BOOST_CHECK_EQUAL(checkResponse(0, commandRegister.getName(), makeResponse(200, "OK", paramsRegister)),
Yanbiao Licf0db022016-01-29 00:54:25 -0800385 CheckResponseResult::OK);
Davide Pesavento21e24f92025-01-10 22:22:43 -0500386 BOOST_CHECK_EQUAL(checkResponse(1, commandUnregister.getName(), makeResponse(200, "OK", paramsUnregister)),
Yanbiao Licf0db022016-01-29 00:54:25 -0800387 CheckResponseResult::OK);
Vince Lehman72446ec2014-07-09 10:50:02 -0500388
Junxiao Shidf1dc652019-08-30 19:03:19 +0000389 BOOST_REQUIRE_EQUAL(m_fibUpdater.updates.size(), 2);
390 BOOST_CHECK_EQUAL(m_fibUpdater.updates.front(),
391 rib::FibUpdate::createAddUpdate("/test-register-unregister", 9527, 10));
392 BOOST_CHECK_EQUAL(m_fibUpdater.updates.back(),
393 rib::FibUpdate::createRemoveUpdate("/test-register-unregister", 9527));
Vince Lehman72446ec2014-07-09 10:50:02 -0500394}
395
Yanbiao Licf0db022016-01-29 00:54:25 -0800396BOOST_AUTO_TEST_CASE(SelfOperation)
Vince Lehman72446ec2014-07-09 10:50:02 -0500397{
Yanbiao Licf0db022016-01-29 00:54:25 -0800398 auto paramsRegister = makeRegisterParameters("/test-self-register-unregister");
399 auto paramsUnregister = makeUnregisterParameters("/test-self-register-unregister");
400 BOOST_CHECK_EQUAL(paramsRegister.getFaceId(), 0);
401 BOOST_CHECK_EQUAL(paramsUnregister.getFaceId(), 0);
Vince Lehman72446ec2014-07-09 10:50:02 -0500402
Yanbiao Licf0db022016-01-29 00:54:25 -0800403 const uint64_t inFaceId = 9527;
Davide Pesavento1d2d3372025-01-14 12:04:12 -0500404 auto commandRegister = makeControlCommandRequest(REG_REQUEST, paramsRegister);
Junxiao Shi8a1f1702017-07-03 00:05:08 +0000405 commandRegister.setTag(make_shared<lp::IncomingFaceIdTag>(inFaceId));
Davide Pesavento1d2d3372025-01-14 12:04:12 -0500406 auto commandUnregister = makeControlCommandRequest(UNREG_REQUEST, paramsUnregister);
Junxiao Shi8a1f1702017-07-03 00:05:08 +0000407 commandUnregister.setTag(make_shared<lp::IncomingFaceIdTag>(inFaceId));
Vince Lehman72446ec2014-07-09 10:50:02 -0500408
Yanbiao Licf0db022016-01-29 00:54:25 -0800409 receiveInterest(commandRegister);
410 receiveInterest(commandUnregister);
Vince Lehman72446ec2014-07-09 10:50:02 -0500411
Yanbiao Licf0db022016-01-29 00:54:25 -0800412 paramsRegister.setFaceId(inFaceId);
413 paramsUnregister.setFaceId(inFaceId);
Vince Lehman72446ec2014-07-09 10:50:02 -0500414
Yanbiao Licf0db022016-01-29 00:54:25 -0800415 BOOST_REQUIRE_EQUAL(m_responses.size(), 2);
Davide Pesavento21e24f92025-01-10 22:22:43 -0500416 BOOST_CHECK_EQUAL(checkResponse(0, commandRegister.getName(), makeResponse(200, "OK", paramsRegister)),
Yanbiao Licf0db022016-01-29 00:54:25 -0800417 CheckResponseResult::OK);
Davide Pesavento21e24f92025-01-10 22:22:43 -0500418 BOOST_CHECK_EQUAL(checkResponse(1, commandUnregister.getName(), makeResponse(200, "OK", paramsUnregister)),
Yanbiao Licf0db022016-01-29 00:54:25 -0800419 CheckResponseResult::OK);
Vince Lehman72446ec2014-07-09 10:50:02 -0500420
Junxiao Shidf1dc652019-08-30 19:03:19 +0000421 BOOST_REQUIRE_EQUAL(m_fibUpdater.updates.size(), 2);
422 BOOST_CHECK_EQUAL(m_fibUpdater.updates.front(),
423 rib::FibUpdate::createAddUpdate("/test-self-register-unregister", 9527, 10));
424 BOOST_CHECK_EQUAL(m_fibUpdater.updates.back(),
425 rib::FibUpdate::createRemoveUpdate("/test-self-register-unregister", 9527));
Vince Lehman72446ec2014-07-09 10:50:02 -0500426}
427
Yanbiao Licf0db022016-01-29 00:54:25 -0800428BOOST_AUTO_TEST_CASE(Expiration)
Junxiao Shi0de23a22015-12-03 20:07:02 +0000429{
Davide Pesavento8a05c7f2019-02-28 02:26:19 -0500430 auto paramsRegister = makeRegisterParameters("/test-expiry", 9527, 50_ms);
Yanbiao Licf0db022016-01-29 00:54:25 -0800431 auto paramsUnregister = makeRegisterParameters("/test-expiry", 9527);
Davide Pesavento1d2d3372025-01-14 12:04:12 -0500432 receiveInterest(makeControlCommandRequest(REG_REQUEST, paramsRegister));
Junxiao Shi0de23a22015-12-03 20:07:02 +0000433
Davide Pesavento8a05c7f2019-02-28 02:26:19 -0500434 advanceClocks(55_ms);
Junxiao Shidf1dc652019-08-30 19:03:19 +0000435 BOOST_REQUIRE_EQUAL(m_fibUpdater.updates.size(), 2); // the registered route has expired
436 BOOST_CHECK_EQUAL(m_fibUpdater.updates.front(),
437 rib::FibUpdate::createAddUpdate("/test-expiry", 9527, 10));
438 BOOST_CHECK_EQUAL(m_fibUpdater.updates.back(),
439 rib::FibUpdate::createRemoveUpdate("/test-expiry", 9527));
Junxiao Shi0de23a22015-12-03 20:07:02 +0000440
Junxiao Shidf1dc652019-08-30 19:03:19 +0000441 m_fibUpdater.updates.clear();
Davide Pesavento8a05c7f2019-02-28 02:26:19 -0500442 paramsRegister.setExpirationPeriod(100_ms);
Davide Pesavento1d2d3372025-01-14 12:04:12 -0500443 receiveInterest(makeControlCommandRequest(REG_REQUEST, paramsRegister));
Junxiao Shi0de23a22015-12-03 20:07:02 +0000444
Davide Pesavento8a05c7f2019-02-28 02:26:19 -0500445 advanceClocks(55_ms);
Junxiao Shidf1dc652019-08-30 19:03:19 +0000446 BOOST_REQUIRE_EQUAL(m_fibUpdater.updates.size(), 1); // the registered route is still active
447 BOOST_CHECK_EQUAL(m_fibUpdater.updates.front(),
448 rib::FibUpdate::createAddUpdate("/test-expiry", 9527, 10));
Junxiao Shi0de23a22015-12-03 20:07:02 +0000449}
450
Junxiao Shi75306352018-02-01 21:59:44 +0000451BOOST_AUTO_TEST_CASE(NameTooLong)
452{
453 Name prefix;
Davide Pesavento2cae8ca2019-04-18 20:48:05 -0400454 while (prefix.size() <= Fib::getMaxDepth()) {
Junxiao Shi75306352018-02-01 21:59:44 +0000455 prefix.append("A");
456 }
457 auto params = makeRegisterParameters(prefix, 2899);
Davide Pesavento1d2d3372025-01-14 12:04:12 -0500458 auto command = makeControlCommandRequest(REG_REQUEST, params);
jaczhib0657682025-01-08 23:01:45 -0800459
Junxiao Shi75306352018-02-01 21:59:44 +0000460 receiveInterest(command);
461
462 BOOST_REQUIRE_EQUAL(m_responses.size(), 1);
Davide Pesavento2cae8ca2019-04-18 20:48:05 -0400463 BOOST_CHECK_EQUAL(checkResponse(0, command.getName(),
464 ControlResponse(414, "Route prefix cannot exceed " +
Davide Pesavento2c9d2ca2024-01-27 16:36:51 -0500465 std::to_string(Fib::getMaxDepth()) + " components")),
Junxiao Shi75306352018-02-01 21:59:44 +0000466 CheckResponseResult::OK);
467
Junxiao Shidf1dc652019-08-30 19:03:19 +0000468 BOOST_CHECK_EQUAL(m_fibUpdater.updates.size(), 0);
Junxiao Shi75306352018-02-01 21:59:44 +0000469}
470
Yanbiao Licf0db022016-01-29 00:54:25 -0800471BOOST_AUTO_TEST_SUITE_END() // RegisterUnregister
472
jaczhib0657682025-01-08 23:01:45 -0800473BOOST_FIXTURE_TEST_SUITE(PrefixAnnounce, LocalhostAuthorizedRibManagerFixture)
474
475BOOST_AUTO_TEST_CASE(Basic)
476{
477 const uint64_t announceFaceId = 1234;
478
479 ndn::PrefixAnnouncement pa = signPrefixAnn(makePrefixAnn("/test-prefix-announce", 10_s), m_keyChain);
Davide Pesavento1d2d3372025-01-14 12:04:12 -0500480 auto commandAnnounce = makeControlCommandRequest(ANNOUNCE_REQUEST, pa);
jaczhib0657682025-01-08 23:01:45 -0800481 commandAnnounce.setTag(make_shared<lp::IncomingFaceIdTag>(announceFaceId));
482
483 auto paramsUnregister = makeUnregisterParameters("/test-prefix-announce");
484 paramsUnregister.setOrigin(ndn::nfd::ROUTE_ORIGIN_PREFIXANN);
485 BOOST_CHECK_EQUAL(paramsUnregister.getFaceId(), 0);
Davide Pesavento1d2d3372025-01-14 12:04:12 -0500486 auto commandUnregister = makeControlCommandRequest(UNREG_REQUEST, paramsUnregister);
jaczhib0657682025-01-08 23:01:45 -0800487 commandUnregister.setTag(make_shared<lp::IncomingFaceIdTag>(announceFaceId)); // same incoming face
488
489 receiveInterest(commandAnnounce);
490 receiveInterest(commandUnregister);
491
492 ControlParameters paramsAnnounceResponse;
493 paramsAnnounceResponse.setName("/test-prefix-announce")
494 .setFaceId(announceFaceId)
495 .setOrigin(ndn::nfd::ROUTE_ORIGIN_PREFIXANN)
496 .setCost(rib::Route::PA_ROUTE_COST)
497 .setFlags(ndn::nfd::ROUTE_FLAG_CHILD_INHERIT)
498 .setExpirationPeriod(10_s);
499 paramsUnregister.setFaceId(announceFaceId);
500
501 BOOST_REQUIRE_EQUAL(m_responses.size(), 2);
Davide Pesavento21e24f92025-01-10 22:22:43 -0500502 BOOST_CHECK_EQUAL(checkResponse(0, commandAnnounce.getName(), makeResponse(200, "OK", paramsAnnounceResponse)),
jaczhib0657682025-01-08 23:01:45 -0800503 CheckResponseResult::OK);
Davide Pesavento21e24f92025-01-10 22:22:43 -0500504 BOOST_CHECK_EQUAL(checkResponse(1, commandUnregister.getName(), makeResponse(200, "OK", paramsUnregister)),
jaczhib0657682025-01-08 23:01:45 -0800505 CheckResponseResult::OK);
506
507 BOOST_REQUIRE_EQUAL(m_fibUpdater.updates.size(), 2);
508 BOOST_CHECK_EQUAL(m_fibUpdater.updates.front(),
Davide Pesavento21e24f92025-01-10 22:22:43 -0500509 rib::FibUpdate::createAddUpdate("/test-prefix-announce", announceFaceId,
510 rib::Route::PA_ROUTE_COST));
jaczhib0657682025-01-08 23:01:45 -0800511 BOOST_CHECK_EQUAL(m_fibUpdater.updates.back(),
512 rib::FibUpdate::createRemoveUpdate("/test-prefix-announce", announceFaceId));
513}
514
515BOOST_AUTO_TEST_CASE(UnregisterFromDifferentFace)
516{
517 const uint64_t announceFaceId = 1234;
518
519 ndn::PrefixAnnouncement pa = signPrefixAnn(makePrefixAnn("/test-prefix-announce", 10_s), m_keyChain);
Davide Pesavento1d2d3372025-01-14 12:04:12 -0500520 auto commandAnnounce = makeControlCommandRequest(ANNOUNCE_REQUEST, pa);
jaczhib0657682025-01-08 23:01:45 -0800521 commandAnnounce.setTag(make_shared<lp::IncomingFaceIdTag>(announceFaceId));
522
523 auto paramsUnregister = makeUnregisterParameters("/test-prefix-announce", announceFaceId);
524 paramsUnregister.setOrigin(ndn::nfd::ROUTE_ORIGIN_PREFIXANN);
Davide Pesavento1d2d3372025-01-14 12:04:12 -0500525 auto commandUnregister = makeControlCommandRequest(UNREG_REQUEST, paramsUnregister);
jaczhib0657682025-01-08 23:01:45 -0800526 commandUnregister.setTag(make_shared<lp::IncomingFaceIdTag>(999)); // unregister from different face
527
528 receiveInterest(commandAnnounce);
529 receiveInterest(commandUnregister);
530
531 ControlParameters paramsAnnounceResponse;
532 paramsAnnounceResponse.setName("/test-prefix-announce")
533 .setFaceId(announceFaceId)
534 .setOrigin(ndn::nfd::ROUTE_ORIGIN_PREFIXANN)
535 .setCost(rib::Route::PA_ROUTE_COST)
536 .setFlags(ndn::nfd::ROUTE_FLAG_CHILD_INHERIT)
537 .setExpirationPeriod(10_s);
538
539 BOOST_REQUIRE_EQUAL(m_responses.size(), 2);
Davide Pesavento21e24f92025-01-10 22:22:43 -0500540 BOOST_CHECK_EQUAL(checkResponse(0, commandAnnounce.getName(), makeResponse(200, "OK", paramsAnnounceResponse)),
jaczhib0657682025-01-08 23:01:45 -0800541 CheckResponseResult::OK);
Davide Pesavento21e24f92025-01-10 22:22:43 -0500542 BOOST_CHECK_EQUAL(checkResponse(1, commandUnregister.getName(), makeResponse(200, "OK", paramsUnregister)),
jaczhib0657682025-01-08 23:01:45 -0800543 CheckResponseResult::OK);
544
545 BOOST_REQUIRE_EQUAL(m_fibUpdater.updates.size(), 2);
546 BOOST_CHECK_EQUAL(m_fibUpdater.updates.front(),
Davide Pesavento21e24f92025-01-10 22:22:43 -0500547 rib::FibUpdate::createAddUpdate("/test-prefix-announce", announceFaceId,
548 rib::Route::PA_ROUTE_COST));
jaczhib0657682025-01-08 23:01:45 -0800549 BOOST_CHECK_EQUAL(m_fibUpdater.updates.back(),
550 rib::FibUpdate::createRemoveUpdate("/test-prefix-announce", announceFaceId));
551}
552
553BOOST_AUTO_TEST_CASE(NameTooLong)
554{
555 Name prefix;
556 while (prefix.size() <= Fib::getMaxDepth()) {
557 prefix.append("A");
558 }
559 ndn::PrefixAnnouncement pa = signPrefixAnn(makePrefixAnn(prefix, 10_s), m_keyChain);
Davide Pesavento1d2d3372025-01-14 12:04:12 -0500560 auto command = makeControlCommandRequest(ANNOUNCE_REQUEST, pa);
jaczhib0657682025-01-08 23:01:45 -0800561 command.setTag(make_shared<lp::IncomingFaceIdTag>(333));
562
563 receiveInterest(command);
564
565 BOOST_REQUIRE_EQUAL(m_responses.size(), 1);
566 BOOST_CHECK_EQUAL(checkResponse(0, command.getName(),
567 ControlResponse(414, "Route prefix cannot exceed " +
568 std::to_string(Fib::getMaxDepth()) + " components")),
569 CheckResponseResult::OK);
570
571 BOOST_CHECK_EQUAL(m_fibUpdater.updates.size(), 0);
572}
573
574BOOST_AUTO_TEST_SUITE_END() // PrefixAnnounce
575
Yanbiao Licf0db022016-01-29 00:54:25 -0800576BOOST_FIXTURE_TEST_CASE(RibDataset, UnauthorizedRibManagerFixture)
Vince Lehman72446ec2014-07-09 10:50:02 -0500577{
Yanbiao Licf0db022016-01-29 00:54:25 -0800578 uint64_t faceId = 0;
Davide Pesavento8a05c7f2019-02-28 02:26:19 -0500579 auto generateRoute = [&faceId] () -> rib::Route {
580 rib::Route route;
Yanbiao Licf0db022016-01-29 00:54:25 -0800581 route.faceId = ++faceId;
Davide Pesaventod2ea2352017-03-12 20:38:09 -0400582 route.cost = route.faceId * 10;
Davide Pesaventob7bfcb92022-05-22 23:55:23 -0400583 route.expires = std::nullopt;
Yanbiao Licf0db022016-01-29 00:54:25 -0800584 return route;
585 };
Vince Lehman72446ec2014-07-09 10:50:02 -0500586
Yanbiao Licf0db022016-01-29 00:54:25 -0800587 const size_t nEntries = 108;
588 std::set<Name> actualPrefixes;
589 for (size_t i = 0; i < nEntries; ++i) {
590 Name prefix = Name("/test-dataset").appendNumber(i);
591 actualPrefixes.insert(prefix);
592 m_rib.insert(prefix, generateRoute());
593 if (i & 0x1) {
594 m_rib.insert(prefix, generateRoute());
595 m_rib.insert(prefix, generateRoute());
596 }
597 }
Vince Lehman72446ec2014-07-09 10:50:02 -0500598
Junxiao Shi9d727852019-05-14 13:44:22 -0600599 receiveInterest(*makeInterest("/localhost/nfd/rib/list", true));
Vince Lehman72446ec2014-07-09 10:50:02 -0500600
Davide Pesaventod2ea2352017-03-12 20:38:09 -0400601 Block content = concatenateResponses();
602 content.parse();
Yanbiao Licf0db022016-01-29 00:54:25 -0800603 BOOST_REQUIRE_EQUAL(content.elements().size(), nEntries);
604
Davide Pesaventod2ea2352017-03-12 20:38:09 -0400605 std::vector<ndn::nfd::RibEntry> receivedRecords, expectedRecords;
Yanbiao Licf0db022016-01-29 00:54:25 -0800606 for (size_t idx = 0; idx < nEntries; ++idx) {
Davide Pesaventod2ea2352017-03-12 20:38:09 -0400607 ndn::nfd::RibEntry decodedEntry(content.elements()[idx]);
Davide Pesaventod7083a52023-10-19 17:51:16 -0400608 BOOST_TEST_INFO_SCOPE(decodedEntry);
Yanbiao Licf0db022016-01-29 00:54:25 -0800609 receivedRecords.push_back(decodedEntry);
Yanbiao Licf0db022016-01-29 00:54:25 -0800610 actualPrefixes.erase(decodedEntry.getName());
611
612 auto matchedEntryIt = m_rib.find(decodedEntry.getName());
613 BOOST_REQUIRE(matchedEntryIt != m_rib.end());
614
615 auto matchedEntry = matchedEntryIt->second;
616 BOOST_REQUIRE(matchedEntry != nullptr);
617
Davide Pesaventod2ea2352017-03-12 20:38:09 -0400618 expectedRecords.emplace_back();
619 expectedRecords.back().setName(matchedEntry->getName());
620 for (const auto& route : matchedEntry->getRoutes()) {
621 expectedRecords.back().addRoute(ndn::nfd::Route()
622 .setFaceId(route.faceId)
623 .setOrigin(route.origin)
624 .setCost(route.cost)
625 .setFlags(route.flags));
Yanbiao Licf0db022016-01-29 00:54:25 -0800626 }
Yanbiao Licf0db022016-01-29 00:54:25 -0800627 }
628
629 BOOST_CHECK_EQUAL(actualPrefixes.size(), 0);
Davide Pesaventoa3a7a4e2022-05-29 16:06:22 -0400630 BOOST_TEST(receivedRecords == expectedRecords, boost::test_tools::per_element());
Vince Lehman72446ec2014-07-09 10:50:02 -0500631}
632
Yanbiao Licf0db022016-01-29 00:54:25 -0800633BOOST_FIXTURE_TEST_SUITE(FaceMonitor, LocalhostAuthorizedRibManagerFixture)
634
635BOOST_AUTO_TEST_CASE(FetchActiveFacesEvent)
Vince Lehmancd16c832014-07-23 15:14:55 -0700636{
Junxiao Shidf1dc652019-08-30 19:03:19 +0000637 BOOST_CHECK_EQUAL(m_fibUpdater.updates.size(), 0);
Vince Lehman76c751c2014-11-18 17:36:38 -0600638
Davide Pesavento8a05c7f2019-02-28 02:26:19 -0500639 advanceClocks(301_s); // RibManager::ACTIVE_FACE_FETCH_INTERVAL = 300s
Junxiao Shidf1dc652019-08-30 19:03:19 +0000640 BOOST_REQUIRE_EQUAL(m_face.sentInterests.size(), 2);
641 BOOST_CHECK_EQUAL(m_face.sentInterests[0].getName(), "/localhost/nfd/faces/events");
642 BOOST_CHECK_EQUAL(m_face.sentInterests[1].getName(), "/localhost/nfd/faces/list");
Vince Lehmancd16c832014-07-23 15:14:55 -0700643}
644
Yanbiao Licf0db022016-01-29 00:54:25 -0800645BOOST_AUTO_TEST_CASE(RemoveInvalidFaces)
Vince Lehman281ded72014-08-21 12:17:08 -0500646{
Yanbiao Licf0db022016-01-29 00:54:25 -0800647 auto parameters1 = makeRegisterParameters("/test-remove-invalid-faces-1");
648 auto parameters2 = makeRegisterParameters("/test-remove-invalid-faces-2");
Davide Pesavento1d2d3372025-01-14 12:04:12 -0500649 receiveInterest(makeControlCommandRequest(REG_REQUEST, parameters1.setFaceId(1)));
650 receiveInterest(makeControlCommandRequest(REG_REQUEST, parameters1.setFaceId(2)));
651 receiveInterest(makeControlCommandRequest(REG_REQUEST, parameters2.setFaceId(2)));
Yanbiao Licf0db022016-01-29 00:54:25 -0800652 BOOST_REQUIRE_EQUAL(m_rib.size(), 3);
Vince Lehman281ded72014-08-21 12:17:08 -0500653
Vince Lehman26b215c2014-08-17 15:00:41 -0500654 ndn::nfd::FaceStatus status;
655 status.setFaceId(1);
Weiwei Liu6e21cdb2016-09-29 15:16:23 -0700656 std::vector<ndn::nfd::FaceStatus> activeFaces;
657 activeFaces.push_back(status);
Vince Lehman26b215c2014-08-17 15:00:41 -0500658
Weiwei Liu6e21cdb2016-09-29 15:16:23 -0700659 m_manager.removeInvalidFaces(activeFaces);
Davide Pesavento8a05c7f2019-02-28 02:26:19 -0500660 advanceClocks(100_ms);
Yanbiao Licf0db022016-01-29 00:54:25 -0800661 BOOST_REQUIRE_EQUAL(m_rib.size(), 1);
Vince Lehman26b215c2014-08-17 15:00:41 -0500662
Yanbiao Licf0db022016-01-29 00:54:25 -0800663 auto it1 = m_rib.find("/test-remove-invalid-faces-1");
664 auto it2 = m_rib.find("/test-remove-invalid-faces-2");
665 BOOST_CHECK(it2 == m_rib.end());
666 BOOST_REQUIRE(it1 != m_rib.end());
667 BOOST_CHECK(it1->second->hasFaceId(1));
668 BOOST_CHECK(!it1->second->hasFaceId(2));
Vince Lehman26b215c2014-08-17 15:00:41 -0500669}
670
Yanbiao Licf0db022016-01-29 00:54:25 -0800671BOOST_AUTO_TEST_CASE(OnNotification)
Vince Lehman7c7d33a2015-01-20 17:40:26 -0600672{
Yanbiao Licf0db022016-01-29 00:54:25 -0800673 auto parameters1 = makeRegisterParameters("/test-face-event-notification-1", 1);
674 auto parameters2 = makeRegisterParameters("/test-face-event-notification-2", 1);
Davide Pesavento1d2d3372025-01-14 12:04:12 -0500675 receiveInterest(makeControlCommandRequest(REG_REQUEST, parameters1));
676 receiveInterest(makeControlCommandRequest(REG_REQUEST, parameters2));
Yanbiao Licf0db022016-01-29 00:54:25 -0800677 BOOST_REQUIRE_EQUAL(m_rib.size(), 2);
Vince Lehman7c7d33a2015-01-20 17:40:26 -0600678
Davide Pesavento8a05c7f2019-02-28 02:26:19 -0500679 auto makeNotification = [] (ndn::nfd::FaceEventKind kind, uint64_t faceId) {
680 return ndn::nfd::FaceEventNotification().setKind(kind).setFaceId(faceId);
Yanbiao Licf0db022016-01-29 00:54:25 -0800681 };
Vince Lehman7c7d33a2015-01-20 17:40:26 -0600682
Yanbiao Licf0db022016-01-29 00:54:25 -0800683 m_manager.onNotification(makeNotification(ndn::nfd::FaceEventKind::FACE_EVENT_DESTROYED, 1));
Davide Pesavento8a05c7f2019-02-28 02:26:19 -0500684 advanceClocks(100_ms);
Yanbiao Licf0db022016-01-29 00:54:25 -0800685 BOOST_CHECK_EQUAL(m_rib.size(), 0);
Vince Lehman7c7d33a2015-01-20 17:40:26 -0600686
Yanbiao Licf0db022016-01-29 00:54:25 -0800687 m_manager.onNotification(makeNotification(ndn::nfd::FaceEventKind::FACE_EVENT_CREATED, 2));
Davide Pesavento8a05c7f2019-02-28 02:26:19 -0500688 advanceClocks(100_ms);
Yanbiao Licf0db022016-01-29 00:54:25 -0800689 BOOST_CHECK_EQUAL(m_rib.size(), 0);
Vince Lehman7c7d33a2015-01-20 17:40:26 -0600690}
691
Yanbiao Licf0db022016-01-29 00:54:25 -0800692BOOST_AUTO_TEST_SUITE_END() // FaceMonitor
Davide Pesavento8a05c7f2019-02-28 02:26:19 -0500693
Yanbiao Licf0db022016-01-29 00:54:25 -0800694BOOST_AUTO_TEST_SUITE_END() // TestRibManager
Davide Pesavento8a05c7f2019-02-28 02:26:19 -0500695BOOST_AUTO_TEST_SUITE_END() // Mgmt
Vince Lehman72446ec2014-07-09 10:50:02 -0500696
Davide Pesaventoe422f9e2022-06-03 01:30:23 -0400697} // namespace nfd::tests