blob: b365f9b3ff3d22cb947f2c53ec1632c32fc835ef [file] [log] [blame]
Junxiao Shid9ee45c2014-02-27 15:38:11 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Junxiao Shifc2e13d2017-07-25 02:08:48 +00002/*
Junxiao Shi99540072017-01-27 19:57:33 +00003 * Copyright (c) 2014-2017, Regents of the University of California,
Yukai Tu0a49d342015-09-13 12:54:22 +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.
Alexander Afanasyev9bcbc7c2014-04-06 19:37:37 -070010 *
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/>.
Alexander Afanasyevc026d252014-06-16 11:14:15 -070024 */
Junxiao Shid9ee45c2014-02-27 15:38:11 -070025
Alexander Afanasyev613e2a92014-04-15 13:36:58 -070026#ifndef NFD_TESTS_TEST_COMMON_HPP
27#define NFD_TESTS_TEST_COMMON_HPP
Junxiao Shid9ee45c2014-02-27 15:38:11 -070028
Alexander Afanasyev8552a382014-05-15 20:13:42 -070029#include "boost-test.hpp"
30
Junxiao Shid9ee45c2014-02-27 15:38:11 -070031#include "core/global-io.hpp"
Steve DiBenedettobf6a93d2014-03-21 14:03:02 -060032#include "core/logger.hpp"
Alexander Afanasyev8552a382014-05-15 20:13:42 -070033
Junxiao Shi455581d2014-11-17 18:38:40 -070034#include <ndn-cxx/util/time-unit-test-clock.hpp>
Junxiao Shid9ee45c2014-02-27 15:38:11 -070035
Weiwei Liuf5aee942016-03-19 07:00:42 +000036#ifdef HAVE_PRIVILEGE_DROP_AND_ELEVATE
37#include <unistd.h>
38#define SKIP_IF_NOT_SUPERUSER() \
39 do { \
40 if (::geteuid() != 0) { \
Davide Pesavento231ddd72016-09-02 22:20:00 +000041 BOOST_WARN_MESSAGE(false, "skipping assertions that require superuser privileges"); \
Weiwei Liuf5aee942016-03-19 07:00:42 +000042 return; \
43 } \
44 } while (false)
45#else
46#define SKIP_IF_NOT_SUPERUSER()
47#endif // HAVE_PRIVILEGE_DROP_AND_ELEVATE
48
Junxiao Shid9ee45c2014-02-27 15:38:11 -070049namespace nfd {
50namespace tests {
51
52/** \brief base test fixture
53 *
54 * Every test case should be based on this fixture,
55 * to have per test case io_service initialization.
56 */
57class BaseFixture
58{
59protected:
Junxiao Shid23de8b2016-07-23 20:05:42 +000060 BaseFixture();
Junxiao Shif3c07812014-03-11 21:48:49 -070061
Junxiao Shid23de8b2016-07-23 20:05:42 +000062 ~BaseFixture();
Junxiao Shid9ee45c2014-02-27 15:38:11 -070063
64protected:
Junxiao Shid23de8b2016-07-23 20:05:42 +000065 /** \brief reference to global io_service
66 */
Junxiao Shid9ee45c2014-02-27 15:38:11 -070067 boost::asio::io_service& g_io;
68};
69
Junxiao Shi455581d2014-11-17 18:38:40 -070070/** \brief a base test fixture that overrides steady clock and system clock
71 */
Yukai Tu0a49d342015-09-13 12:54:22 +080072class UnitTestTimeFixture : public virtual BaseFixture
Junxiao Shi455581d2014-11-17 18:38:40 -070073{
Junxiao Shie368d992014-12-02 23:44:31 -070074protected:
Junxiao Shid23de8b2016-07-23 20:05:42 +000075 UnitTestTimeFixture();
Junxiao Shi455581d2014-11-17 18:38:40 -070076
Junxiao Shid23de8b2016-07-23 20:05:42 +000077 ~UnitTestTimeFixture();
Junxiao Shi455581d2014-11-17 18:38:40 -070078
79 /** \brief advance steady and system clocks
80 *
81 * Clocks are advanced in increments of \p tick for \p nTicks ticks.
82 * After each tick, global io_service is polled to process pending I/O events.
83 *
84 * Exceptions thrown during I/O events are propagated to the caller.
85 * Clock advancing would stop in case of an exception.
86 */
87 void
Junxiao Shid23de8b2016-07-23 20:05:42 +000088 advanceClocks(const time::nanoseconds& tick, size_t nTicks = 1);
Junxiao Shie368d992014-12-02 23:44:31 -070089
90 /** \brief advance steady and system clocks
91 *
92 * Clocks are advanced in increments of \p tick for \p total time.
93 * The last increment might be shorter than \p tick.
94 * After each tick, global io_service is polled to process pending I/O events.
95 *
96 * Exceptions thrown during I/O events are propagated to the caller.
97 * Clock advancing would stop in case of an exception.
98 */
99 void
Junxiao Shid23de8b2016-07-23 20:05:42 +0000100 advanceClocks(const time::nanoseconds& tick, const time::nanoseconds& total);
Junxiao Shi3cb4fc62014-12-25 22:17:39 -0700101
Junxiao Shi455581d2014-11-17 18:38:40 -0700102protected:
103 shared_ptr<time::UnitTestSteadyClock> steadyClock;
104 shared_ptr<time::UnitTestSystemClock> systemClock;
Junxiao Shid23de8b2016-07-23 20:05:42 +0000105
106 friend class LimitedIo;
Junxiao Shi455581d2014-11-17 18:38:40 -0700107};
Junxiao Shif3c07812014-03-11 21:48:49 -0700108
Junxiao Shid23de8b2016-07-23 20:05:42 +0000109/** \brief create an Interest
110 * \param name Interest name
111 * \param nonce if non-zero, set Nonce to this value
112 * (useful for creating Nack with same Nonce)
113 */
114shared_ptr<Interest>
115makeInterest(const Name& name, uint32_t nonce = 0);
Junxiao Shif3c07812014-03-11 21:48:49 -0700116
Junxiao Shid23de8b2016-07-23 20:05:42 +0000117/** \brief create a Data with fake signature
118 * \note Data may be modified afterwards without losing the fake signature.
119 * If a real signature is desired, sign again with KeyChain.
120 */
121shared_ptr<Data>
122makeData(const Name& name);
123
124/** \brief add a fake signature to Data
125 */
126Data&
127signData(Data& data);
128
129/** \brief add a fake signature to Data
130 */
Junxiao Shif3c07812014-03-11 21:48:49 -0700131inline shared_ptr<Data>
Junxiao Shi0355e9f2015-09-02 07:24:53 -0700132signData(shared_ptr<Data> data)
Junxiao Shif3c07812014-03-11 21:48:49 -0700133{
Junxiao Shid23de8b2016-07-23 20:05:42 +0000134 signData(*data);
Junxiao Shif3c07812014-03-11 21:48:49 -0700135 return data;
136}
137
Junxiao Shid23de8b2016-07-23 20:05:42 +0000138/** \brief create a Nack
Junxiao Shi99540072017-01-27 19:57:33 +0000139 * \param interest Interest
140 * \param reason Nack reason
141 */
142lp::Nack
143makeNack(Interest interest, lp::NackReason reason);
144
145/** \brief create a Nack
Junxiao Shid23de8b2016-07-23 20:05:42 +0000146 * \param name Interest name
147 * \param nonce Interest nonce
148 * \param reason Nack reason
149 */
150lp::Nack
151makeNack(const Name& name, uint32_t nonce, lp::NackReason reason);
Eric Newberrya98bf932015-09-21 00:58:47 -0700152
Junxiao Shid7631272016-08-17 04:16:31 +0000153/** \brief replace a name component
154 * \param[inout] name name
155 * \param index name component index
156 * \param a arguments to name::Component constructor
157 */
158template<typename...A>
159void
160setNameComponent(Name& name, ssize_t index, const A& ...a)
161{
162 Name name2 = name.getPrefix(index);
163 name2.append(name::Component(a...));
164 name2.append(name.getSubName(name2.size()));
165 name = name2;
166}
167
168template<typename Packet, typename...A>
169void
170setNameComponent(Packet& packet, ssize_t index, const A& ...a)
171{
172 Name name = packet.getName();
173 setNameComponent(name, index, a...);
174 packet.setName(name);
175}
176
Junxiao Shid9ee45c2014-02-27 15:38:11 -0700177} // namespace tests
178} // namespace nfd
179
Alexander Afanasyev613e2a92014-04-15 13:36:58 -0700180#endif // NFD_TESTS_TEST_COMMON_HPP