GNUnet 0.24.1-12-gebf1afa89
plugin_testing_transport_udp_backchannel.c
Go to the documentation of this file.
1/*
2 This file is part of GNUnet
3 Copyright (C) 2021 GNUnet e.V.
4
5 GNUnet is free software: you can redistribute it and/or modify it
6 under the terms of the GNU Affero General Public License as published
7 by the Free Software Foundation, either version 3 of the License,
8 or (at your option) any later version.
9
10 GNUnet is distributed in the hope that it will be useful, but
11 WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Affero General Public License for more details.
14
15 You should have received a copy of the GNU Affero General Public License
16 along with this program. If not, see <http://www.gnu.org/licenses/>.
17
18 SPDX-License-Identifier: AGPL3.0-or-later
19 */
20
26#include "platform.h"
27#include "gnunet_testing_barrier.h"
28#include "gnunet_testing_netjail_lib.h"
29#include "gnunet_util_lib.h"
31#include "transport-testing2.h"
33#include "gnunet_testing_barrier.h"
34
38#define LOG(kind, ...) GNUNET_log_from (kind, "udp-backchannel", __VA_ARGS__)
39
40#define BASE_DIR "testdir"
41
42#define TOPOLOGY_CONFIG "test_transport_udp_backchannel_topo.conf"
43
44#define TIMEOUT GNUNET_TIME_relative_multiply (GNUNET_TIME_UNIT_SECONDS, 600)
45
47
49
51
53
54
60static int
61check_test (void *cls,
62 const struct GNUNET_TRANSPORT_TESTING_TestMessage *message)
63{
64 return GNUNET_OK;
65}
66
67
73static void
74handle_test (void *cls,
75 const struct GNUNET_TRANSPORT_TESTING_TestMessage *message)
76{
77 // struct GNUNET_TESTING_AsyncContext *ac;
78
79 /*GNUNET_TESTING_get_trait_async_context (&block_receive,
80 &ac);
81 if ((NULL == ac) || (NULL == ac->cont))
82 GNUNET_TESTING_async_fail (ac);
83 else
84 GNUNET_TESTING_async_finish (ac);*/
85}
86
87
88struct GNUNET_TESTING_BarrierList *
90{
91 // No Barrier
92 return GNUNET_new (struct GNUNET_TESTING_BarrierList);
93}
94
95
100static void
102{
104
105 GNUNET_TESTING_get_trait_async_context (&block_send,
106 &ac);
107 GNUNET_assert (NULL != ac);
108 if ((NULL == ac->cont))
110 else
112}
113
114
121static void
122handle_result (void *cls,
124{
125 struct TestState *ts = cls;
126
128 "Local test exits with status %d\n",
129 rv);
130
131 ts->finished_cb (rv);
132 GNUNET_free (ts->testdir);
133 GNUNET_free (ts->cfgname);
135 GNUNET_free (ts);
136}
137
138
143static void *
145 const struct GNUNET_PeerIdentity *peer)
146{
147 const struct ConnectPeersState *cps;
148
149 GNUNET_TRANSPORT_TESTING_get_trait_connect_peer_state (&connect_peers,
150 &cps);
151 void *ret = NULL;
152
153 cps->notify_connect (is,
154 peer);
155 return ret;
156}
157
158
162static void
164{
165 const struct GNUNET_TESTING_LocalPreparedState *lfs;
166
167 GNUNET_TESTING_get_trait_local_prepared_state (&local_prepared,
168 &lfs);
169 GNUNET_assert (NULL != &lfs->ac);
170 if (NULL == lfs->ac.cont)
172 else
174 GNUNET_TESTING_AsyncContext *) &lfs->ac);
175}
176
177
184void *
186{
188
189 unsigned int n_int;
190 unsigned int m_int;
191 unsigned int local_m_int;
192 unsigned int num;
193 struct TestState *ts = GNUNET_new (struct TestState);
194 struct GNUNET_TESTING_NetjailTopology *topology;
195 unsigned int sscanf_ret = 0;
196
197 ts->finished_cb = finished_cb;
199 "n %s m %s\n",
200 n,
201 m);
202
203 if (GNUNET_YES == *read_file)
204 {
206 "read from file\n");
207 topology = GNUNET_TESTING_get_topo_from_file (topology_data);
208 }
209 else
210 topology = GNUNET_TESTING_get_topo_from_string (topology_data);
211
212 ts->topology = topology;
213
214 errno = 0;
215 sscanf_ret = sscanf (m, "%u", &m_int);
216 if (errno != 0)
217 {
219 }
220 GNUNET_assert (0 < sscanf_ret);
221 errno = 0;
222 sscanf_ret = sscanf (n, "%u", &n_int);
223 if (errno != 0)
224 {
226 }
227 GNUNET_assert (0 < sscanf_ret);
228 errno = 0;
229 sscanf_ret = sscanf (local_m, "%u", &local_m_int);
230 if (errno != 0)
231 {
233 }
234 GNUNET_assert (0 < sscanf_ret);
235
236
237 if (0 == n_int)
238 num = m_int;
239 else
240 num = (n_int - 1) * local_m_int + m_int + topology->nodes_x;
241
242 block_send = GNUNET_TESTING_cmd_block_until_external_trigger (
243 "block");
245 "start-peer",
246 "system-create",
247 num,
248 topology,
249 0,
250 GNUNET_YES);
251 local_prepared = GNUNET_TESTING_cmd_local_test_prepared (
252 "local-test-prepared",
254
256 "test_transport_api_tcp_node1.conf");
257
259 "plugin cfgname: %s\n",
260 ts->cfgname);
261
263 "node ip: %s\n",
264 node_ip);
265
267 "%s%s%s",
268 BASE_DIR,
269 m,
270 n);
271
276 NULL),
278 };
279
281 GNUNET_TESTING_cmd_system_create ("system-create",
282 ts->testdir),
284 "system-create",
285 num,
286 node_ip,
287 handlers,
288 ts->cfgname,
290 GNUNET_NO),
291 GNUNET_TESTING_cmd_send_peer_ready ("send-peer-ready",
295 GNUNET_TRANSPORT_cmd_backchannel_check ("backchannel-check",
296 "start-peer",
297 "system-create",
298 num,
299 m_int,
300 n_int,
301 topology),
304 "start-peer"),
305 GNUNET_TESTING_cmd_system_destroy ("system-destroy",
306 "system-create"),
308 };
309
311}
312
313
315 libgnunet,
316 udp_backchannel,
317 GNUNET_TESTING_cmd_system_create ("system-create",
318 ts->testdir),
320 "system-create",
321 num,
322 node_ip,
323 handlers,
324 ts->cfgname,
326 GNUNET_NO),
327 GNUNET_TESTING_cmd_send_peer_ready (
328 "send-peer-ready",
333 "backchannel-check",
334 "start-peer",
335 "system-create",
336 num,
337 m_int,
338 n_int,
339 topology),
342 "start-peer"),
343 GNUNET_TESTING_cmd_system_destroy ("system-destroy",
344 "system-create")
345 );
346
347
354void *
356{
358
359 GNUNET_free (api);
360 return NULL;
361}
362
363
364/* end of plugin_cmd_simple_send.c */
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 int ret
Final status code.
Definition: gnunet-arm.c:93
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.
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.
struct GNUNET_TESTING_Command GNUNET_TESTING_cmd_end(void)
Create command array terminator.
struct GNUNET_TESTING_PluginFunctions * GNUNET_TESTING_make_plugin(const struct GNUNET_TESTING_Command *commands)
Bandwidth allocation API for applications to interact with.
#define GNUNET_log(kind,...)
GNUNET_GenericReturnValue
Named constants for return values.
@ GNUNET_OK
@ GNUNET_YES
@ GNUNET_NO
#define GNUNET_assert(cond)
Use this for fatal errors that cannot be handled.
#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
@ GNUNET_ERROR_TYPE_DEBUG
int int GNUNET_asprintf(char **buf, const char *format,...) __attribute__((format(printf
Like asprintf, just portable.
#define GNUNET_new(type)
Allocate a struct or union of the given type.
#define GNUNET_free(ptr)
Wrapper around free.
#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 struct GNUNET_TESTING_Command block_send
GNUNET_TESTING_MAKE_PLUGIN(libgnunet, udp_backchannel, GNUNET_TESTING_cmd_system_create("system-create", ts->testdir), GNUNET_TRANSPORT_cmd_start_peer("start-peer", "system-create", num, node_ip, handlers, ts->cfgname, notify_connect, GNUNET_NO), GNUNET_TESTING_cmd_send_peer_ready("send-peer-ready", write_message), block_send, connect_peers, GNUNET_TRANSPORT_cmd_backchannel_check("backchannel-check", "start-peer", "system-create", num, m_int, n_int, topology), local_prepared, GNUNET_TRANSPORT_cmd_stop_peer("stop-peer", "start-peer"), GNUNET_TESTING_cmd_system_destroy("system-destroy", "system-create"))
static void handle_result(void *cls, enum GNUNET_GenericReturnValue rv)
Function called with the final result of the test.
static struct GNUNET_TESTING_Command local_prepared
static struct GNUNET_TESTING_Command connect_peers
void * libgnunet_test_transport_plugin_cmd_udp_backchannel_done(void *cls)
Exit point from the plugin.
static void all_local_tests_prepared()
Callback to set the flag indicating all peers are prepared to finish.
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.
struct GNUNET_TESTING_BarrierList * get_waiting_for_barriers()
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.
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.
static struct GNUNET_TESTING_Interpreter * is
void * libgnunet_test_transport_plugin_cmd_udp_backchannel_init(void *cls)
Entry point for the plugin.
#define LOG(kind,...)
Generic logging shortcut.
static void all_peers_started()
Callback to set the flag indicating all peers started.
Struct to store information needed in callbacks.
GNUNET_TESTING_notify_connect_cb notify_connect
Message handler for a specific message type.
The identity of the host (wraps the signing key of the peer).
State each asynchronous command must have in its closure.
A command to be run by the interpreter.
void * cls
Closure for all commands with command-specific context information.
Global state of the interpreter, used by a command to access information about other commands.
Topology of our netjail setup.
unsigned int nodes_x
Number of global known nodes.
The plugin API every test case plugin has to implement.
void * cls
Closure to pass to start_testcase.
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.
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_backchannel_check(const char *label, const char *start_peer_label, const char *create_label, uint32_t num, unsigned int node_n, unsigned int namespace_n, struct GNUNET_TESTING_NetjailTopology *topology)
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().