36#define LOG(kind, ...) GNUNET_log (kind, __VA_ARGS__)
38#define BASE_DIR "testdir"
40#define TOPOLOGY_CONFIG "test_transport_simple_send_topo.conf"
42#define TIMEOUT GNUNET_TIME_relative_multiply (GNUNET_TIME_UNIT_SECONDS, 600)
88struct GNUNET_TESTING_BarrierList *
92 return GNUNET_new (
struct GNUNET_TESTING_BarrierList);
106 "Received message\n");
107 GNUNET_TESTING_get_trait_async_context (&
block_send,
110 if (NULL == ac->cont)
130 "Local test exits with status %d\n",
132 ts->finished_cb (rv);
151 struct GNUNET_TESTING_BlockState *bs;
160 "notify_connect running\n");
162 if (NULL == ac->cont)
169 cmd = GNUNET_TESTING_interpreter_lookup_future_command (
is,
174 GNUNET_TESTING_get_trait_block_state (
180 bs->asynchronous_finish);
184 bs->asynchronous_finish);
197 const struct GNUNET_TESTING_LocalPreparedState *lfs;
202 if (NULL == lfs->ac.cont)
222 const char *router_ip,
227 const char *topology_data,
233 unsigned int local_m_int;
237 unsigned int sscanf_ret = 0;
249 topology = GNUNET_TESTING_get_topo_from_file (topology_data);
252 topology = GNUNET_TESTING_get_topo_from_string (topology_data);
257 sscanf_ret = sscanf (
m,
"%u", &m_int);
264 sscanf_ret = sscanf (n,
"%u", &n_int);
271 sscanf_ret = sscanf (local_m,
"%u", &local_m_int);
281 num = (n_int - 1) * local_m_int + m_int + topology->
nodes_x;
283 block_send = GNUNET_TESTING_cmd_block_until_external_trigger (
"block");
284 block_receive = GNUNET_TESTING_cmd_block_until_external_trigger (
286 connect_peers = GNUNET_TESTING_cmd_block_until_external_trigger (
289 "local-test-prepared",
294 "test_transport_api_tcp_node1.conf");
297 "plugin cfgname: %s\n",
319 GNUNET_TESTING_cmd_system_create (
"system-create",
329 GNUNET_TESTING_cmd_send_peer_ready (
"send-peer-ready",
342 GNUNET_TESTING_cmd_system_destroy (
"system-destroy",
struct GNUNET_MQ_MessageHandlers handlers[]
static struct GNUNET_ARM_MonitorHandle * m
Monitor connection with ARM.
static int ret
Final status code.
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_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.
Bandwidth allocation API for applications to interact with.
#define GNUNET_log(kind,...)
GNUNET_GenericReturnValue
Named constants for return values.
#define GNUNET_assert(cond)
Use this for fatal errors that cannot be handled.
enum GNUNET_GenericReturnValue GNUNET_log_setup(const char *comp, const char *loglevel, const char *logfile)
Setup logging.
#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)
static struct GNUNET_TESTING_Command block_receive
static struct GNUNET_TESTING_Command block_send
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
static void all_local_tests_prepared()
Callback to set the flag indicating all peers are prepared to finish.
void * libgnunet_test_transport_plugin_cmd_simple_send_broadcast_done(void *cls)
Exit point from the plugin.
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
#define LOG(kind,...)
Generic logging shortcut.
static void all_peers_started()
Callback to set the flag indicating all peers started.
void * libgnunet_test_transport_plugin_cmd_simple_send_broadcast_init(void *cls)
Entry point for the plugin.
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.
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.
struct GNUNET_TESTING_Interpreter * is
Interpreter we are part of.
enum GNUNET_GenericReturnValue finished
Indication if the command finished (GNUNET_OK).
A command to be run by the interpreter.
struct GNUNET_TESTING_CommandLabel label
Label for the command.
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.
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.
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_cmd_helper_write_cb)(const struct GNUNET_MessageHeader *message)
Callback function to write messages from the helper process running on a netjail node to the master p...
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_send_simple(const char *label, const char *start_peer_label, const char *create_label, uint32_t num)
Create command.
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_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().