add nick name for cached records
[oweals/gnunet.git] / src / dv / test_transport_dv.c
1 /*
2      This file is part of GNUnet.
3      (C) 2009, 2013 Christian Grothoff (and other contributing authors)
4
5      GNUnet is free software; you can redistribute it and/or modify
6      it under the terms of the GNU General Public License as published
7      by the Free Software Foundation; either version 3, or (at your
8      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      General Public License for more details.
14
15      You should have received a copy of the GNU General Public License
16      along with GNUnet; see the file COPYING.  If not, write to the
17      Free Software Foundation, Inc., 59 Temple Place - Suite 330,
18      Boston, MA 02111-1307, USA.
19 */
20 /**
21  * @file dv/test_transport_dv.c
22  * @brief base testcase for testing distance vector transport
23  */
24 #include "platform.h"
25 #include "gnunet_core_service.h"
26 #include "gnunet_testbed_service.h"
27
28 /**
29  * Return value from main, set to 0 on success.
30  */
31 static int ok;
32
33 struct GNUNET_TESTBED_Operation *topology_op;
34
35 static GNUNET_SCHEDULER_TaskIdentifier shutdown_task;
36
37 static void do_shutdown (void *cls, const struct GNUNET_SCHEDULER_TaskContext *tc)
38 {
39   if (NULL != topology_op)
40   {
41     GNUNET_TESTBED_operation_done (topology_op);
42     topology_op = NULL;
43   }
44 }
45
46 static void topology_completed (void *cls,
47                                 unsigned int nsuccess,
48                                 unsigned int nfailures)
49 {
50   GNUNET_log (GNUNET_ERROR_TYPE_INFO, "Links successful %u / %u failed\n", nsuccess, nfailures);
51   GNUNET_TESTBED_operation_done (topology_op);
52   topology_op = NULL;
53
54   if (nfailures > 0)
55   {
56     fprintf (stderr, "Error: links successful %u but %u failed\n", nsuccess, nfailures);
57     ok = 1;
58   }
59   else
60     ok = 0;
61
62   GNUNET_SCHEDULER_shutdown ();
63 }
64
65
66 static void
67 test_connection (void *cls,
68                  struct GNUNET_TESTBED_RunHandle *h,
69                  unsigned int num_peers,
70                  struct GNUNET_TESTBED_Peer **peers,
71                  unsigned int links_succeeded,
72                  unsigned int links_failed)
73 {
74   shutdown_task = GNUNET_SCHEDULER_add_delayed (GNUNET_TIME_UNIT_FOREVER_REL, &do_shutdown, NULL);
75   if (4 != num_peers)
76   {
77     ok = 1;
78     fprintf (stderr, "Only %u out of 4 peers were started ...\n",
79         num_peers);
80   }
81
82   if (0 != links_failed)
83   {
84     /* All peers except DV peers are connected  */
85     fprintf (stderr, "Testbed failed to connect peers,\n");
86
87     topology_op = GNUNET_TESTBED_overlay_configure_topology(NULL, num_peers, peers, NULL,
88         &topology_completed, NULL,
89         GNUNET_TESTBED_TOPOLOGY_CLIQUE,
90         GNUNET_TESTBED_TOPOLOGY_OPTION_END);
91     return;
92   }
93
94   ok = 1;
95   fprintf (stderr, "Testbed connected peers, should not happen...\n");
96   GNUNET_SCHEDULER_shutdown ();
97 }
98
99
100 int
101 main (int argc, char *argv[])
102 {
103   ok = 1;
104   /* Connecting initial topology */
105   (void) GNUNET_TESTBED_test_run ("test-transport-dv",
106                                   "test_transport_dv_data.conf",
107                                   4,
108                                   0, NULL, NULL,
109                                   &test_connection, NULL);
110   return ok;
111 }
112
113 /* end of test_transport_dv.c */