blob: 26644f883d80459086b4d0123ad5719b55bc92d7 [file] [log] [blame]
Saurab Dulal7526cee2018-01-31 18:14:10 +00001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Ashlesh Gawande5d93aa52020-06-13 18:57:45 -07002/*
3 * Copyright (c) 2014-2021, The University of Memphis,
Saurab Dulal7526cee2018-01-31 18:14:10 +00004 * Regents of the University of California,
5 * Arizona Board of Regents.
6 *
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/>.
Ashlesh Gawande5d93aa52020-06-13 18:57:45 -070020 */
Saurab Dulal7526cee2018-01-31 18:14:10 +000021
22#include "update/prefix-update-processor.hpp"
Saurab Dulal7526cee2018-01-31 18:14:10 +000023#include "nlsr.hpp"
24
Saurab Dulal427e0122019-11-28 11:58:02 -060025#include "tests/control-commands.hpp"
26#include "tests/test-common.hpp"
dulalsaurab82a34c22019-02-04 17:31:21 +000027#include "conf-parameter.hpp"
Junxiao Shi008c9b12019-01-13 23:15:56 +000028
Saurab Dulal7526cee2018-01-31 18:14:10 +000029#include <ndn-cxx/mgmt/nfd/control-response.hpp>
Junxiao Shi008c9b12019-01-13 23:15:56 +000030#include <ndn-cxx/security/command-interest-signer.hpp>
Saurab Dulal7526cee2018-01-31 18:14:10 +000031#include <ndn-cxx/security/pib/identity.hpp>
32#include <ndn-cxx/security/signing-helpers.hpp>
Junxiao Shi008c9b12019-01-13 23:15:56 +000033
Saurab Dulal7526cee2018-01-31 18:14:10 +000034#include <boost/filesystem.hpp>
35
36namespace nlsr {
Saurab Dulal7526cee2018-01-31 18:14:10 +000037namespace test {
38
39namespace pt = boost::property_tree;
40using namespace pt;
41
42class PrefixSaveDeleteFixture : public nlsr::test::UnitTestTimeFixture
43{
44public:
45 PrefixSaveDeleteFixture()
46 : face(m_ioService, m_keyChain, {true, true})
47 , siteIdentityName(ndn::Name("/edu/test-site"))
48 , opIdentityName(ndn::Name("/edu/test-site").append(ndn::Name("%C1.Operator")))
Saurab Dulal7526cee2018-01-31 18:14:10 +000049 , testConfFile("/tmp/nlsr.conf.test")
Saurab Dulal427e0122019-11-28 11:58:02 -060050 , conf(face, m_keyChain, testConfFile)
Ashlesh Gawande85998a12017-12-07 22:22:13 -060051 , confProcessor(conf)
52 , nlsr(face, m_keyChain, conf)
53 , SITE_CERT_PATH(boost::filesystem::current_path() / std::string("site.cert"))
Saurab Dulal7526cee2018-01-31 18:14:10 +000054 , counter(0)
55 {
Ashlesh Gawande30d96e42021-03-21 19:15:33 -070056 std::ifstream source("nlsr.conf", std::ios::binary);
Ashlesh Gawande85998a12017-12-07 22:22:13 -060057 std::ofstream destination(testConfFile, std::ios::binary);
Saurab Dulal7526cee2018-01-31 18:14:10 +000058 destination << source.rdbuf();
59 source.close();
60 destination.close();
61
dulalsaurab82a34c22019-02-04 17:31:21 +000062 conf.setConfFileNameDynamic(testConfFile);
Saurab Dulal7526cee2018-01-31 18:14:10 +000063 siteIdentity = addIdentity(siteIdentityName);
64 saveCertificate(siteIdentity, SITE_CERT_PATH.string());
65
66 // Operator cert
67 opIdentity = addSubCertificate(opIdentityName, siteIdentity);
68 // Loading the security section's validator part into the validator
69 // See conf file processor for more details
70 std::ifstream inputFile;
71 inputFile.open(testConfFile);
72 BOOST_REQUIRE(inputFile.is_open());
73 pt::ptree pt;
74 boost::property_tree::read_info(inputFile, pt);
75 // Loads section and file name
76 for (const auto& section : pt) {
77 if (section.first == "security") {
Ashlesh Gawande85998a12017-12-07 22:22:13 -060078 for (const auto& it : section.second) {
79 if (it.first == "prefix-update-validator") {
80 conf.getPrefixUpdateValidator().load(it.second, std::string("nlsr.conf"));
81 }
Saurab Dulal7526cee2018-01-31 18:14:10 +000082 }
Saurab Dulal7526cee2018-01-31 18:14:10 +000083 }
84 }
dulalsaurab82a34c22019-02-04 17:31:21 +000085
Saurab Dulal7526cee2018-01-31 18:14:10 +000086 inputFile.close();
Ashlesh Gawande85998a12017-12-07 22:22:13 -060087
Saurab Dulal7526cee2018-01-31 18:14:10 +000088 // Site cert
89 siteIdentity = addIdentity(siteIdentityName);
90 saveCertificate(siteIdentity, SITE_CERT_PATH.string());
91
92 // Operator cert
93 opIdentity = addSubCertificate(opIdentityName, siteIdentity);
Saurab Dulal427e0122019-11-28 11:58:02 -060094
95 // Create certificate and load it to the validator
96 conf.initializeKey();
97 conf.loadCertToValidator(siteIdentity.getDefaultKey().getDefaultCertificate());
98 conf.loadCertToValidator(opIdentity.getDefaultKey().getDefaultCertificate());
Saurab Dulal7526cee2018-01-31 18:14:10 +000099
100 // Set the network so the LSA prefix is constructed
Ashlesh Gawande85998a12017-12-07 22:22:13 -0600101 addIdentity(conf.getRouterPrefix());
Saurab Dulal7526cee2018-01-31 18:14:10 +0000102
Saurab Dulal7526cee2018-01-31 18:14:10 +0000103 this->advanceClocks(ndn::time::milliseconds(10));
104 face.sentInterests.clear();
105 }
106
107 uint32_t
108 getResponseCode()
109 {
110 ndn::nfd::ControlResponse response;
111 for (const auto& data : face.sentData) {
112 response.wireDecode(data.getContent().blockFromValue());
113 }
114 return response.getCode();
115 }
116
117 bool
118 checkPrefix(const std::string prefixName)
119 {
120 counter = 0;
121 pt::ptree m_savePrefix;
122 pt::info_parser::read_info(testConfFile, m_savePrefix);
123 // counter helps to check if multiple prefix of same name exists on conf file
124 for (const auto& section : m_savePrefix.get_child("advertising")) {
125 std:: string b = section.second.get_value<std::string>();
126 if (b == prefixName) {
127 counter++;
128 }
129 }
130 if (counter > 0) {
131 return true;
132 }
133 return false;
134 }
135
136 ndn::Interest
137 advertiseWithdraw(std::string prefixName, std::string type, bool P_FLAG)
138 {
139 ndn::nfd::ControlParameters parameters;
140 parameters.setName(prefixName);
141 if (P_FLAG)
142 {
Ashlesh Gawande85998a12017-12-07 22:22:13 -0600143 parameters.setFlags(update::PREFIX_FLAG);
Saurab Dulal7526cee2018-01-31 18:14:10 +0000144 }
145 ndn::Name advertiseCommand("/localhost/nlsr/prefix-update/advertise");
146 ndn::Name withdrawCommand("/localhost/nlsr/prefix-update/withdraw");
Saurab Dulal7526cee2018-01-31 18:14:10 +0000147 ndn::security::CommandInterestSigner cis(m_keyChain);
148 // type true for advertise, else withdraw
149 if (type == "advertise") {
150 advertiseCommand.append(parameters.wireEncode());
Junxiao Shi008c9b12019-01-13 23:15:56 +0000151 return cis.makeCommandInterest(advertiseCommand, ndn::security::signingByIdentity(opIdentity));
Saurab Dulal7526cee2018-01-31 18:14:10 +0000152 }
153 else {
154 withdrawCommand.append(parameters.wireEncode());
Junxiao Shi008c9b12019-01-13 23:15:56 +0000155 return cis.makeCommandInterest(withdrawCommand, ndn::security::signingByIdentity(opIdentity));
Saurab Dulal7526cee2018-01-31 18:14:10 +0000156 }
Saurab Dulal7526cee2018-01-31 18:14:10 +0000157 }
158
159public:
160 ndn::util::DummyClientFace face;
Saurab Dulal427e0122019-11-28 11:58:02 -0600161 ndn::Name siteIdentityName, routerIdName;
162 ndn::security::pib::Identity siteIdentity, routerId;
Saurab Dulal7526cee2018-01-31 18:14:10 +0000163
164 ndn::Name opIdentityName;
165 ndn::security::pib::Identity opIdentity;
166
Ashlesh Gawande85998a12017-12-07 22:22:13 -0600167 std::string testConfFile;
168 ConfParameter conf;
169 DummyConfFileProcessor confProcessor;
Saurab Dulal7526cee2018-01-31 18:14:10 +0000170 Nlsr nlsr;
171 const boost::filesystem::path SITE_CERT_PATH;
172 ndn::Name sessionTime;
Saurab Dulal7526cee2018-01-31 18:14:10 +0000173 int counter;
174};
175
176BOOST_FIXTURE_TEST_SUITE(TestAdvertiseWithdrawPrefix, PrefixSaveDeleteFixture)
177
178BOOST_AUTO_TEST_CASE(Basic)
179{
dulalsaurab82a34c22019-02-04 17:31:21 +0000180
Saurab Dulal7526cee2018-01-31 18:14:10 +0000181 face.receive(advertiseWithdraw("/prefix/to/save", "advertise", false));
182 this->advanceClocks(ndn::time::milliseconds(10));
183 BOOST_CHECK_EQUAL(checkPrefix("/prefix/to/save"), false);
184 BOOST_CHECK_EQUAL(getResponseCode(), 200);
185 face.sentData.clear();
186
187 // trying to re-advertise
188 face.receive(advertiseWithdraw("/prefix/to/save", "advertise", false));
189 this->advanceClocks(ndn::time::milliseconds(10));
190 BOOST_CHECK_EQUAL(getResponseCode(), 204);
191 face.sentData.clear();
192
193 // only withdraw
194 face.receive(advertiseWithdraw("/prefix/to/save", "withdraw", false));
195 this->advanceClocks(ndn::time::milliseconds(10));
196 BOOST_CHECK_EQUAL(checkPrefix("/prefix/to/save"), false);
197 BOOST_CHECK_EQUAL(getResponseCode(), 200);
198 face.sentData.clear();
199
200 // trying to re-advertise
201 face.receive(advertiseWithdraw("/prefix/to/save", "withdraw", false));
202 this->advanceClocks(ndn::time::milliseconds(10));
203 BOOST_CHECK_EQUAL(getResponseCode(), 204);
204 face.sentData.clear();
205}
206
207BOOST_AUTO_TEST_CASE(PrefixStillSavedAfterJustWithdrawn)
208{
209 // advertise and save
210 face.receive(advertiseWithdraw("/prefix/to/save", "advertise", true));
211 this->advanceClocks(ndn::time::milliseconds(10));
212 face.sentData.clear();
213 BOOST_CHECK_EQUAL(checkPrefix("/prefix/to/save"), true);
214
215 // trying to advertise same name prefix
dulalsaurab82a34c22019-02-04 17:31:21 +0000216 face.receive(advertiseWithdraw("/prefix/to/save", "advertise", true));
Saurab Dulal7526cee2018-01-31 18:14:10 +0000217 this->advanceClocks(ndn::time::milliseconds(10));
218 BOOST_REQUIRE(counter == 1);
219 BOOST_CHECK_EQUAL(getResponseCode(), 406);
220 face.sentData.clear();
221
222 // only withdraw
223 face.receive(advertiseWithdraw("/prefix/to/save", "withdraw", false));
224 this->advanceClocks(ndn::time::milliseconds(10));
225 // after withdrawing only prefix should still be there
226 BOOST_CHECK_EQUAL(checkPrefix("/prefix/to/save"), true);
227 BOOST_CHECK_EQUAL(getResponseCode(), 200);
228
229 // delete
230 face.receive(advertiseWithdraw("/prefix/to/save", "withdraw", true));
231 this->advanceClocks(ndn::time::milliseconds(10));
232 // after withdrawn delete prefix should be deleted from the file
233 BOOST_CHECK_EQUAL(getResponseCode(), 205);
dulalsaurab82a34c22019-02-04 17:31:21 +0000234 BOOST_CHECK_EQUAL(checkPrefix("/prefix/to/save"), false);
Saurab Dulal7526cee2018-01-31 18:14:10 +0000235}
236
237BOOST_AUTO_TEST_SUITE_END()
238
239} // namespace test
Saurab Dulal7526cee2018-01-31 18:14:10 +0000240} // namespace nlsr