blob: f19a2f0c90ae00c9be63961d5a60908880801423 [file] [log] [blame]
Alexander Afanasyevc169a812014-05-20 20:37:29 -04001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Junxiao Shi71ff2312017-07-12 13:32:50 +00002/*
Davide Pesavento5d36a522024-02-09 01:36:52 -05003 * Copyright (c) 2013-2024 Regents of the University of California.
Alexander Afanasyevdfa52c42014-04-24 21:10:11 -07004 *
5 * This file is part of ndn-cxx library (NDN C++ library with eXperimental eXtensions).
Alexander Afanasyevdfa52c42014-04-24 21:10:11 -07006 *
Alexander Afanasyevc169a812014-05-20 20:37:29 -04007 * ndn-cxx library is free software: you can redistribute it and/or modify it under the
8 * terms of the GNU Lesser General Public License as published by the Free Software
9 * Foundation, either version 3 of the License, or (at your option) any later version.
10 *
11 * ndn-cxx library is distributed in the hope that it will be useful, but WITHOUT ANY
12 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
13 * PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
14 *
15 * You should have received copies of the GNU General Public License and GNU Lesser
16 * General Public License along with ndn-cxx, e.g., in COPYING.md file. If not, see
17 * <http://www.gnu.org/licenses/>.
18 *
19 * See AUTHORS.md for complete list of ndn-cxx authors and contributors.
Alexander Afanasyev52eb20d2014-02-06 18:25:54 -080020 */
21
Davide Pesavento7e780642018-11-24 15:51:34 -050022#include "ndn-cxx/name.hpp"
Alexander Afanasyev52eb20d2014-02-06 18:25:54 -080023
Davide Pesavento7e780642018-11-24 15:51:34 -050024#include "tests/boost-test.hpp"
25
Yingdi Yu90e23582014-11-06 14:21:04 -080026#include <unordered_map>
Davide Pesavento152ef442023-04-22 02:02:29 -040027#include <boost/range/concepts.hpp>
Alexander Afanasyevb1db7c62014-04-03 14:57:25 -070028
Davide Pesavento47ce2ee2023-05-09 01:33:33 -040029namespace ndn::tests {
Alexander Afanasyev52eb20d2014-02-06 18:25:54 -080030
Davide Pesavento47ce2ee2023-05-09 01:33:33 -040031using ndn::name::Component;
Junxiao Shia36f15d2018-04-04 02:22:11 +000032
Davide Pesavento152ef442023-04-22 02:02:29 -040033BOOST_CONCEPT_ASSERT((boost::EqualityComparable<Name>));
Davide Pesaventofffdd622023-08-28 22:50:43 -040034BOOST_CONCEPT_ASSERT((boost::Comparable<Name>));
Davide Pesavento152ef442023-04-22 02:02:29 -040035BOOST_CONCEPT_ASSERT((WireEncodable<Name>));
36BOOST_CONCEPT_ASSERT((WireEncodableWithEncodingBuffer<Name>));
37BOOST_CONCEPT_ASSERT((WireDecodable<Name>));
38BOOST_CONCEPT_ASSERT((boost::RandomAccessIterator<Name::iterator>));
39BOOST_CONCEPT_ASSERT((boost::RandomAccessIterator<Name::const_iterator>));
40BOOST_CONCEPT_ASSERT((boost::RandomAccessIterator<Name::reverse_iterator>));
41BOOST_CONCEPT_ASSERT((boost::RandomAccessIterator<Name::const_reverse_iterator>));
42BOOST_CONCEPT_ASSERT((boost::RandomAccessRangeConcept<Name>));
43static_assert(std::is_convertible_v<Name::Error*, tlv::Error*>,
44 "Name::Error must inherit from tlv::Error");
45
Alexander Afanasyev52eb20d2014-02-06 18:25:54 -080046BOOST_AUTO_TEST_SUITE(TestName)
47
Junxiao Shia36f15d2018-04-04 02:22:11 +000048// ---- encoding, decoding, and URI ----
Alexander Afanasyev52eb20d2014-02-06 18:25:54 -080049
Junxiao Shia36f15d2018-04-04 02:22:11 +000050BOOST_AUTO_TEST_CASE(EncodeDecode)
Alexander Afanasyevc2344292014-03-02 00:08:00 +000051{
Davide Pesavento5d36a522024-02-09 01:36:52 -050052 constexpr auto uri = "/Emid/25042=P3/.../..../%1C%9F/"
53 "sha256digest=0415e3624a151850ac686c84f155f29808c0dd73819aa4a4c20be73a4d8a874c"sv;
54
55 // construct from std::string_view
Junxiao Shia36f15d2018-04-04 02:22:11 +000056 Name name(uri);
57 BOOST_CHECK_EQUAL(name.size(), 6);
58 BOOST_CHECK_EQUAL(name[0], Component("Emid"));
59 BOOST_CHECK_EQUAL(name[1], Component("FD61D2025033"_block));
60 BOOST_CHECK_EQUAL(name[2], Component(""));
61 BOOST_CHECK_EQUAL(name[3], Component("."));
62 BOOST_CHECK_EQUAL(name[4], Component("\x1C\x9F"));
63 BOOST_CHECK(name[5].isImplicitSha256Digest());
Alexander Afanasyevc2344292014-03-02 00:08:00 +000064
Davide Pesavento47ce2ee2023-05-09 01:33:33 -040065 BOOST_CHECK_EQUAL(name.toUri(name::UriFormat::CANONICAL),
Junxiao Shia39c0b52019-12-31 15:13:15 -070066 "/8=Emid/25042=P3/8=.../8=..../8=%1C%9F/"
67 "1=%04%15%E3bJ%15%18P%AChl%84%F1U%F2%98%08%C0%DDs%81%9A%A4%A4%C2%0B%E7%3AM%8A%87L");
68
Junxiao Shia36f15d2018-04-04 02:22:11 +000069 Block wire = name.wireEncode();
Junxiao Shi72c0c642018-04-20 15:41:09 +000070 BOOST_CHECK_EQUAL(wire,
Davide Pesavento5d36a522024-02-09 01:36:52 -050071 "0737 0804456D6964 FD61D2025033 0800 08012E 08021C9F "
72 "01200415E3624A151850AC686C84F155F29808C0DD73819AA4A4C20BE73A4D8A874C"_block);
Alexander Afanasyevc2344292014-03-02 00:08:00 +000073
Davide Pesavento5d36a522024-02-09 01:36:52 -050074 // construct from Block
Junxiao Shia36f15d2018-04-04 02:22:11 +000075 Name decoded(wire);
Davide Pesavento5d36a522024-02-09 01:36:52 -050076 BOOST_TEST(decoded == name);
77 BOOST_CHECK_EXCEPTION(Name("0802CAFE"_block), tlv::Error,
78 [] (const auto& e) { return e.what() == "Expecting Name element, but TLV has type 8"sv; });
79
80 // implicit conversion from char*
81 name = "/hello";
82 BOOST_TEST(name.toUri(name::UriFormat::CANONICAL) == "/8=hello");
83
84 // implicit conversion from std::string
85 name = "/world"s;
86 BOOST_TEST(name.toUri(name::UriFormat::CANONICAL) == "/8=world");
Alexander Afanasyev6486d522014-10-23 14:14:11 -070087}
88
Junxiao Shi9c9672e2018-04-18 12:55:08 +000089BOOST_AUTO_TEST_CASE(ParseUri)
Alexander Afanasyevd7eacc72015-04-03 13:06:26 -070090{
Junxiao Shia39c0b52019-12-31 15:13:15 -070091 // canonical URI
92 BOOST_CHECK_EQUAL(Name("/8=hello/8=world").toUri(), "/hello/world");
93
Junxiao Shi9c9672e2018-04-18 12:55:08 +000094 // URI with correct scheme
95 BOOST_CHECK_EQUAL(Name("ndn:/hello/world").toUri(), "/hello/world");
Davide Pesavento3fdb02f2023-04-12 02:32:38 -040096 BOOST_CHECK_EQUAL(Name("ndn:/").toUri(), "/");
97 BOOST_CHECK_EQUAL(Name("ndn:").toUri(), "/");
Alexander Afanasyevd7eacc72015-04-03 13:06:26 -070098
Junxiao Shi9c9672e2018-04-18 12:55:08 +000099 // URI with incorrect scheme: auto-corrected
100 BOOST_CHECK_EQUAL(Name("ncc:/hello/world").toUri(), "/hello/world");
Davide Pesavento3fdb02f2023-04-12 02:32:38 -0400101 BOOST_CHECK_EQUAL(Name(":/").toUri(), "/");
102 BOOST_CHECK_EQUAL(Name(":").toUri(), "/");
Junxiao Shi9c9672e2018-04-18 12:55:08 +0000103
104 // URI with authority: authority ignored
105 BOOST_CHECK_EQUAL(Name("//authority/hello/world").toUri(), "/hello/world");
106 BOOST_CHECK_EQUAL(Name("ndn://authority/hello/world").toUri(), "/hello/world");
Davide Pesavento3fdb02f2023-04-12 02:32:38 -0400107 BOOST_CHECK_EQUAL(Name("//authority").toUri(), "/");
108 BOOST_CHECK_EQUAL(Name("ndn://").toUri(), "/");
Junxiao Shi9c9672e2018-04-18 12:55:08 +0000109
110 // URI containing unescaped characters: auto-corrected
111 BOOST_CHECK_EQUAL(Name("/ hello\t/\tworld \r\n").toUri(), "/%20hello%09/%09world%20%0D%0A");
112 BOOST_CHECK_EQUAL(Name("/hello/world/ ").toUri(), "/hello/world/%20%20");
113 BOOST_CHECK_EQUAL(Name("/:?#[]@").toUri(), "/%3A%3F%23%5B%5D%40");
114
115 // URI not starting with '/': accepted as PartialName
116 BOOST_CHECK_EQUAL(Name("").toUri(), "/");
117 BOOST_CHECK_EQUAL(Name(" ").toUri(), "/%20");
Davide Pesavento3fdb02f2023-04-12 02:32:38 -0400118 BOOST_CHECK_EQUAL(Name("ndn: ").toUri(), "/%20");
119 BOOST_CHECK_EQUAL(Name("ndn: /").toUri(), "/%20");
Junxiao Shi9c9672e2018-04-18 12:55:08 +0000120 BOOST_CHECK_EQUAL(Name(" /hello/world").toUri(), "/%20%20/hello/world");
121 BOOST_CHECK_EQUAL(Name("hello/world").toUri(), "/hello/world");
Davide Pesavento3fdb02f2023-04-12 02:32:38 -0400122 BOOST_CHECK_EQUAL(Name("hello").toUri(), "/hello");
123 BOOST_CHECK_EQUAL(Name("ndn:hello").toUri(), "/hello");
Junxiao Shi9c9672e2018-04-18 12:55:08 +0000124
125 // URI ending with '/': auto-corrected
126 BOOST_CHECK_EQUAL(Name("/hello/world/").toUri(), "/hello/world");
127
128 // URI containing bad component: rejected
Alexander Afanasyevd7eacc72015-04-03 13:06:26 -0700129 BOOST_CHECK_THROW(Name("/hello//world"), name::Component::Error);
Junxiao Shi9c9672e2018-04-18 12:55:08 +0000130 BOOST_CHECK_THROW(Name("/hello/./world"), name::Component::Error);
131 BOOST_CHECK_THROW(Name("/hello/../world"), name::Component::Error);
Alexander Afanasyevd7eacc72015-04-03 13:06:26 -0700132}
133
Junxiao Shi71ff2312017-07-12 13:32:50 +0000134BOOST_AUTO_TEST_CASE(DeepCopy)
135{
136 Name n1("/hello/world");
137 Name n2 = n1.deepCopy();
138
139 BOOST_CHECK_EQUAL(n1, n2);
140 BOOST_CHECK_NE(&n1.wireEncode(), &n2.wireEncode());
141
142 EncodingBuffer buffer(1024, 0);
143 n1.wireEncode(buffer);
144 Name n3(buffer.block());
145
146 BOOST_CHECK_EQUAL(n1, n3);
147 BOOST_CHECK_EQUAL(n3.wireEncode().getBuffer()->size(), 1024);
148 n3 = n3.deepCopy();
149
150 BOOST_CHECK_LT(n3.wireEncode().size(), 1024);
151 BOOST_CHECK_EQUAL(n3.wireEncode().getBuffer()->size(), n3.wireEncode().size());
152}
153
Junxiao Shia36f15d2018-04-04 02:22:11 +0000154// ---- access ----
155
156BOOST_AUTO_TEST_CASE(At)
157{
158 Name name("/hello/5=NDN");
159
160 BOOST_CHECK_EQUAL(name.at(0), name::Component("080568656C6C6F"_block));
161 BOOST_CHECK_EQUAL(name.at(1), name::Component("05034E444E"_block));
162 BOOST_CHECK_EQUAL(name.at(-1), name::Component("05034E444E"_block));
163 BOOST_CHECK_EQUAL(name.at(-2), name::Component("080568656C6C6F"_block));
164
165 BOOST_CHECK_THROW(name.at(2), Name::Error);
166 BOOST_CHECK_THROW(name.at(-3), Name::Error);
167}
168
169BOOST_AUTO_TEST_CASE(SubName)
170{
171 Name name("/hello/world");
172
173 BOOST_CHECK_EQUAL("/hello/world", name.getSubName(0));
174 BOOST_CHECK_EQUAL("/world", name.getSubName(1));
Junxiao Shi9c9672e2018-04-18 12:55:08 +0000175 BOOST_CHECK_EQUAL("/hello", name.getSubName(0, 1));
Junxiao Shia36f15d2018-04-04 02:22:11 +0000176}
177
178BOOST_AUTO_TEST_CASE(SubNameNegativeIndex)
179{
180 Name name("/first/second/third/last");
181
182 BOOST_CHECK_EQUAL("/last", name.getSubName(-1));
183 BOOST_CHECK_EQUAL("/third/last", name.getSubName(-2));
184 BOOST_CHECK_EQUAL("/second", name.getSubName(-3, 1));
185}
186
187BOOST_AUTO_TEST_CASE(SubNameOutOfRangeIndexes)
188{
189 Name name("/first/second/last");
190 // No length
191 BOOST_CHECK_EQUAL("/first/second/last", name.getSubName(-10));
192 BOOST_CHECK_EQUAL("/", name.getSubName(10));
193
194 // Starting after the max position
195 BOOST_CHECK_EQUAL("/", name.getSubName(10, 1));
196 BOOST_CHECK_EQUAL("/", name.getSubName(10, 10));
197
198 // Not enough components
199 BOOST_CHECK_EQUAL("/second/last", name.getSubName(1, 10));
200 BOOST_CHECK_EQUAL("/last", name.getSubName(-1, 10));
201
202 // Start before first
203 BOOST_CHECK_EQUAL("/first/second", name.getSubName(-10, 2));
204 BOOST_CHECK_EQUAL("/first/second/last", name.getSubName(-10, 10));
205}
206
Junxiao Shi71ff2312017-07-12 13:32:50 +0000207// ---- iterators ----
208
209BOOST_AUTO_TEST_CASE(ForwardIterator)
210{
211 name::Component comps[] {
212 name::Component("A"),
213 name::Component("B"),
214 name::Component("C"),
215 name::Component("D")
216 };
217
218 Name n0;
219 BOOST_CHECK_EQUAL_COLLECTIONS(n0.begin(), n0.end(), comps, comps + 0);
220
221 Name n4("/A/B/C/D");
222 BOOST_CHECK_EQUAL_COLLECTIONS(n4.begin(), n4.end(), comps, comps + 4);
223}
224
225BOOST_AUTO_TEST_CASE(ReverseIterator)
226{
227 name::Component comps[] {
228 name::Component("D"),
229 name::Component("C"),
230 name::Component("B"),
231 name::Component("A")
232 };
233
234 Name n0;
235 BOOST_CHECK_EQUAL_COLLECTIONS(n0.rbegin(), n0.rend(), comps, comps + 0);
236
237 Name n4("/A/B/C/D");
238 BOOST_CHECK_EQUAL_COLLECTIONS(n4.rbegin(), n4.rend(), comps, comps + 4);
239}
240
241// ---- modifiers ----
242
Davide Pesaventoadc9aa22019-06-30 19:00:20 -0400243BOOST_AUTO_TEST_CASE(SetComponent)
244{
245 Name name("/A/B");
246 BOOST_CHECK_EQUAL(name.wireEncode(), "0706 080141 080142"_block);
247 BOOST_CHECK_EQUAL(name.hasWire(), true);
248
249 // pass by const lvalue ref
250 const Component c("C");
251 name.set(0, c);
252 BOOST_CHECK_EQUAL(name.hasWire(), false);
253 BOOST_CHECK_EQUAL(name.wireEncode(), "0706 080143 080142"_block);
254
255 // pass by rvalue ref
256 Component d("D");
257 name.set(1, std::move(d));
258 BOOST_CHECK_EQUAL(name.hasWire(), false);
259 BOOST_CHECK_EQUAL(name.wireEncode(), "0706 080143 080144"_block);
260
261 // negative index
262 name.set(-1, Component("E"));
263 BOOST_CHECK_EQUAL(name.wireEncode(), "0706 080143 080145"_block);
264}
265
Junxiao Shia36f15d2018-04-04 02:22:11 +0000266BOOST_AUTO_TEST_CASE(AppendComponent)
Joao Pereira6f7cfd02015-06-15 11:36:26 -0400267{
Junxiao Shia36f15d2018-04-04 02:22:11 +0000268 Name name;
Junxiao Shi72c0c642018-04-20 15:41:09 +0000269 BOOST_CHECK_EQUAL(name.wireEncode(), "0700"_block);
Ashlesh Gawande7dffab62017-12-21 16:40:53 -0600270
Junxiao Shia36f15d2018-04-04 02:22:11 +0000271 name.append(Component("Emid"));
Junxiao Shi72c0c642018-04-20 15:41:09 +0000272 BOOST_CHECK_EQUAL(name.wireEncode(), "0706 0804456D6964"_block);
Junxiao Shia36f15d2018-04-04 02:22:11 +0000273
Davide Pesaventodf8fd8a2022-02-21 20:04:21 -0500274 name.append(25042, {'P', '3'});
Junxiao Shi72c0c642018-04-20 15:41:09 +0000275 BOOST_CHECK_EQUAL(name.wireEncode(), "070C 0804456D6964 FD61D2025033"_block);
Junxiao Shia36f15d2018-04-04 02:22:11 +0000276
Davide Pesavento2f92b6e2022-04-10 16:42:01 -0400277 const uint8_t arr[] = {'.'};
278 name.append(arr);
Junxiao Shi72c0c642018-04-20 15:41:09 +0000279 BOOST_CHECK_EQUAL(name.wireEncode(), "070F 0804456D6964 FD61D2025033 08012E"_block);
Junxiao Shia36f15d2018-04-04 02:22:11 +0000280
Davide Pesavento2f92b6e2022-04-10 16:42:01 -0400281 const std::vector<uint8_t> vec{0x28, 0xF0, 0xA3, 0x6B};
282 name.append(16, vec.begin(), vec.end());
Junxiao Shi72c0c642018-04-20 15:41:09 +0000283 BOOST_CHECK_EQUAL(name.wireEncode(), "0715 0804456D6964 FD61D2025033 08012E 100428F0A36B"_block);
Junxiao Shia36f15d2018-04-04 02:22:11 +0000284
Junxiao Shia36f15d2018-04-04 02:22:11 +0000285 name.clear();
Junxiao Shi72c0c642018-04-20 15:41:09 +0000286 BOOST_CHECK_EQUAL(name.wireEncode(), "0700"_block);
Junxiao Shia36f15d2018-04-04 02:22:11 +0000287
Davide Pesavento2f92b6e2022-04-10 16:42:01 -0400288 name.append(vec.begin(), vec.end());
Junxiao Shi72c0c642018-04-20 15:41:09 +0000289 BOOST_CHECK_EQUAL(name.wireEncode(), "0706 080428F0A36B"_block);
Junxiao Shia36f15d2018-04-04 02:22:11 +0000290
291 name.append("xKh");
Junxiao Shi72c0c642018-04-20 15:41:09 +0000292 BOOST_CHECK_EQUAL(name.wireEncode(), "070B 080428F0A36B 0803784B68"_block);
Joao Pereira6f7cfd02015-06-15 11:36:26 -0400293}
294
Junxiao Shia36f15d2018-04-04 02:22:11 +0000295BOOST_AUTO_TEST_CASE(AppendPartialName)
Junxiao Shi71ff2312017-07-12 13:32:50 +0000296{
Junxiao Shia36f15d2018-04-04 02:22:11 +0000297 Name name("/A/B");
298 name.append(PartialName("/6=C/D"))
299 .append(PartialName("/E"));
Junxiao Shi72c0c642018-04-20 15:41:09 +0000300 BOOST_CHECK_EQUAL(name.wireEncode(), "070F 080141 080142 060143 080144 080145"_block);
Davide Pesaventoadc9aa22019-06-30 19:00:20 -0400301
302 name = "/A/B";
303 name.append(name);
304 BOOST_CHECK_EQUAL(name.wireEncode(), "070C 080141 080142 080141 080142"_block);
Junxiao Shi71ff2312017-07-12 13:32:50 +0000305}
306
307BOOST_AUTO_TEST_CASE(AppendNumber)
308{
309 Name name;
310 for (uint32_t i = 0; i < 10; i++) {
311 name.appendNumber(i);
312 }
Junxiao Shi71ff2312017-07-12 13:32:50 +0000313 BOOST_CHECK_EQUAL(name.size(), 10);
314
315 for (uint32_t i = 0; i < 10; i++) {
316 BOOST_CHECK_EQUAL(name[i].toNumber(), i);
317 }
318}
319
Davide Pesaventoadc9aa22019-06-30 19:00:20 -0400320BOOST_AUTO_TEST_CASE(AppendParametersSha256Digest)
321{
322 auto digest = make_shared<Buffer>(32);
323
324 Name name("/P");
Davide Pesavento765abc92021-12-27 00:44:04 -0500325 name.appendParametersSha256Digest(digest); // ConstBufferPtr overload
Davide Pesaventoadc9aa22019-06-30 19:00:20 -0400326 BOOST_CHECK_EQUAL(name.wireEncode(),
327 "0725 080150 02200000000000000000000000000000000000000000000000000000000000000000"_block);
328
329 name = "/P";
Davide Pesavento765abc92021-12-27 00:44:04 -0500330 name.appendParametersSha256Digest(*digest); // span overload
Davide Pesaventoadc9aa22019-06-30 19:00:20 -0400331 BOOST_CHECK_EQUAL(name.wireEncode(),
332 "0725 080150 02200000000000000000000000000000000000000000000000000000000000000000"_block);
333
334 name = "/P";
335 name.appendParametersSha256DigestPlaceholder();
336 BOOST_CHECK_EQUAL(name.wireEncode(),
337 "0725 080150 0220E3B0C44298FC1C149AFBF4C8996FB92427AE41E4649B934CA495991B7852B855"_block);
338}
339
Davide Pesavento21ee8992022-02-25 20:46:04 -0500340BOOST_AUTO_TEST_CASE(AppendTypedComponent)
Junxiao Shi71ff2312017-07-12 13:32:50 +0000341{
342 // TestNameComponent/NamingConvention provides additional coverage for these methods,
Davide Pesavento21ee8992022-02-25 20:46:04 -0500343 // including verification of the wire format.
Junxiao Shi71ff2312017-07-12 13:32:50 +0000344
345 Name name;
346 uint64_t number;
347
Davide Pesavento5d36a522024-02-09 01:36:52 -0500348 number = name.appendSegment(30923).at(-1).toSegment();
Davide Pesavento21ee8992022-02-25 20:46:04 -0500349 BOOST_TEST(number == 30923);
Junxiao Shi71ff2312017-07-12 13:32:50 +0000350
Davide Pesavento5d36a522024-02-09 01:36:52 -0500351 number = name.appendByteOffset(41880).at(-1).toByteOffset();
Davide Pesavento21ee8992022-02-25 20:46:04 -0500352 BOOST_TEST(number == 41880);
Junxiao Shi71ff2312017-07-12 13:32:50 +0000353
Davide Pesavento21ee8992022-02-25 20:46:04 -0500354 auto before = time::toUnixTimestamp(time::system_clock::now());
Davide Pesavento5d36a522024-02-09 01:36:52 -0500355 number = name.appendVersion().at(-1).toVersion();
Davide Pesavento21ee8992022-02-25 20:46:04 -0500356 auto after = time::toUnixTimestamp(time::system_clock::now());
357 BOOST_TEST(number >= before.count());
358 BOOST_TEST(number <= after.count());
359
Davide Pesavento5d36a522024-02-09 01:36:52 -0500360 number = name.appendVersion(25912).at(-1).toVersion();
Davide Pesavento21ee8992022-02-25 20:46:04 -0500361 BOOST_TEST(number == 25912);
Junxiao Shi71ff2312017-07-12 13:32:50 +0000362
Davide Pesavento46cdf902020-06-08 16:38:23 -0400363 const auto tp = time::system_clock::now();
Davide Pesavento47ce2ee2023-05-09 01:33:33 -0400364 time::system_clock::time_point tp2;
Davide Pesavento5d36a522024-02-09 01:36:52 -0500365 tp2 = name.appendTimestamp(tp).at(-1).toTimestamp();
Davide Pesavento21ee8992022-02-25 20:46:04 -0500366 BOOST_TEST(time::abs(tp2 - tp) <= 1_us);
Junxiao Shi71ff2312017-07-12 13:32:50 +0000367
Davide Pesavento5d36a522024-02-09 01:36:52 -0500368 number = name.appendSequenceNumber(11676).at(-1).toSequenceNumber();
Davide Pesavento21ee8992022-02-25 20:46:04 -0500369 BOOST_TEST(number == 11676);
370
371 name.appendKeyword({0xab, 0xcd, 0xef});
Davide Pesavento8e047e12024-02-12 16:50:23 -0500372 BOOST_TEST(name.at(-1) == Component::fromUri("32=%AB%CD%EF"sv));
Davide Pesavento21ee8992022-02-25 20:46:04 -0500373
374 name.appendKeyword("test-keyword");
Davide Pesavento8e047e12024-02-12 16:50:23 -0500375 BOOST_TEST(name.at(-1) == Component::fromUri("32=test-keyword"sv));
Junxiao Shi71ff2312017-07-12 13:32:50 +0000376}
377
Davide Pesaventoadc9aa22019-06-30 19:00:20 -0400378BOOST_AUTO_TEST_CASE(EraseComponent)
379{
380 Name name("/A/B/C");
381 BOOST_CHECK_EQUAL(name.wireEncode(), "0709 080141 080142 080143"_block);
382 BOOST_CHECK_EQUAL(name.hasWire(), true);
383
Davide Pesavento21ee8992022-02-25 20:46:04 -0500384 name.erase(-2);
Davide Pesaventoadc9aa22019-06-30 19:00:20 -0400385 BOOST_CHECK_EQUAL(name.size(), 2);
386 BOOST_CHECK_EQUAL(name.hasWire(), false);
387 BOOST_CHECK_EQUAL(name.wireEncode(), "0706 080141 080143"_block);
388
Davide Pesavento21ee8992022-02-25 20:46:04 -0500389 name.erase(1);
Davide Pesaventoadc9aa22019-06-30 19:00:20 -0400390 BOOST_CHECK_EQUAL(name.size(), 1);
391 BOOST_CHECK_EQUAL(name.hasWire(), false);
392 BOOST_CHECK_EQUAL(name.wireEncode(), "0703 080141"_block);
Davide Pesavento21ee8992022-02-25 20:46:04 -0500393
394 name.erase(0);
395 BOOST_CHECK_EQUAL(name.size(), 0);
396 BOOST_CHECK_EQUAL(name.hasWire(), false);
397 BOOST_CHECK_EQUAL(name.wireEncode(), "0700"_block);
Davide Pesaventoadc9aa22019-06-30 19:00:20 -0400398}
399
400BOOST_AUTO_TEST_CASE(Clear)
401{
402 Name name("/A/B/C");
403 BOOST_CHECK_EQUAL(name.empty(), false);
404 name.clear();
405 BOOST_CHECK_EQUAL(name.empty(), true);
406 BOOST_CHECK(name.begin() == name.end());
407}
408
Junxiao Shi71ff2312017-07-12 13:32:50 +0000409// ---- algorithms ----
410
411BOOST_AUTO_TEST_CASE(GetSuccessor)
412{
Junxiao Shicf0aff82018-07-23 06:42:13 -0600413 BOOST_CHECK_EQUAL(Name().getSuccessor(), "/sha256digest=0000000000000000000000000000000000000000000000000000000000000000");
414 BOOST_CHECK_EQUAL(Name("/sha256digest=0000000000000000000000000000000000000000000000000000000000000000").getSuccessor(),
415 "/sha256digest=0000000000000000000000000000000000000000000000000000000000000001");
416 BOOST_CHECK_EQUAL(Name("/sha256digest=ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff").getSuccessor(),
Junxiao Shi4053bd52018-08-16 13:39:25 -0600417 "/params-sha256=0000000000000000000000000000000000000000000000000000000000000000");
418 BOOST_CHECK_EQUAL(Name("/params-sha256=0000000000000000000000000000000000000000000000000000000000000000").getSuccessor(),
419 "/params-sha256=0000000000000000000000000000000000000000000000000000000000000001");
420 BOOST_CHECK_EQUAL(Name("/params-sha256=ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff").getSuccessor(),
421 "/3=...");
Junxiao Shicf0aff82018-07-23 06:42:13 -0600422 BOOST_CHECK_EQUAL(Name("/P/A").getSuccessor(), "/P/B");
423 BOOST_CHECK_EQUAL(Name("/P/AAA").getSuccessor(), "/P/AAB");
424 BOOST_CHECK_EQUAL(Name("/Q/...").getSuccessor(), "/Q/%00");
425 BOOST_CHECK_EQUAL(Name("/Q/%FF").getSuccessor(), "/Q/%00%00");
426 BOOST_CHECK_EQUAL(Name("/Q/%FE%FF").getSuccessor(), "/Q/%FF%00");
427 BOOST_CHECK_EQUAL(Name("/Q/%FF%FF").getSuccessor(), "/Q/%00%00%00");
428 BOOST_CHECK_EQUAL(Name("/P/3=A").getSuccessor(), "/P/3=B");
429 BOOST_CHECK_EQUAL(Name("/P/3=AAA").getSuccessor(), "/P/3=AAB");
430 BOOST_CHECK_EQUAL(Name("/Q/3=...").getSuccessor(), "/Q/3=%00");
431 BOOST_CHECK_EQUAL(Name("/Q/3=%FF").getSuccessor(), "/Q/3=%00%00");
432 BOOST_CHECK_EQUAL(Name("/Q/3=%FE%FF").getSuccessor(), "/Q/3=%FF%00");
433 BOOST_CHECK_EQUAL(Name("/Q/3=%FF%FF").getSuccessor(), "/Q/3=%00%00%00");
Junxiao Shi71ff2312017-07-12 13:32:50 +0000434}
435
Junxiao Shia36f15d2018-04-04 02:22:11 +0000436BOOST_AUTO_TEST_CASE(IsPrefixOf)
437{
438 BOOST_CHECK(Name("/").isPrefixOf("/"));
439 BOOST_CHECK(Name("/").isPrefixOf("/sha256digest=0000000000000000000000000000000000000000000000000000000000000000"));
Junxiao Shi4053bd52018-08-16 13:39:25 -0600440 BOOST_CHECK(Name("/").isPrefixOf("/params-sha256=ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"));
441 BOOST_CHECK(Name("/").isPrefixOf("/3=D"));
Junxiao Shia36f15d2018-04-04 02:22:11 +0000442 BOOST_CHECK(Name("/").isPrefixOf("/F"));
443 BOOST_CHECK(Name("/").isPrefixOf("/21426=AA"));
444
445 BOOST_CHECK(Name("/B").isPrefixOf("/B"));
446 BOOST_CHECK(Name("/B").isPrefixOf("/B/sha256digest=0000000000000000000000000000000000000000000000000000000000000000"));
Junxiao Shi4053bd52018-08-16 13:39:25 -0600447 BOOST_CHECK(Name("/").isPrefixOf("/B/params-sha256=ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"));
448 BOOST_CHECK(Name("/B").isPrefixOf("/B/3=D"));
Junxiao Shia36f15d2018-04-04 02:22:11 +0000449 BOOST_CHECK(Name("/B").isPrefixOf("/B/F"));
450 BOOST_CHECK(Name("/B").isPrefixOf("/B/21426=AA"));
451
452 BOOST_CHECK(!Name("/C").isPrefixOf("/"));
453 BOOST_CHECK(!Name("/C").isPrefixOf("/sha256digest=0000000000000000000000000000000000000000000000000000000000000000"));
Junxiao Shi4053bd52018-08-16 13:39:25 -0600454 BOOST_CHECK(Name("/").isPrefixOf("/params-sha256=ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"));
455 BOOST_CHECK(!Name("/C").isPrefixOf("/3=D"));
Junxiao Shia36f15d2018-04-04 02:22:11 +0000456 BOOST_CHECK(!Name("/C").isPrefixOf("/F"));
457 BOOST_CHECK(!Name("/C").isPrefixOf("/21426=AA"));
458}
459
460BOOST_AUTO_TEST_CASE(CompareOp)
461{
Davide Pesavento334516a2024-02-09 18:02:36 -0500462 const std::vector<Name> names = {
Junxiao Shia36f15d2018-04-04 02:22:11 +0000463 Name("/"),
464 Name("/sha256digest=0000000000000000000000000000000000000000000000000000000000000000"),
465 Name("/sha256digest=0000000000000000000000000000000000000000000000000000000000000001"),
466 Name("/sha256digest=FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF"),
Junxiao Shi4053bd52018-08-16 13:39:25 -0600467 Name("/params-sha256=0000000000000000000000000000000000000000000000000000000000000000"),
468 Name("/params-sha256=0000000000000000000000000000000000000000000000000000000000000001"),
469 Name("/params-sha256=FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF"),
470 Name("/3=..."),
471 Name("/3=D"),
472 Name("/3=F"),
473 Name("/3=AA"),
Junxiao Shia36f15d2018-04-04 02:22:11 +0000474 Name("/..."),
475 Name("/D"),
476 Name("/D/sha256digest=0000000000000000000000000000000000000000000000000000000000000000"),
477 Name("/D/sha256digest=0000000000000000000000000000000000000000000000000000000000000001"),
478 Name("/D/sha256digest=FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF"),
Junxiao Shi4053bd52018-08-16 13:39:25 -0600479 Name("/D/params-sha256=0000000000000000000000000000000000000000000000000000000000000000"),
480 Name("/D/params-sha256=0000000000000000000000000000000000000000000000000000000000000001"),
481 Name("/D/params-sha256=FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF"),
482 Name("/D/3=..."),
483 Name("/D/3=D"),
484 Name("/D/3=F"),
485 Name("/D/3=AA"),
Junxiao Shia36f15d2018-04-04 02:22:11 +0000486 Name("/D/..."),
487 Name("/D/D"),
488 Name("/D/F"),
489 Name("/D/AA"),
490 Name("/D/21426=..."),
491 Name("/D/21426=D"),
492 Name("/D/21426=F"),
493 Name("/D/21426=AA"),
494 Name("/F"),
495 Name("/AA"),
496 Name("/21426=..."),
497 Name("/21426=D"),
498 Name("/21426=F"),
499 Name("/21426=AA"),
500 };
501
502 for (size_t i = 0; i < names.size(); ++i) {
503 for (size_t j = 0; j < names.size(); ++j) {
Davide Pesavento334516a2024-02-09 18:02:36 -0500504 const auto& lhs = names[i];
505 const auto& rhs = names[j];
506 BOOST_TEST_INFO_SCOPE("lhs = " << lhs);
507 BOOST_TEST_INFO_SCOPE("rhs = " << rhs);
Junxiao Shia36f15d2018-04-04 02:22:11 +0000508 BOOST_CHECK_EQUAL(lhs == rhs, i == j);
509 BOOST_CHECK_EQUAL(lhs != rhs, i != j);
510 BOOST_CHECK_EQUAL(lhs < rhs, i < j);
511 BOOST_CHECK_EQUAL(lhs <= rhs, i <= j);
512 BOOST_CHECK_EQUAL(lhs > rhs, i > j);
513 BOOST_CHECK_EQUAL(lhs >= rhs, i >= j);
514 }
515 }
516}
517
518BOOST_AUTO_TEST_CASE(CompareFunc)
Junxiao Shi71ff2312017-07-12 13:32:50 +0000519{
520 BOOST_CHECK_EQUAL(Name("/A") .compare(Name("/A")), 0);
521 BOOST_CHECK_LT (Name("/A") .compare(Name("/B")), 0);
522 BOOST_CHECK_GT (Name("/B") .compare(Name("/A")), 0);
523 BOOST_CHECK_LT (Name("/A") .compare(Name("/AA")), 0);
524 BOOST_CHECK_GT (Name("/AA") .compare(Name("/A")), 0);
525 BOOST_CHECK_LT (Name("/A") .compare(Name("/A/C")), 0);
526 BOOST_CHECK_GT (Name("/A/C").compare(Name("/A")), 0);
527
528 BOOST_CHECK_EQUAL(Name("/Z/A/Y") .compare(1, 1, Name("/A")), 0);
529 BOOST_CHECK_LT (Name("/Z/A/Y") .compare(1, 1, Name("/B")), 0);
530 BOOST_CHECK_GT (Name("/Z/B/Y") .compare(1, 1, Name("/A")), 0);
531 BOOST_CHECK_LT (Name("/Z/A/Y") .compare(1, 1, Name("/AA")), 0);
532 BOOST_CHECK_GT (Name("/Z/AA/Y") .compare(1, 1, Name("/A")), 0);
533 BOOST_CHECK_LT (Name("/Z/A/Y") .compare(1, 1, Name("/A/C")), 0);
534 BOOST_CHECK_GT (Name("/Z/A/C/Y").compare(1, 2, Name("/A")), 0);
535
536 BOOST_CHECK_EQUAL(Name("/Z/A") .compare(1, Name::npos, Name("/A")), 0);
537 BOOST_CHECK_LT (Name("/Z/A") .compare(1, Name::npos, Name("/B")), 0);
538 BOOST_CHECK_GT (Name("/Z/B") .compare(1, Name::npos, Name("/A")), 0);
539 BOOST_CHECK_LT (Name("/Z/A") .compare(1, Name::npos, Name("/AA")), 0);
540 BOOST_CHECK_GT (Name("/Z/AA") .compare(1, Name::npos, Name("/A")), 0);
541 BOOST_CHECK_LT (Name("/Z/A") .compare(1, Name::npos, Name("/A/C")), 0);
542 BOOST_CHECK_GT (Name("/Z/A/C").compare(1, Name::npos, Name("/A")), 0);
543
544 BOOST_CHECK_EQUAL(Name("/Z/A/Y") .compare(1, 1, Name("/X/A/W"), 1, 1), 0);
545 BOOST_CHECK_LT (Name("/Z/A/Y") .compare(1, 1, Name("/X/B/W"), 1, 1), 0);
546 BOOST_CHECK_GT (Name("/Z/B/Y") .compare(1, 1, Name("/X/A/W"), 1, 1), 0);
547 BOOST_CHECK_LT (Name("/Z/A/Y") .compare(1, 1, Name("/X/AA/W"), 1, 1), 0);
548 BOOST_CHECK_GT (Name("/Z/AA/Y") .compare(1, 1, Name("/X/A/W"), 1, 1), 0);
549 BOOST_CHECK_LT (Name("/Z/A/Y") .compare(1, 1, Name("/X/A/C/W"), 1, 2), 0);
550 BOOST_CHECK_GT (Name("/Z/A/C/Y").compare(1, 2, Name("/X/A/W"), 1, 1), 0);
551
552 BOOST_CHECK_EQUAL(Name("/Z/A/Y") .compare(1, 1, Name("/X/A"), 1), 0);
553 BOOST_CHECK_LT (Name("/Z/A/Y") .compare(1, 1, Name("/X/B"), 1), 0);
554 BOOST_CHECK_GT (Name("/Z/B/Y") .compare(1, 1, Name("/X/A"), 1), 0);
555 BOOST_CHECK_LT (Name("/Z/A/Y") .compare(1, 1, Name("/X/AA"), 1), 0);
556 BOOST_CHECK_GT (Name("/Z/AA/Y") .compare(1, 1, Name("/X/A"), 1), 0);
557 BOOST_CHECK_LT (Name("/Z/A/Y") .compare(1, 1, Name("/X/A/C"), 1), 0);
558 BOOST_CHECK_GT (Name("/Z/A/C/Y").compare(1, 2, Name("/X/A"), 1), 0);
559}
560
Davide Pesavento5d36a522024-02-09 01:36:52 -0500561BOOST_AUTO_TEST_CASE(UnorderedMapKey)
Alexander Afanasyev4f512fb2016-05-18 10:47:53 -0700562{
Junxiao Shi71ff2312017-07-12 13:32:50 +0000563 std::unordered_map<Name, int> map;
564 Name name1("/1");
565 Name name2("/2");
566 Name name3("/3");
567 map[name1] = 1;
568 map[name2] = 2;
569 map[name3] = 3;
Alexander Afanasyev4f512fb2016-05-18 10:47:53 -0700570
Junxiao Shi71ff2312017-07-12 13:32:50 +0000571 BOOST_CHECK_EQUAL(map[name1], 1);
572 BOOST_CHECK_EQUAL(map[name2], 2);
573 BOOST_CHECK_EQUAL(map[name3], 3);
Alexander Afanasyev4f512fb2016-05-18 10:47:53 -0700574}
575
Davide Pesaventoeee3e822016-11-26 19:19:34 +0100576BOOST_AUTO_TEST_SUITE_END() // TestName
Alexander Afanasyev52eb20d2014-02-06 18:25:54 -0800577
Davide Pesavento47ce2ee2023-05-09 01:33:33 -0400578} // namespace ndn::tests