From 9d7ff3c3fbee189367da05a1517777c76a80b23b Mon Sep 17 00:00:00 2001 From: t3sserakt Date: Mon, 19 Jul 2021 19:53:56 +0200 Subject: - finished first prototype for running several local testcase. --- src/testing/testing_api_cmd_send_peer_ready.c | 104 ++++++++++++++++++++++++++ src/testing/testing_api_loop.c | 4 +- 2 files changed, 106 insertions(+), 2 deletions(-) create mode 100644 src/testing/testing_api_cmd_send_peer_ready.c (limited to 'src/testing') diff --git a/src/testing/testing_api_cmd_send_peer_ready.c b/src/testing/testing_api_cmd_send_peer_ready.c new file mode 100644 index 000000000..27761c4d5 --- /dev/null +++ b/src/testing/testing_api_cmd_send_peer_ready.c @@ -0,0 +1,104 @@ +/* + This file is part of GNUnet + Copyright (C) 2021 GNUnet e.V. + + GNUnet is free software: you can redistribute it and/or modify it + under the terms of the GNU Affero General Public License as published + by the Free Software Foundation, either version 3 of the License, + or (at your option) any later version. + + GNUnet is distributed in the hope that it will be useful, but + WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Affero General Public License for more details. + + You should have received a copy of the GNU Affero General Public License + along with this program. If not, see . + + SPDX-License-Identifier: AGPL3.0-or-later + */ + +/** + * @file testing_api_cmd_send_peer_ready.c + * @brief cmd to send a helper message if peer is ready. + * @author t3sserakt + */ +#include "platform.h" +#include "gnunet_util_lib.h" +#include "gnunet_testing_ng_lib.h" +#include "testbed_api.h" +#include "testbed_helper.h" + + +struct SendPeerReadyState +{ + TESTBED_CMD_HELPER_write_cb write_message; + + struct GNUNET_CMDS_PEER_STARTED *reply; +}; + + +static int +send_peer_ready_traits (void *cls, + const void **ret, + const char *trait, + unsigned int index) +{ + return GNUNET_OK; +} + + +static void +send_peer_ready_cleanup (void *cls, + const struct GNUNET_TESTING_Command *cmd) +{ + struct SendPeerReadyState *sprs = cls; + + GNUNET_free (sprs->reply); + GNUNET_free (sprs); +} + + +static void +send_peer_ready_run (void *cls, + const struct GNUNET_TESTING_Command *cmd, + struct GNUNET_TESTING_Interpreter *is) +{ + struct SendPeerReadyState *sprs = cls; + struct GNUNET_CMDS_PEER_STARTED *reply; + size_t msg_length; + + msg_length = sizeof(struct GNUNET_CMDS_HelperInit);// GNUNET_CMDS_PEER_STARTED); + reply = GNUNET_new (struct GNUNET_CMDS_PEER_STARTED); + reply->header.type = htons (GNUNET_MESSAGE_TYPE_CMDS_HELPER_PEER_STARTED); + reply->header.size = htons ((uint16_t) msg_length); + sprs->reply = reply; + sprs->write_message ((struct GNUNET_MessageHeader *) reply, msg_length); +} + + +/** + * Create command. + * + * @param label name for command. + * @return command. + */ +struct GNUNET_TESTING_Command +GNUNET_TESTING_cmd_send_peer_ready (const char *label, + TESTBED_CMD_HELPER_write_cb write_message) +{ + struct SendPeerReadyState *sprs; + + sprs = GNUNET_new (struct SendPeerReadyState); + sprs->write_message = write_message; + + struct GNUNET_TESTING_Command cmd = { + .cls = sprs, + .label = label, + .run = &send_peer_ready_run, + .cleanup = &send_peer_ready_cleanup, + .traits = &send_peer_ready_traits + }; + + return cmd; +} diff --git a/src/testing/testing_api_loop.c b/src/testing/testing_api_loop.c index 7b7dc010a..f4fa4e17e 100644 --- a/src/testing/testing_api_loop.c +++ b/src/testing/testing_api_loop.c @@ -415,7 +415,7 @@ interpreter_run (void *cls) if (NULL == cmd->label) { - GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, + GNUNET_log (GNUNET_ERROR_TYPE_ERROR, "Running command END %p\n", is); is->result = GNUNET_OK; @@ -424,7 +424,7 @@ interpreter_run (void *cls) } else if (NULL != cmd) { - GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, + GNUNET_log (GNUNET_ERROR_TYPE_ERROR, "Running command `%s' %p\n", cmd->label, is); -- cgit v1.2.3