blob: 387206a6608c3fbcda3312f6c32ec3d67fd614c7 [file] [log] [blame]
Junxiao Shicbba04c2014-01-26 14:21:22 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Davide Pesavento16916ae2019-03-29 23:53:26 -04002/*
3 * Copyright (c) 2014-2019, Regents of the University of California,
Alexander Afanasyev319f2c82015-01-07 14:56:53 -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/>.
Junxiao Shi08d07a72014-06-09 23:17:57 -070024 */
Junxiao Shicbba04c2014-01-26 14:21:22 -070025
Junxiao Shi08d07a72014-06-09 23:17:57 -070026#ifndef NFD_TESTS_DAEMON_FACE_DUMMY_FACE_HPP
27#define NFD_TESTS_DAEMON_FACE_DUMMY_FACE_HPP
Junxiao Shicbba04c2014-01-26 14:21:22 -070028
29#include "face/face.hpp"
30
Alexander Afanasyev18bbf812014-01-29 01:40:23 -080031namespace nfd {
Junxiao Shicde37ad2015-12-24 01:02:05 -070032namespace face {
Junxiao Shid9ee45c2014-02-27 15:38:11 -070033namespace tests {
Junxiao Shicbba04c2014-01-26 14:21:22 -070034
Davide Pesaventoa8098582019-03-31 15:48:02 -040035class DummyLinkService;
36
37/** \brief A Face for unit testing.
Junxiao Shicde37ad2015-12-24 01:02:05 -070038 *
39 * The DummyFace has no underlying transport, but allows observing outgoing packets
40 * and injecting incoming packets at network layer.
41 * It's primarily used for forwarding test suites, but can be used in other tests as well.
42 *
43 * Outgoing network-layer packets sent through the DummyFace are recorded in sent* vectors,
44 * which can be observed in test cases.
45 * Incoming network-layer packets can be injected from test cases through receive* method.
Junxiao Shicbba04c2014-01-26 14:21:22 -070046 */
Junxiao Shi0de23a22015-12-03 20:07:02 +000047class DummyFace : public Face
Junxiao Shicbba04c2014-01-26 14:21:22 -070048{
49public:
Davide Pesaventoa8098582019-03-31 15:48:02 -040050 explicit
Junxiao Shicde37ad2015-12-24 01:02:05 -070051 DummyFace(const std::string& localUri = "dummy://", const std::string& remoteUri = "dummy://",
52 ndn::nfd::FaceScope scope = ndn::nfd::FACE_SCOPE_NON_LOCAL,
53 ndn::nfd::FacePersistency persistency = ndn::nfd::FACE_PERSISTENCY_PERSISTENT,
54 ndn::nfd::LinkType linkType = ndn::nfd::LINK_TYPE_POINT_TO_POINT);
55
56 /** \brief changes face state
Junxiao Shi02b73f52016-07-28 01:48:27 +000057 * \throw std::runtime_error state transition is invalid
Junxiao Shicde37ad2015-12-24 01:02:05 -070058 */
Davide Pesavento66ff0982015-01-29 22:39:00 +010059 void
Junxiao Shicde37ad2015-12-24 01:02:05 -070060 setState(FaceState state);
Junxiao Shi9b27bd22014-02-26 20:29:58 -070061
Junxiao Shicde37ad2015-12-24 01:02:05 -070062 /** \brief causes the face to receive an Interest
63 */
Davide Pesavento66ff0982015-01-29 22:39:00 +010064 void
Junxiao Shicde37ad2015-12-24 01:02:05 -070065 receiveInterest(const Interest& interest);
Alexander Afanasyeva0a10fb2014-02-13 19:56:15 -080066
Junxiao Shicde37ad2015-12-24 01:02:05 -070067 /** \brief causes the face to receive a Data
68 */
Davide Pesavento66ff0982015-01-29 22:39:00 +010069 void
Junxiao Shicde37ad2015-12-24 01:02:05 -070070 receiveData(const Data& data);
Alexander Afanasyev93ce75e2014-02-18 19:45:34 -080071
Junxiao Shicde37ad2015-12-24 01:02:05 -070072 /** \brief causes the face to receive a Nack
73 */
Junxiao Shi9b27bd22014-02-26 20:29:58 -070074 void
Junxiao Shicde37ad2015-12-24 01:02:05 -070075 receiveNack(const lp::Nack& nack);
Junxiao Shi9b27bd22014-02-26 20:29:58 -070076
Davide Pesaventoa8098582019-03-31 15:48:02 -040077 /** \brief Emitted after a network-layer packet is sent.
Junxiao Shicde37ad2015-12-24 01:02:05 -070078 *
Davide Pesaventoa8098582019-03-31 15:48:02 -040079 * The packet type is reported via the argument, whose value will be one of
80 * tlv::Interest, tlv::Data, or lp::tlv::Nack. Signal handlers may retrieve
81 * the packet via `sentInterests.back()`, `sentData.back()`, or `sentNacks.back()`.
Junxiao Shicde37ad2015-12-24 01:02:05 -070082 */
Davide Pesaventoa8098582019-03-31 15:48:02 -040083 signal::Signal<DummyLinkService, uint32_t>& afterSend;
Junxiao Shi9b27bd22014-02-26 20:29:58 -070084
Junxiao Shicde37ad2015-12-24 01:02:05 -070085private:
Davide Pesaventoa8098582019-03-31 15:48:02 -040086 DummyLinkService*
87 getDummyLinkService() const;
Junxiao Shicde37ad2015-12-24 01:02:05 -070088
Junxiao Shi9b27bd22014-02-26 20:29:58 -070089public:
Junxiao Shicde37ad2015-12-24 01:02:05 -070090 std::vector<Interest>& sentInterests;
91 std::vector<Data>& sentData;
92 std::vector<lp::Nack>& sentNacks;
Junxiao Shicbba04c2014-01-26 14:21:22 -070093};
94
Junxiao Shicde37ad2015-12-24 01:02:05 -070095} // namespace tests
96} // namespace face
Alexander Afanasyevbd220a02014-02-20 00:29:56 -080097
Junxiao Shicde37ad2015-12-24 01:02:05 -070098namespace tests {
99using nfd::face::tests::DummyFace;
Junxiao Shid9ee45c2014-02-27 15:38:11 -0700100} // namespace tests
Davide Pesavento16916ae2019-03-29 23:53:26 -0400101
Alexander Afanasyev18bbf812014-01-29 01:40:23 -0800102} // namespace nfd
Junxiao Shicbba04c2014-01-26 14:21:22 -0700103
Junxiao Shi08d07a72014-06-09 23:17:57 -0700104#endif // NFD_TESTS_DAEMON_FACE_DUMMY_FACE_HPP