A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
hwmp-simplest-regression.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2009 IITP RAS
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation;
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program; if not, write to the Free Software
15 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16 *
17 * Authors: Kirill Andreev <andreev@iitp.ru>
18 */
19
20#include "ns3/ipv4-interface-container.h"
21#include "ns3/node-container.h"
22#include "ns3/nstime.h"
23#include "ns3/pcap-file.h"
24#include "ns3/test.h"
25
26using namespace ns3;
27
28/**
29 * \ingroup dot11s-test
30 *
31 * \brief Peering Management & HWM Protocol regression test
32 * Initiate scenario with 2 stations. Procedure of opening peer link
33 * is the following:
34 * \verbatim
35 * server client
36 * <-----------|-----------> Broadcast frame
37 * |----------->| Unicast frame
38 *
39 * !!! PMP routines:
40 * <-----------|----------->| Beacon
41 * |----------->| Peer Link Open frame
42 * |<-----------| Peer Link Confirm frame
43 * |<-----------| Peer Link Open frame
44 * |----------->| Peer Link Confirm frame
45 * |............| !!! Data started:
46 * |<-----------|-----------> ARP Request (time 2)
47 * <-----------|----------->| PREQ
48 * |<-----------| PREP
49 * |----------->| ARP reply
50 * <-----------|----------->| ARP Request (reflooded after delay)
51 * |<-----------| Data (first UDP datagram)
52 * <-----------|----------->| ARP Request
53 * |<-----------| ARP reply
54 * |----------->| Data
55 * |<-----------|-----------> ARP Request (reflooded after delay)
56 * |............| Some other beacons
57 * |<-----------| Data
58 * |----------->| Data
59 * |............| !!! Route expiration routines:
60 * |............| !!! (after time 7)
61 * |<-----------|-----------> PREQ (route expired)
62 * |----------->| PREP
63 * |<-----------| Data
64 * |----------->| Data
65 * |............|
66 * \endverbatim
67 * At 10 seconds stations become unreachable, so UDP client tries to
68 * close peer link due to TX-fail, and UDP server tries to close peer link
69 * due to beacon loss
70 */
72{
73 public:
76
77 void DoRun() override;
78 /// Check results function
79 void CheckResults();
80
81 private:
82 /// \internal It is important to have pointers here
84 /// Simulation time
87
88 /// Create nodes function
89 void CreateNodes();
90 /// Create devices function
91 void CreateDevices();
92 /// Install application function
94 /// Reset position
95 void ResetPosition();
96
97 /// Server-side socket
99 /// Client-side socket
101
102 /// sent packets counter
104
105 /**
106 * Send data
107 * \param socket the sending socket
108 */
109 void SendData(Ptr<Socket> socket);
110
111 /**
112 * \brief Handle a packet reception.
113 *
114 * This function is called by lower layers.
115 *
116 * \param socket the socket the packet was received to.
117 */
118 void HandleReadServer(Ptr<Socket> socket);
119
120 /**
121 * \brief Handle a packet reception.
122 *
123 * This function is called by lower layers.
124 *
125 * \param socket the socket the packet was received to.
126 */
127 void HandleReadClient(Ptr<Socket> socket);
128};
Peering Management & HWM Protocol regression test Initiate scenario with 2 stations.
void HandleReadClient(Ptr< Socket > socket)
Handle a packet reception.
void DoRun() override
Implementation to actually run this TestCase.
Ipv4InterfaceContainer m_interfaces
interfaces
void CheckResults()
Check results function.
void HandleReadServer(Ptr< Socket > socket)
Handle a packet reception.
void CreateDevices()
Create devices function.
Ptr< Socket > m_serverSocket
Server-side socket.
void CreateNodes()
Create nodes function.
void InstallApplications()
Install application function.
void SendData(Ptr< Socket > socket)
Send data.
uint32_t m_sentPktsCounter
sent packets counter
Ptr< Socket > m_clientSocket
Client-side socket.
holds a vector of std::pair of Ptr<Ipv4> and interface index.
keep track of a set of node pointers.
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:77
encapsulates test code
Definition: test.h:1061
Simulation virtual time values and global simulation resolution.
Definition: nstime.h:105
Every class exported by the ns3 library is enclosed in the ns3 namespace.