blob: 93bcd48c36904ff24b627997710a8f00d9987db5 [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
Junxiao Shi0de23a22015-12-03 20:07:02 +000035/** \brief a Face for unit testing
Junxiao Shicde37ad2015-12-24 01:02:05 -070036 *
37 * The DummyFace has no underlying transport, but allows observing outgoing packets
38 * and injecting incoming packets at network layer.
39 * It's primarily used for forwarding test suites, but can be used in other tests as well.
40 *
41 * Outgoing network-layer packets sent through the DummyFace are recorded in sent* vectors,
42 * which can be observed in test cases.
43 * Incoming network-layer packets can be injected from test cases through receive* method.
Junxiao Shicbba04c2014-01-26 14:21:22 -070044 */
Junxiao Shi0de23a22015-12-03 20:07:02 +000045class DummyFace : public Face
Junxiao Shicbba04c2014-01-26 14:21:22 -070046{
47public:
Junxiao Shicde37ad2015-12-24 01:02:05 -070048 class LinkService;
Chengyu Fan320d2332014-10-29 16:40:33 -060049
Junxiao Shicde37ad2015-12-24 01:02:05 -070050 DummyFace(const std::string& localUri = "dummy://", const std::string& remoteUri = "dummy://",
51 ndn::nfd::FaceScope scope = ndn::nfd::FACE_SCOPE_NON_LOCAL,
52 ndn::nfd::FacePersistency persistency = ndn::nfd::FACE_PERSISTENCY_PERSISTENT,
53 ndn::nfd::LinkType linkType = ndn::nfd::LINK_TYPE_POINT_TO_POINT);
54
55 /** \brief changes face state
Junxiao Shi02b73f52016-07-28 01:48:27 +000056 * \throw std::runtime_error state transition is invalid
Junxiao Shicde37ad2015-12-24 01:02:05 -070057 */
Davide Pesavento66ff0982015-01-29 22:39:00 +010058 void
Junxiao Shicde37ad2015-12-24 01:02:05 -070059 setState(FaceState state);
Junxiao Shi9b27bd22014-02-26 20:29:58 -070060
Junxiao Shicde37ad2015-12-24 01:02:05 -070061 /** \brief causes the face to receive an Interest
62 */
Davide Pesavento66ff0982015-01-29 22:39:00 +010063 void
Junxiao Shicde37ad2015-12-24 01:02:05 -070064 receiveInterest(const Interest& interest);
Alexander Afanasyeva0a10fb2014-02-13 19:56:15 -080065
Junxiao Shicde37ad2015-12-24 01:02:05 -070066 /** \brief causes the face to receive a Data
67 */
Davide Pesavento66ff0982015-01-29 22:39:00 +010068 void
Junxiao Shicde37ad2015-12-24 01:02:05 -070069 receiveData(const Data& data);
Alexander Afanasyev93ce75e2014-02-18 19:45:34 -080070
Junxiao Shicde37ad2015-12-24 01:02:05 -070071 /** \brief causes the face to receive a Nack
72 */
Junxiao Shi9b27bd22014-02-26 20:29:58 -070073 void
Junxiao Shicde37ad2015-12-24 01:02:05 -070074 receiveNack(const lp::Nack& nack);
Junxiao Shi9b27bd22014-02-26 20:29:58 -070075
Junxiao Shicde37ad2015-12-24 01:02:05 -070076 /** \brief signals after any network-layer packet is sent
77 *
78 * The network-layer packet type is indicated as an argument,
79 * which is either of tlv::Interest, tlv::Data, or lp::tlv::Nack.
80 * The callback may retrieve the packet from sentInterests.back(), sentData.back(), or sentNacks.back().
81 */
82 signal::Signal<LinkService, uint32_t>& afterSend;
Junxiao Shi9b27bd22014-02-26 20:29:58 -070083
Junxiao Shicde37ad2015-12-24 01:02:05 -070084private:
85 LinkService*
86 getLinkServiceInternal();
87
Junxiao Shi9b27bd22014-02-26 20:29:58 -070088public:
Junxiao Shicde37ad2015-12-24 01:02:05 -070089 std::vector<Interest>& sentInterests;
90 std::vector<Data>& sentData;
91 std::vector<lp::Nack>& sentNacks;
Junxiao Shicbba04c2014-01-26 14:21:22 -070092};
93
Junxiao Shicde37ad2015-12-24 01:02:05 -070094} // namespace tests
95} // namespace face
Alexander Afanasyevbd220a02014-02-20 00:29:56 -080096
Junxiao Shicde37ad2015-12-24 01:02:05 -070097namespace tests {
98using nfd::face::tests::DummyFace;
Junxiao Shid9ee45c2014-02-27 15:38:11 -070099} // namespace tests
Davide Pesavento16916ae2019-03-29 23:53:26 -0400100
Alexander Afanasyev18bbf812014-01-29 01:40:23 -0800101} // namespace nfd
Junxiao Shicbba04c2014-01-26 14:21:22 -0700102
Junxiao Shi08d07a72014-06-09 23:17:57 -0700103#endif // NFD_TESTS_DAEMON_FACE_DUMMY_FACE_HPP