X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=src%2Futil%2Ftest_connection_timeout.c;h=ec8057cf29cea16c22f7757a649bc64a6e2728ba;hb=69f9662283ade69910b500e00f491a47c1b4eb8c;hp=61d9a2d0774fcbc9ef649e9be12675b1c3d613ab;hpb=db5fce6cd527aa49fb5762d730564a918131a30f;p=oweals%2Fgnunet.git diff --git a/src/util/test_connection_timeout.c b/src/util/test_connection_timeout.c index 61d9a2d07..ec8057cf2 100644 --- a/src/util/test_connection_timeout.c +++ b/src/util/test_connection_timeout.c @@ -4,7 +4,7 @@ GNUnet is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published - by the Free Software Foundation; either version 2, or (at your + by the Free Software Foundation; either version 3, or (at your option) any later version. GNUnet is distributed in the hope that it will be useful, but @@ -22,12 +22,7 @@ * @brief tests for connection.c */ #include "platform.h" -#include "gnunet_common.h" -#include "gnunet_connection_lib.h" -#include "gnunet_scheduler_lib.h" -#include "gnunet_time_lib.h" - -#define VERBOSE GNUNET_NO +#include "gnunet_util_lib.h" #define PORT 12435 @@ -35,7 +30,9 @@ static struct GNUNET_CONNECTION_Handle *csock; static struct GNUNET_CONNECTION_Handle *lsock; -static struct GNUNET_NETWORK_Descriptor *ls; +static struct GNUNET_NETWORK_Handle *ls; + +static struct GNUNET_CONFIGURATION_Handle *cfg; /** @@ -43,21 +40,27 @@ static struct GNUNET_NETWORK_Descriptor *ls; * * @return NULL on error, otherwise the listen socket */ -static struct GNUNET_NETWORK_Descriptor * +static struct GNUNET_NETWORK_Handle * open_listen_socket () { const static int on = 1; struct sockaddr_in sa; - struct GNUNET_NETWORK_Descriptor *desc; + struct GNUNET_NETWORK_Handle *desc; memset (&sa, 0, sizeof (sa)); +#if HAVE_SOCKADDR_IN_SIN_LEN + sa.sin_len = sizeof (sa); +#endif + sa.sin_family = AF_INET; sa.sin_port = htons (PORT); - desc = GNUNET_NETWORK_socket_socket (AF_INET, SOCK_STREAM, 0); + desc = GNUNET_NETWORK_socket_create (AF_INET, SOCK_STREAM, 0); GNUNET_assert (desc != NULL); - if (GNUNET_NETWORK_socket_setsockopt (desc, SOL_SOCKET, SO_REUSEADDR, &on, sizeof (on)) < 0) - GNUNET_log (GNUNET_ERROR_TYPE_ERROR | GNUNET_ERROR_TYPE_BULK, - "setsockopt"); - GNUNET_assert (GNUNET_NETWORK_socket_bind (desc, &sa, sizeof (sa)) >= 0); + if (GNUNET_NETWORK_socket_setsockopt + (desc, SOL_SOCKET, SO_REUSEADDR, &on, sizeof (on)) != GNUNET_OK) + GNUNET_log (GNUNET_ERROR_TYPE_ERROR | GNUNET_ERROR_TYPE_BULK, "setsockopt"); + GNUNET_assert (GNUNET_OK == + GNUNET_NETWORK_socket_bind (desc, (const struct sockaddr *) &sa, + sizeof (sa))); GNUNET_NETWORK_socket_listen (desc, 5); return desc; } @@ -67,28 +70,24 @@ static size_t send_kilo (void *cls, size_t size, void *buf) { int *ok = cls; + if (size == 0) - { -#if VERBOSE - GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "Got the desired timeout!\n"); -#endif - GNUNET_assert (buf == NULL); - *ok = 0; - GNUNET_CONNECTION_destroy (lsock); - GNUNET_CONNECTION_destroy (csock); - return 0; - } -#if VERBOSE + { + GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "Got the desired timeout!\n"); + GNUNET_assert (buf == NULL); + *ok = 0; + GNUNET_CONNECTION_destroy (lsock); + GNUNET_CONNECTION_destroy (csock); + return 0; + } GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "Sending kilo to fill buffer.\n"); -#endif GNUNET_assert (size >= 1024); memset (buf, 42, 1024); GNUNET_assert (NULL != - GNUNET_CONNECTION_notify_transmit_ready (csock, - 1024, - GNUNET_TIME_UNIT_SECONDS, - &send_kilo, cls)); + GNUNET_CONNECTION_notify_transmit_ready (csock, 1024, + GNUNET_TIME_UNIT_SECONDS, + &send_kilo, cls)); return 1024; } @@ -98,47 +97,33 @@ task_timeout (void *cls, const struct GNUNET_SCHEDULER_TaskContext *tc) { ls = open_listen_socket (); - lsock = GNUNET_CONNECTION_create_from_existing (tc->sched, ls, 0); + lsock = GNUNET_CONNECTION_create_from_existing (ls); GNUNET_assert (lsock != NULL); - csock = GNUNET_CONNECTION_create_from_connect (tc->sched, - "localhost", PORT, 1024); + csock = GNUNET_CONNECTION_create_from_connect (cfg, "localhost", PORT); GNUNET_assert (csock != NULL); GNUNET_assert (NULL != - GNUNET_CONNECTION_notify_transmit_ready (csock, - 1024, - GNUNET_TIME_UNIT_SECONDS, - &send_kilo, cls)); + GNUNET_CONNECTION_notify_transmit_ready (csock, 1024, + GNUNET_TIME_UNIT_SECONDS, + &send_kilo, cls)); } - -/** - * Main method, starts scheduler with task_timeout. - */ -static int -check_timeout () -{ - int ok; - - ok = 1; - GNUNET_SCHEDULER_run (&task_timeout, &ok); - return ok; -} - int main (int argc, char *argv[]) { - int ret = 0; + int ok; GNUNET_log_setup ("test_connection_timeout", -#if VERBOSE - "DEBUG", -#else "WARNING", -#endif NULL); - ret += check_timeout (); - return ret; + + ok = 1; + cfg = GNUNET_CONFIGURATION_create (); + GNUNET_CONFIGURATION_set_value_string (cfg, "resolver", "HOSTNAME", + "localhost"); + GNUNET_SCHEDULER_run (&task_timeout, &ok); + GNUNET_CONFIGURATION_destroy (cfg); + return ok; } /* end of test_connection_timeout.c */