GNUnet 0.24.1-14-gdb0ea5ed9
plugin_testing_transport_nat_mapping.c File Reference
#include "platform.h"
#include "gnunet_testing_barrier.h"
#include "gnunet_testing_netjail_lib.h"
#include "gnunet_util_lib.h"
#include "gnunet_transport_application_service.h"
#include "transport-testing2.h"
#include "transport-testing-cmds.h"
Include dependency graph for plugin_testing_transport_nat_mapping.c:

Go to the source code of this file.

Macros

#define LOG(kind, ...)   GNUNET_log (kind, __VA_ARGS__)
 Generic logging shortcut. More...
 
#define BASE_DIR   "testdir"
 
#define TIMEOUT   GNUNET_TIME_relative_multiply (GNUNET_TIME_UNIT_SECONDS, 600)
 
#define ROUTER_BASE_IP   "92.68.150."
 

Functions

static int check_test (void *cls, const struct GNUNET_TRANSPORT_TESTING_TestMessage *message)
 Function called to check a message of type GNUNET_TRANSPORT_TESTING_SIMPLE_MTYPE being received. More...
 
static void handle_test (void *cls, const struct GNUNET_TRANSPORT_TESTING_TestMessage *message)
 Function called to handle a message of type GNUNET_TRANSPORT_TESTING_SIMPLE_MTYPE being received. More...
 
struct GNUNET_TESTING_BarrierList * get_waiting_for_barriers ()
 
static void all_peers_started ()
 Callback to set the flag indicating all peers started. More...
 
static void handle_result (void *cls, enum GNUNET_GenericReturnValue rv)
 Function called with the final result of the test. More...
 
static void * notify_connect (struct GNUNET_TESTING_Interpreter *is, const struct GNUNET_PeerIdentity *peer)
 Callback from start peer cmd for signaling a peer got connected. More...
 
static void all_local_tests_prepared ()
 Callback to set the flag indicating all peers are prepared to finish. More...
 
static void child_completed_callback (void *cls, enum GNUNET_OS_ProcessStatusType type, long unsigned int exit_code)
 
static struct GNUNET_TESTING_Interpreterstart_testcase (GNUNET_TESTING_cmd_helper_write_cb write_message, const char *router_ip, const char *node_ip, const char *m, const char *n, const char *local_m, const char *topology_data, unsigned int *read_file, GNUNET_TESTING_cmd_helper_finish_cb finished_cb)
 Function to start a local test case. More...
 
void * libgnunet_test_transport_plugin_cmd_nat_mapping_init (void *cls)
 Entry point for the plugin. More...
 
void * libgnunet_test_transport_plugin_cmd_nat_mapping_done (void *cls)
 Exit point from the plugin. More...
 

Variables

static struct GNUNET_TESTING_Command block_send
 
static struct GNUNET_TESTING_Command block_receive
 
static struct GNUNET_TESTING_Command connect_peers
 
static struct GNUNET_TESTING_Command local_prepared
 
static struct GNUNET_TESTING_Interpreteris
 

Macro Definition Documentation

◆ LOG

#define LOG (   kind,
  ... 
)    GNUNET_log (kind, __VA_ARGS__)

Generic logging shortcut.

Definition at line 38 of file plugin_testing_transport_nat_mapping.c.

◆ BASE_DIR

#define BASE_DIR   "testdir"

Definition at line 40 of file plugin_testing_transport_nat_mapping.c.

◆ TIMEOUT

◆ ROUTER_BASE_IP

#define ROUTER_BASE_IP   "92.68.150."

Definition at line 44 of file plugin_testing_transport_nat_mapping.c.

Function Documentation

◆ check_test()

static int check_test ( void *  cls,
const struct GNUNET_TRANSPORT_TESTING_TestMessage message 
)
static

Function called to check a message of type GNUNET_TRANSPORT_TESTING_SIMPLE_MTYPE being received.

Definition at line 62 of file plugin_testing_transport_nat_mapping.c.

64{
65 return GNUNET_OK;
66}
@ GNUNET_OK

References GNUNET_OK.

◆ handle_test()

static void handle_test ( void *  cls,
const struct GNUNET_TRANSPORT_TESTING_TestMessage message 
)
static

Function called to handle a message of type GNUNET_TRANSPORT_TESTING_SIMPLE_MTYPE being received.

Definition at line 75 of file plugin_testing_transport_nat_mapping.c.

77{
79
80 GNUNET_TESTING_get_trait_async_context (&block_receive,
81 &ac);
82 GNUNET_assert (NULL != ac);
83 if (NULL == ac->cont)
85 else
87}
void GNUNET_TESTING_async_finish(struct GNUNET_TESTING_AsyncContext *ac)
The asynchronous command of ac has finished.
void GNUNET_TESTING_async_fail(struct GNUNET_TESTING_AsyncContext *ac)
The asynchronous command of ac has failed.
#define GNUNET_assert(cond)
Use this for fatal errors that cannot be handled.
static struct GNUNET_TESTING_Command block_receive
State each asynchronous command must have in its closure.

References block_receive, GNUNET_assert, GNUNET_TESTING_async_fail(), and GNUNET_TESTING_async_finish().

Here is the call graph for this function:

◆ get_waiting_for_barriers()

struct GNUNET_TESTING_BarrierList * get_waiting_for_barriers ( )

Definition at line 91 of file plugin_testing_transport_nat_mapping.c.

92{
93 //No Barrier
94 return GNUNET_new (struct GNUNET_TESTING_BarrierList);
95}
#define GNUNET_new(type)
Allocate a struct or union of the given type.

References GNUNET_new.

Referenced by libgnunet_test_transport_plugin_cmd_nat_mapping_init().

Here is the caller graph for this function:

◆ all_peers_started()

static void all_peers_started ( )
static

Callback to set the flag indicating all peers started.

Will be called via the plugin api.

Definition at line 103 of file plugin_testing_transport_nat_mapping.c.

104{
106
107 GNUNET_TESTING_get_trait_async_context (&block_send,
108 &ac);
109 GNUNET_assert (NULL != ac);
110 if (NULL == ac->cont)
112 else
114}
static struct GNUNET_TESTING_Command block_send

References block_send, GNUNET_assert, GNUNET_TESTING_async_fail(), and GNUNET_TESTING_async_finish().

Referenced by libgnunet_test_transport_plugin_cmd_nat_mapping_init().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ handle_result()

static void handle_result ( void *  cls,
enum GNUNET_GenericReturnValue  rv 
)
static

Function called with the final result of the test.

Parameters
clsthe struct MainParams
rvGNUNET_OK if the test passed

Definition at line 124 of file plugin_testing_transport_nat_mapping.c.

126{
127 struct TestState *ts = cls;
128
130 "Local test exits with status %d\n",
131 rv);
132
133 ts->finished_cb (rv);
134 GNUNET_free (ts->testdir);
135 GNUNET_free (ts->cfgname);
137 GNUNET_free (ts);
138}
#define GNUNET_log(kind,...)
@ GNUNET_ERROR_TYPE_DEBUG
#define GNUNET_free(ptr)
Wrapper around free.
char * cfgname
The name for the configuration file of the specific node.
char * testdir
The name for a specific test environment directory.
struct GNUNET_TESTING_NetjailTopology * topology
The complete topology information.
void GNUNET_TESTING_free_topology(struct GNUNET_TESTING_NetjailTopology *topology)
Deallocate memory of the struct GNUNET_TESTING_NetjailTopology.

References TestState::cfgname, GNUNET_ERROR_TYPE_DEBUG, GNUNET_free, GNUNET_log, GNUNET_TESTING_free_topology(), TestState::testdir, and TestState::topology.

Referenced by start_testcase().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ notify_connect()

static void * notify_connect ( struct GNUNET_TESTING_Interpreter is,
const struct GNUNET_PeerIdentity peer 
)
static

Callback from start peer cmd for signaling a peer got connected.

Definition at line 146 of file plugin_testing_transport_nat_mapping.c.

148{
149 const struct ConnectPeersState *cps;
150 const struct GNUNET_TESTING_Command *cmd;
151
153 "connect-peers");
154 GNUNET_TRANSPORT_TESTING_get_trait_connect_peer_state (cmd,
155 &cps);
156 void *ret = NULL;
157
158 cps->notify_connect (is,
159 peer);
160 return ret;
161}
static int ret
Final status code.
Definition: gnunet-arm.c:93
const struct GNUNET_TESTING_Command * GNUNET_TESTING_interpreter_lookup_command(struct GNUNET_TESTING_Interpreter *is, const char *label)
Lookup command by label.
static struct GNUNET_TESTING_Interpreter * is
Struct to store information needed in callbacks.
GNUNET_TESTING_notify_connect_cb notify_connect
A command to be run by the interpreter.

References GNUNET_TESTING_interpreter_lookup_command(), is, ConnectPeersState::notify_connect, and ret.

Referenced by start_testcase().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ all_local_tests_prepared()

static void all_local_tests_prepared ( )
static

Callback to set the flag indicating all peers are prepared to finish.

Will be called via the plugin api.

Definition at line 168 of file plugin_testing_transport_nat_mapping.c.

169{
170 const struct GNUNET_TESTING_LocalPreparedState *lfs;
171
172 GNUNET_TESTING_get_trait_local_prepared_state (&local_prepared,
173 &lfs);
174 GNUNET_assert (NULL != &lfs->ac);
175 if (NULL == lfs->ac.cont)
177 else
179 GNUNET_TESTING_AsyncContext *) &lfs->ac);
180}
static struct GNUNET_TESTING_Command local_prepared

References GNUNET_assert, GNUNET_TESTING_async_fail(), GNUNET_TESTING_async_finish(), and local_prepared.

Referenced by libgnunet_test_transport_plugin_cmd_nat_mapping_init().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ child_completed_callback()

static void child_completed_callback ( void *  cls,
enum GNUNET_OS_ProcessStatusType  type,
long unsigned int  exit_code 
)
static

Definition at line 184 of file plugin_testing_transport_nat_mapping.c.

187{
188
189}

Referenced by start_testcase().

Here is the caller graph for this function:

◆ start_testcase()

static struct GNUNET_TESTING_Interpreter * start_testcase ( GNUNET_TESTING_cmd_helper_write_cb  write_message,
const char *  router_ip,
const char *  node_ip,
const char *  m,
const char *  n,
const char *  local_m,
const char *  topology_data,
unsigned int *  read_file,
GNUNET_TESTING_cmd_helper_finish_cb  finished_cb 
)
static

Function to start a local test case.

Parameters
write_messageCallback to send a message to the master loop.
router_ipGlobal address of the network namespace.
node_ipThe IP address of the node.
mThe number of the node in a network namespace.
nThe number of the network namespace.
local_mThe number of nodes in a network namespace.

Definition at line 203 of file plugin_testing_transport_nat_mapping.c.

212{
213
214 unsigned int n_int;
215 unsigned int m_int;
216 unsigned int local_m_int;
217 unsigned int num;
218 struct TestState *ts = GNUNET_new (struct TestState);
219 struct GNUNET_TESTING_NetjailTopology *topology;
220 unsigned int sscanf_ret = 0;
221 char **argv = NULL;
222 unsigned int argc = 0;
223 char *dst_ip;
224 char *num_string;
225
226
227
228 ts->finished_cb = finished_cb;
230 "n %s m %s\n",
231 n,
232 m);
233
234 if (GNUNET_YES == *read_file)
235 {
237 "read from file\n");
238 topology = GNUNET_TESTING_get_topo_from_file (topology_data);
239 }
240 else
241 topology = GNUNET_TESTING_get_topo_from_string (topology_data);
242
243 ts->topology = topology;
244
245 errno = 0;
246 sscanf_ret = sscanf (m, "%u", &m_int);
247 if (errno != 0)
248 {
250 }
251 GNUNET_assert (0 < sscanf_ret);
252 errno = 0;
253 sscanf_ret = sscanf (n, "%u", &n_int);
254 if (errno != 0)
255 {
257 }
258 GNUNET_assert (0 < sscanf_ret);
259 errno = 0;
260 sscanf_ret = sscanf (local_m, "%u", &local_m_int);
261 if (errno != 0)
262 {
264 }
265 GNUNET_assert (0 < sscanf_ret);
266
267 if (0 == n_int)
268 num = m_int;
269 else
270 num = (n_int - 1) * local_m_int + m_int + topology->nodes_x;
271
272 block_send = GNUNET_TESTING_cmd_block_until_external_trigger (
273 "block");
274 block_receive = GNUNET_TESTING_cmd_block_until_external_trigger (
275 "block-receive");
277 "start-peer",
278 "system-create",
279 num,
280 topology,
281 0,
282 GNUNET_YES);
283 local_prepared = GNUNET_TESTING_cmd_local_test_prepared (
284 "local-test-prepared",
286
287
289 "test_transport_api_tcp_node1.conf");
290
292 "plugin cfgname: %s\n",
293 ts->cfgname);
294
296 "node ip: %s\n",
297 node_ip);
298
300 "%s%s%s",
301 BASE_DIR,
302 m,
303 n);
304
309 ts),
311 };
312
314 "num: %u\n",
315 num);
316 GNUNET_asprintf (&num_string,
317 "%u",
318 num);
319 GNUNET_array_append (argv, argc, "7777");
320 GNUNET_array_append (argv, argc, num_string);
321 if (1 == num )
322 {
323 GNUNET_asprintf (&dst_ip,
324 ROUTER_BASE_IP "%u",
325 num + 1);
326 GNUNET_array_append (argv, argc, dst_ip);
327 }
328 else
329 {
330 GNUNET_asprintf (&dst_ip,
331 ROUTER_BASE_IP "%u",
332 num - 1);
333 GNUNET_array_append (argv, argc, dst_ip);
334 }
335
337 "dst_ip %s\n",
338 dst_ip);
340 GNUNET_TESTING_cmd_system_create ("system-create",
341 ts->testdir),
343 "system-create",
344 num,
345 node_ip,
346 handlers,
347 ts->cfgname,
349 GNUNET_NO),
350 GNUNET_TESTING_cmd_exec_bash_script ("nat_node_test",
351 "nat_node_test.sh",
352 argv,
353 argc,
355 GNUNET_TESTING_cmd_send_peer_ready ("send-peer-ready",
361 "start-peer"),
362 GNUNET_TESTING_cmd_system_destroy ("system-destroy",
363 "system-create"),
365 };
366
367 ts->write_message = write_message;
368
370 TIMEOUT,
372 ts);
373 GNUNET_free (num_string);
374 GNUNET_free (dst_ip);
375 return is;
376}
struct GNUNET_MQ_MessageHandlers handlers[]
Definition: 003.c:1
static struct GNUNET_ARM_MonitorHandle * m
Monitor connection with ARM.
Definition: gnunet-arm.c:103
static void write_message(const struct GNUNET_MessageHeader *message)
Callback to write a message to the parent process.
static void finished_cb(void *cls, enum GNUNET_GenericReturnValue rv)
static struct VoipCommand commands[]
List of supported commands.
struct GNUNET_TESTING_Interpreter * GNUNET_TESTING_run(const struct GNUNET_TESTING_Command *commands, struct GNUNET_TIME_Relative timeout, GNUNET_TESTING_ResultCallback rc, void *rc_cls)
Run the testsuite.
struct GNUNET_TESTING_Command GNUNET_TESTING_cmd_end(void)
Create command array terminator.
@ GNUNET_YES
@ GNUNET_NO
#define GNUNET_log_strerror(level, cmd)
Log an error message at log-level 'level' that indicates a failure of the command 'cmd' with the mess...
@ GNUNET_ERROR_TYPE_ERROR
int int GNUNET_asprintf(char **buf, const char *format,...) __attribute__((format(printf
Like asprintf, just portable.
#define GNUNET_array_append(arr, len, element)
Append an element to an array (growing the array by one).
#define GNUNET_MQ_handler_end()
End-marker for the handlers array.
#define GNUNET_MQ_hd_var_size(name, code, str, ctx)
enum GNUNET_GenericReturnValue read_file(char const *const filename, char **buffer)
Definition: pabc_helper.c:71
static void child_completed_callback(void *cls, enum GNUNET_OS_ProcessStatusType type, long unsigned int exit_code)
static void handle_result(void *cls, enum GNUNET_GenericReturnValue rv)
Function called with the final result of the test.
static struct GNUNET_TESTING_Command connect_peers
static void * notify_connect(struct GNUNET_TESTING_Interpreter *is, const struct GNUNET_PeerIdentity *peer)
Callback from start peer cmd for signaling a peer got connected.
#define LOG(kind,...)
Generic logging shortcut.
Message handler for a specific message type.
Topology of our netjail setup.
unsigned int nodes_x
Number of global known nodes.
struct GNUNET_TESTING_Command GNUNET_TRANSPORT_cmd_stop_peer(const char *label, const char *start_label)
Create command.
struct GNUNET_TESTING_Command GNUNET_TRANSPORT_cmd_connect_peers(const char *label, const char *start_peer_label, const char *create_label, uint32_t num, struct GNUNET_TESTING_NetjailTopology *topology, unsigned int additional_connects, unsigned int wait_for_connect)
Create command.
struct GNUNET_TESTING_Command GNUNET_TRANSPORT_cmd_start_peer(const char *label, const char *system_label, uint32_t no, const char *node_ip, struct GNUNET_MQ_MessageHandler *handlers, const char *cfgname, GNUNET_TRANSPORT_notify_connect_cb notify_connect, unsigned int broadcast)
Create command.
#define GNUNET_TRANSPORT_TESTING_SIMPLE_MTYPE
Message type used by GNUNET_TRANSPORT_TESTING_simple_send().

References BASE_DIR, block_receive, block_send, TestState::cfgname, child_completed_callback(), commands, connect_peers, finished_cb(), GNUNET_array_append, GNUNET_asprintf(), GNUNET_assert, GNUNET_ERROR_TYPE_DEBUG, GNUNET_ERROR_TYPE_ERROR, GNUNET_free, GNUNET_log_strerror, GNUNET_MQ_handler_end, GNUNET_MQ_hd_var_size, GNUNET_new, GNUNET_NO, GNUNET_TESTING_cmd_end(), GNUNET_TESTING_run(), GNUNET_TRANSPORT_cmd_connect_peers(), GNUNET_TRANSPORT_cmd_start_peer(), GNUNET_TRANSPORT_cmd_stop_peer(), GNUNET_TRANSPORT_TESTING_SIMPLE_MTYPE, GNUNET_YES, handle_result(), handlers, is, local_prepared, LOG, m, GNUNET_TESTING_NetjailTopology::nodes_x, notify_connect(), read_file(), ROUTER_BASE_IP, TestState::testdir, TIMEOUT, TestState::topology, and write_message().

Referenced by libgnunet_test_transport_plugin_cmd_nat_mapping_init().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ libgnunet_test_transport_plugin_cmd_nat_mapping_init()

void * libgnunet_test_transport_plugin_cmd_nat_mapping_init ( void *  cls)

Entry point for the plugin.

Parameters
clsNULL
Returns
the exported block API

Definition at line 386 of file plugin_testing_transport_nat_mapping.c.

387{
389
390 GNUNET_log_setup ("simple-send",
391 "DEBUG",
392 NULL);
393
396 api->all_peers_started = &all_peers_started;
397 api->all_local_tests_prepared = all_local_tests_prepared;
398 api->get_waiting_for_barriers = get_waiting_for_barriers;
399 return api;
400}
enum GNUNET_GenericReturnValue GNUNET_log_setup(const char *comp, const char *loglevel, const char *logfile)
Setup logging.
static void all_local_tests_prepared()
Callback to set the flag indicating all peers are prepared to finish.
struct GNUNET_TESTING_BarrierList * get_waiting_for_barriers()
static void all_peers_started()
Callback to set the flag indicating all peers started.
static struct GNUNET_TESTING_Interpreter * start_testcase(GNUNET_TESTING_cmd_helper_write_cb write_message, const char *router_ip, const char *node_ip, const char *m, const char *n, const char *local_m, const char *topology_data, unsigned int *read_file, GNUNET_TESTING_cmd_helper_finish_cb finished_cb)
Function to start a local test case.
The plugin API every test case plugin has to implement.
struct GNUNET_TESTING_Interpreter *(* start_testcase)(void *cls, const char *topology_data, uint32_t barrier_count, const struct GNUNET_ShortHashCode *barriers, GNUNET_TESTING_cmd_helper_write_cb write_message, GNUNET_TESTING_ResultCallback finish_cb, void *finish_cb_cls)
Function to be implemented for each test case plugin which starts the test case on a netjail node.

References all_local_tests_prepared(), all_peers_started(), get_waiting_for_barriers(), GNUNET_log_setup(), GNUNET_new, start_testcase(), and GNUNET_TESTING_PluginFunctions::start_testcase.

Here is the call graph for this function:

◆ libgnunet_test_transport_plugin_cmd_nat_mapping_done()

void * libgnunet_test_transport_plugin_cmd_nat_mapping_done ( void *  cls)

Exit point from the plugin.

Parameters
clsthe return value from libgnunet_test_transport_plugin_cmd_nat_mapping_done
Returns
NULL

Definition at line 410 of file plugin_testing_transport_nat_mapping.c.

411{
413
414 GNUNET_free (api);
415 return NULL;
416}
void * cls
Closure to pass to start_testcase.

References GNUNET_TESTING_PluginFunctions::cls, and GNUNET_free.

Variable Documentation

◆ block_send

struct GNUNET_TESTING_Command block_send
static

Definition at line 46 of file plugin_testing_transport_nat_mapping.c.

Referenced by all_peers_started(), and start_testcase().

◆ block_receive

struct GNUNET_TESTING_Command block_receive
static

Definition at line 48 of file plugin_testing_transport_nat_mapping.c.

Referenced by handle_test(), and start_testcase().

◆ connect_peers

struct GNUNET_TESTING_Command connect_peers
static

Definition at line 50 of file plugin_testing_transport_nat_mapping.c.

Referenced by start_testcase().

◆ local_prepared

struct GNUNET_TESTING_Command local_prepared
static

◆ is

struct GNUNET_TESTING_Interpreter* is
static

Definition at line 54 of file plugin_testing_transport_nat_mapping.c.

Referenced by notify_connect(), and start_testcase().